/* =========================================================
   Hub & Link ME — Theme (light/white & navy dark)
   ========================================================= */
:root{
  --navy:#1b2a6b;
  --navy-700:#16235a;
  --navy-900:#0b1230;
  --red:#d8232a;

  --bg:#ffffff;
  --bg-alt:#f5f7fb;
  --surface:#ffffff;
  --text:#0e1430;
  --muted:#5a6079;
  --border:#e6e9f2;
  --primary:var(--navy);
  --primary-contrast:#fff;
  --accent:var(--red);
  --shadow:0 10px 30px rgba(15,23,60,.08);
  --radius:14px;
  --container:1200px;
}
html[data-theme="dark"]{
  --bg:#0a1230;
  --bg-alt:#0e1740;
  --surface:#111c4d;
  --text:#eef1ff;
  --muted:#aab2d8;
  --border:rgba(255,255,255,.08);
  --primary:#3b54c4;
  --shadow:0 10px 30px rgba(0,0,0,.45);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;transition:background .3s,color .3s}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .2s}
a:hover{color:var(--accent)}
h1,h2,h3,h4{font-family:'Sora',sans-serif;line-height:1.15;margin:0 0 .5em;font-weight:700;letter-spacing:-.02em}
h1{font-size:clamp(2.2rem,5vw,3.8rem);font-weight:800}
h2{font-size:clamp(1.75rem,3.2vw,2.5rem)}
h3{font-size:1.15rem}
p{margin:0 0 1em;color:var(--muted)}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.55rem;padding:.7rem 1.25rem;border-radius:999px;font-weight:600;font-size:.95rem;cursor:pointer;border:1px solid transparent;transition:all .2s ease}
.btn--lg{padding:.95rem 1.7rem;font-size:1rem}
.btn--primary{background:var(--primary);color:var(--primary-contrast)}
.btn--primary:hover{background:var(--navy-700);transform:translateY(-2px);color:#fff;box-shadow:var(--shadow)}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn--ghost:hover{background:#fff;color:var(--navy)}

.eyebrow{display:inline-flex;align-items:center;gap:.4rem;font-size:.75rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem}
.eyebrow--light{color:#fff;opacity:.9}
.lead{font-size:1.05rem;color:var(--muted);max-width:55ch}

/* Topbar */
.topbar{background:var(--navy-900);color:#dfe3ff;font-size:.85rem}
.topbar__inner{display:flex;justify-content:space-between;align-items:center;padding:10px 24px;flex-wrap:wrap;gap:8px}
.topbar__meta{display:flex;gap:22px;flex-wrap:wrap;align-items:center}
.topbar a, .topbar span{color:#dfe3ff;display:inline-flex;align-items:center;gap:.45rem}
.topbar a:hover{color:#fff}
.topbar__social{display:flex;gap:10px}
.topbar__social a{width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.08);display:grid;place-items:center;font-size:.75rem;transition:all .2s}
.topbar__social a:hover{background:var(--accent);transform:translateY(-2px)}
.topbar__hide-sm{display:inline-flex}
@media(max-width:720px){.topbar__hide-sm{display:none}}

/* Header */
.header{position:sticky;top:0;z-index:50;background:color-mix(in oklab,var(--bg) 88%,transparent);backdrop-filter:saturate(140%) blur(12px);border-bottom:1px solid var(--border)}
.header__inner{display:flex;align-items:center;justify-content:space-between;padding:14px 4px;gap:16px } 
.brand{display:flex;align-items:center;gap:10px}
.brand img{width:300px;height:65px;object-fit:contain}
.brand span{display:flex;flex-direction:column;line-height:1.05}
.brand strong{font-family:'Sora',sans-serif;font-size:1.05rem;color:var(--text)}
.brand small{font-size:.7rem;letter-spacing:.18em;color:var(--muted);text-transform:uppercase}
.nav{display:flex;gap:28px}
.nav a{font-weight:500;font-size:.95rem;position:relative;padding:6px 0}
.nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--accent);transition:width .25s}
.nav a:hover::after{width:100%}
.header__actions{display:flex;align-items:center;gap:12px}
.icon-btn{width:40px;height:40px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;font-size:1rem;display:inline-flex;align-items:center;justify-content:center;transition:all .2s}
.icon-btn:hover{border-color:var(--accent);color:var(--accent)}
.nav-toggle{display:none}

/* Pro theme toggle */
.theme-toggle{
  width:62px;height:32px;border-radius:999px;border:1px solid var(--border);
  background:var(--bg-alt);position:relative;cursor:pointer;padding:0;
  transition:background .3s,border-color .3s;
}
.theme-toggle:hover{border-color:var(--accent)}
.theme-toggle__track{position:relative;display:block;width:100%;height:100%}
.theme-toggle__thumb{
  position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;
  background:linear-gradient(135deg,#fff,#e6e9f2);
  box-shadow:0 2px 6px rgba(0,0,0,.2);
  transition:transform .3s cubic-bezier(.4,0,.2,1),background .3s;
}
html[data-theme="dark"] .theme-toggle{background:var(--navy-900)}
html[data-theme="dark"] .theme-toggle__thumb{
  transform:translateX(30px);
  background:linear-gradient(135deg,#3b54c4,var(--navy));
}
.theme-toggle__icon{position:absolute;top:50%;transform:translateY(-50%);font-size:.7rem;transition:opacity .3s,color .3s}
.theme-toggle__icon--sun{left:8px;color:#f59e0b;opacity:1}
.theme-toggle__icon--moon{right:8px;color:#9aa3d0;opacity:.4}
html[data-theme="dark"] .theme-toggle__icon--sun{opacity:.4}
html[data-theme="dark"] .theme-toggle__icon--moon{opacity:1;color:#cfd5f3}

/* ============ HERO SLIDER ============ */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero__slides{position:absolute;inset:0}
.hero__slide{
  position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transform:scale(1.08);
  transition:opacity 1.2s ease, transform 7s ease;
}
.hero__slide.is-active{opacity:1;transform:scale(1.0)}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(11,18,48,.88) 0%,rgba(11,18,48,.55) 55%,rgba(11,18,48,.25) 100%)}
.hero__inner{position:relative;padding:130px 24px;max-width:var(--container);width:100%}
.hero h1{color:#fff;max-width:18ch}
.hero p{color:#dbe1ff;max-width:55ch;font-size:1.1rem}
.hero .accent{background:linear-gradient(90deg,#ff5b62,#ffb1b4);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero__cta{display:flex;flex-wrap:wrap;gap:12px;margin:24px 0 50px}
.hero__stats{display:flex;flex-wrap:wrap;gap:40px;padding-top:30px;border-top:1px solid rgba(255,255,255,.18)}
.hero__stats strong{display:block;font-family:'Sora',sans-serif;font-size:2rem;color:#fff}
.hero__stats span{color:#c8d0f3;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase}
.hero__nav{
  position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;
  display:grid;place-items:center;cursor:pointer;backdrop-filter:blur(8px);transition:all .25s;z-index:3;
}
.hero__nav:hover{background:var(--accent);border-color:var(--accent);transform:translateY(-50%) scale(1.08)}
.hero__nav--prev{left:24px}.hero__nav--next{right:24px}
.hero__dots{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:3}
.hero__dots button{width:30px;height:5px;border-radius:999px;border:none;background:rgba(255,255,255,.35);cursor:pointer;transition:all .25s;padding:0}
.hero__dots button.is-active{background:var(--accent);width:50px}
.hero h1,.hero p,.hero__cta,.hero__stats{animation:slideUp .8s ease-out both}
.hero p{animation-delay:.15s}.hero__cta{animation-delay:.3s}.hero__stats{animation-delay:.45s}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* Sections */
.section{padding:96px 0}
.section--alt{background:var(--bg-alt)}
.section__head{text-align:center;max-width:680px;margin:0 auto 56px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}

/* About */
.about__img{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.about__img img{aspect-ratio:4/3;object-fit:cover;transition:transform .6s}
.about__img:hover img{transform:scale(1.05)}
.about__badge{position:absolute;left:20px;bottom:20px;background:var(--accent);color:#fff;border-radius:12px;padding:14px 18px;box-shadow:var(--shadow)}
.about__badge strong{font-family:'Sora',sans-serif;font-size:1.8rem;display:block;line-height:1}
.about__badge span{font-size:.8rem;opacity:.9}
.mv{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:24px 0}
.mv__card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.mv__icon{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,var(--navy),var(--navy-700));color:#fff;display:grid;place-items:center;margin-bottom:12px}
.mv__card h3{color:var(--primary);margin-bottom:6px}
.mv__card p{margin:0;font-size:.92rem}

/* Services */
.services{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.service{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;transition:all .25s;display:flex;flex-direction:column}
.service:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--accent)}
.service__icon{width:56px;height:56px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,var(--navy),var(--navy-700));color:#fff;font-size:1.4rem;margin-bottom:18px;transition:transform .3s}
.service:hover .service__icon{transform:rotate(-6deg) scale(1.05);background:linear-gradient(135deg,var(--accent),#ff6b71)}
.service h3{margin-bottom:8px}
.service p{flex:1;font-size:.92rem}
.service a{color:var(--accent);font-weight:600;font-size:.9rem;margin-top:10px;display:inline-flex;align-items:center;gap:.4rem}

/* ============ SECTORS ============ */
.sectors{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.sector{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:30px 22px;text-align:center;transition:all .3s;position:relative;overflow:hidden;
}
.sector::before{
  content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--navy),var(--accent));
  opacity:0;transition:opacity .3s;z-index:0;
}
.sector > *{position:relative;z-index:1;transition:color .3s}
.sector i{font-size:2.2rem;color:var(--accent);margin-bottom:14px;transition:all .3s;display:inline-block}
.sector h3{margin-bottom:6px}
.sector p{font-size:.9rem;margin:0}
.sector:hover{transform:translateY(-6px);border-color:transparent;box-shadow:var(--shadow)}
.sector:hover::before{opacity:1}
.sector:hover i, .sector:hover h3, .sector:hover p{color:#fff}
.sector:hover i{transform:scale(1.15)}

/* CTA strip */
.cta{position:relative;background-size:cover;background-position:center;color:#fff;padding:110px 0}
.cta__overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(11,18,48,.92),rgba(216,35,42,.55))}
.cta__inner{position:relative;text-align:center;max-width:720px;margin:0 auto}
.cta h2{color:#fff}
.checklist{list-style:none;padding:0;margin:24px 0;display:grid;grid-template-columns:1fr 1fr;gap:14px;text-align:left;max-width:520px;margin-left:auto;margin-right:auto}
.checklist li{color:#fff;display:flex;align-items:center;gap:.6rem}
.checklist li i{color:#7CFFB4;font-size:1.1rem}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;text-align:center}
.stats > div{padding:28px 16px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);transition:all .25s}
.stats > div:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--accent)}
.stats i{font-size:1.6rem;color:var(--accent);margin-bottom:10px;display:block}
.stats strong{font-family:'Sora',sans-serif;font-size:2.2rem;color:var(--primary);display:block}
.stats span{font-size:.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}

/* Contact */
.contact-list{list-style:none;padding:0;margin:20px 0;display:grid;gap:14px}
.contact-list li{color:var(--muted);display:flex;align-items:flex-start;gap:.75rem}
.contact-list i{color:var(--accent);margin-top:4px}
.form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);display:grid;gap:14px}
.form label{display:grid;gap:6px;font-size:.85rem;font-weight:600;color:var(--text)}
.form input,.form textarea{font:inherit;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px 14px;outline:none;transition:all .2s}
.form input:focus,.form textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(216,35,42,.15)}
.form__status{margin:0;font-size:.9rem;color:var(--accent);min-height:1.2em}

/* Footer */
.footer{background:var(--navy-900);color:#cfd5f3;padding:64px 0 24px}
.footer h4{color:#fff;margin-bottom:14px;font-size:1rem}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2px}
.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:10px;font-size:.92rem}
.footer ul li{display:flex;align-items:center;gap:.5rem}
.footer ul li i{color:var(--accent);font-size:.85rem;width:16px}
.footer a:hover{color:#fff}
.brand--footer strong{color:#fff}
.brand--footer small{color:#9aa3d0}
.footer__social{display:flex;gap:10px;margin-top:16px}
.footer__social a{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);display:grid;place-items:center;transition:all .25s}
.footer__social a:hover{background:var(--accent);transform:translateY(-3px);color:#fff}
.footer__bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:18px;margin-top:40px;text-align:center;color:#9aa3d0}

/* Reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* Responsive */
@media (max-width:960px){
  .grid-2{grid-template-columns:1fr;gap:40px}
  .services,.sectors{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:1fr 1fr}
  .nav{position:absolute;top:100%;left:0;right:0;background:var(--surface);flex-direction:column;gap:0;padding:10px 24px;border-bottom:1px solid var(--border);display:none}
  .nav.open{display:flex}
  .nav a{padding:12px 0;border-bottom:1px solid var(--border)}
  .nav-toggle{display:inline-flex}
  .section{padding:72px 0}
  .hero__inner{padding:90px 24px}
  .hero__nav{width:40px;height:40px}
  .checklist{grid-template-columns:1fr}
}
@media (max-width:560px){
  .services,.sectors{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .footer__grid{grid-template-columns:1fr}
  .mv{grid-template-columns:1fr}
  .hero__stats{gap:24px}
  .hero__nav{display:none}
}



/* =========================================
   PREMIUM MOBILE NAVIGATION
========================================= */

@media (max-width:960px){

  .header{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    z-index:9999;
    background:color-mix(in oklab,var(--bg) 92%,transparent);
    backdrop-filter:blur(18px);
  }

  body{
    padding-top:82px;
  }

  .header__inner{
    padding:14px 2px;
    gap:10px;
  }

  .brand img{
    width:230px;
    height:65px;
  }

  .brand strong{
    font-size:.95rem;
  }

  .brand small{
    font-size:.62rem;
  }

  /* Right Side Actions */
  .header__actions{
    margin-left:auto;
    gap:10px;
  }

  /* Dark Toggle Fixed Style */
  .theme-toggle{
    width:58px;
    height:30px;
    flex-shrink:0;
  }

  .theme-toggle__thumb{
    width:22px;
    height:22px;
  }

  html[data-theme="dark"] .theme-toggle__thumb{
    transform:translateX(28px);
  }

  /* Menu Button */
  .nav-toggle{
    display:flex;
    width:42px;
    height:42px;
    border-radius:12px;
    background:var(--surface);
    border:1px solid var(--border);
    box-shadow:0 4px 18px rgba(0,0,0,.08);
  }

  .nav-toggle i{
    font-size:1.05rem;
  }

  /* MOBILE MENU */
  .nav{
    position:fixed;
    top:78px;
    left:-100%;
    width:82%;
    max-width:340px;
    height:calc(100vh - 78px);
    background:var(--surface);
    display:flex;
    flex-direction:column;
    padding:26px;
    gap:6px;
    transition:left .35s ease;
    border-right:1px solid var(--border);
    box-shadow:0 15px 40px rgba(0,0,0,.18);
    overflow-y:auto;
    z-index:9998;
  }

  .nav.open{
    left:0;
  }

  /* Mobile Links */
  .nav a{
    padding:15px 16px;
    border-radius:12px;
    font-size:1rem;
    font-weight:600;
    border:none;
    transition:all .25s ease;
  }

  .nav a:hover{
    background:var(--primary);
    color:#fff;
    transform:translateX(4px);
  }

  .nav a::after{
    display:none;
  }

  /* Mobile Quote Button Hide */
  .header .btn--primary{
    display:none;
  }

  /* Overlay */
  .mobile-overlay{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.45);
    opacity:0;
    visibility:hidden;
    transition:.3s;
    z-index:9990;
    backdrop-filter:blur(3px);
  }

  .mobile-overlay.active{
    opacity:1;
    visibility:visible;
  }
}

/* Small Phones */
@media(max-width:560px){

  .header__inner{
    padding:12px 2px;
  }

@media(max-width:560px){

  .brand{
    gap:8px;
  }

  .brand span{
    display:flex;
  }

  .brand strong{
    font-size:.78rem;
    line-height:1;
  }

  .brand small{
    font-size:.52rem;
    letter-spacing:.12em;
    line-height:1;
  }

}

  .nav{
    width:88%;
  }

  .theme-toggle{
    width:54px;
    height:28px;
  }

  .theme-toggle__thumb{
    width:20px;
    height:20px;
  }

  html[data-theme="dark"] .theme-toggle__thumb{
    transform:translateX(26px);
  }

}



/* =========================================================
   Floating Action Button + Side Panel (Quick Services)
   ========================================================= */
.fab{position:fixed;right:22px;bottom:22px;width:62px;height:62px;border-radius:50%;border:none;cursor:pointer;background:linear-gradient(135deg,var(--accent),#ff5a60);color:#fff;font-size:1.4rem;box-shadow:0 14px 32px rgba(216,35,42,.45);z-index:1000;display:flex;align-items:center;justify-content:center;transition:transform .25s ease}
.fab:hover{transform:scale(1.08) rotate(-6deg)}
.fab__pulse{position:absolute;inset:0;border-radius:50%;background:var(--accent);opacity:.55;animation:fab-pulse 1.8s ease-out infinite;z-index:-1}
@keyframes fab-pulse{0%{transform:scale(1);opacity:.55}100%{transform:scale(1.7);opacity:0}}

.side-panel{position:fixed;inset:0;z-index:1100;visibility:hidden;opacity:0;transition:opacity .25s ease,visibility .25s}
.side-panel.open{visibility:visible;opacity:1}
.side-panel__backdrop{position:absolute;inset:0;background:rgba(8,14,40,.55);backdrop-filter:blur(4px)}
.side-panel__drawer{position:absolute;right:0;top:0;bottom:0;width:min(440px,92vw);background:var(--surface);box-shadow:-20px 0 50px rgba(0,0,0,.25);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .35s cubic-bezier(.5,.1,.2,1)}
.side-panel.open .side-panel__drawer{transform:translateX(0)}
.side-panel__head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,var(--navy),var(--navy-700));color:#fff}
.side-panel__head h3{margin:0;color:#fff;font-size:1.05rem}
.side-panel__close{background:rgba(255,255,255,.15);border:none;color:#fff;width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:1rem;transition:background .2s}
.side-panel__close:hover{background:rgba(255,255,255,.3)}
.side-panel__tabs{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--border);background:var(--bg-alt)}
.sp-tab{background:none;border:none;padding:14px 6px;font-size:.78rem;font-weight:600;color:var(--muted);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;border-bottom:3px solid transparent;transition:all .2s;font-family:inherit}
.sp-tab i{font-size:1.1rem}
.sp-tab:hover{color:var(--primary)}
.sp-tab.is-active{color:var(--accent);border-bottom-color:var(--accent);background:var(--surface)}
.side-panel__body{flex:1;overflow-y:auto;padding:22px}
.sp-pane{display:none;animation:sp-fade .3s ease}
.sp-pane.is-active{display:block}
@keyframes sp-fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.sp-lead{color:var(--muted);margin:0 0 16px;font-size:.92rem}
.sp-form{display:flex;flex-direction:column;gap:12px}
.sp-form label{display:flex;flex-direction:column;gap:5px;font-size:.82rem;font-weight:600;color:var(--text)}
.sp-form input,.sp-form select,.sp-form textarea{padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--bg);color:var(--text);font:inherit;font-weight:400;transition:border-color .2s,box-shadow .2s}
.sp-form input:focus,.sp-form select:focus,.sp-form textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(27,42,107,.15)}
.sp-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.sp-form .btn{margin-top:6px;justify-content:center}
.sp-status{margin:14px 0 0;text-align:center;font-size:.9rem;font-weight:600;min-height:1.2em}
.sp-foot{margin-top:20px;padding-top:16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px;font-size:.85rem}
.sp-foot a{color:var(--muted);display:flex;align-items:center;gap:8px}
.sp-foot a:hover{color:var(--accent)}
@media (max-width:480px){
  .fab{width:56px;height:56px;right:16px;bottom:16px}
  .sp-tab{font-size:.7rem;padding:12px 4px}
  .sp-row{grid-template-columns:1fr}
}


/* =========================================
   MOBILE FIXES FOR QUICK PANEL
   ========================================= */

@media (max-width:480px){

  /* Full screen drawer */

  .side-panel__drawer{
    width:100vw;
    max-width:100vw;
    height:100vh;
    border-radius:0;
  }

  /* Header */

  .side-panel__head{
    padding:14px 16px;
    min-height:64px;
    display:flex;
    align-items:center;
    justify-content:space-between;
  }

  .side-panel__head h3{
    font-size:.95rem;
    display:flex;
    align-items:center;
    gap:8px;
    padding-right:10px;
  }

  /* Close button */

  .side-panel__close{
    width:40px;
    height:40px;
    min-width:40px;
    min-height:40px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:50%;
    font-size:1rem;
    flex-shrink:0;
  }

  /* Tabs */

  .side-panel__tabs{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    overflow:hidden;
  }

  .side-panel .sp-tab{
    padding:10px 2px;
    font-size:.62rem;
    line-height:1.2;
    text-align:center;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
  }

  .side-panel .sp-tab i{
    font-size:1rem;
    margin-bottom:4px;
  }

  /* Body */

  .side-panel__body{
    padding:16px;
    overflow-y:auto;
  }

  /* Forms */

  .side-panel .sp-form input,
  .side-panel .sp-form select,
  .side-panel .sp-form textarea{
    font-size:16px;
    padding:12px;
  }

  /* Footer */

  .side-panel .sp-foot{
    padding-bottom:20px;
  }

}

/* =========================================
   EXTRA SMALL DEVICE FIX
   ========================================= */

@media (max-width:360px){

  .side-panel .sp-tab{
    font-size:.55rem;
  }

  .side-panel .sp-tab i{
    font-size:.85rem;
  }

  .side-panel__head h3{
    font-size:.85rem;
  }

}



@media (max-width:768px){

  .side-panel__drawer{
      width:100vw !important;
      max-width:100vw !important;
      height:100vh;
      right:0;
      top:0;
      border-radius:0;
  }

  .side-panel__body{
      padding:20px;
  }

  .side-panel__tabs{
      display:flex;
      overflow-x:auto;
      white-space:nowrap;
      scrollbar-width:none;
  }

  .side-panel__tabs::-webkit-scrollbar{
      display:none;
  }

  .sp-tab{
      min-width:90px;
      flex-shrink:0;
      font-size:12px;
  }

  .sp-tab i{
      font-size:16px;
      margin-bottom:4px;
  }

  .side-panel__head{
      display:flex;
      justify-content:space-between;
      align-items:center;
      padding:15px;
  }

  .side-panel__head h3{
      font-size:18px;
      margin:0;
      color:#fff;
  }

  .side-panel__close{
      display:flex !important;
      align-items:center;
      justify-content:center;
      width:40px;
      height:40px;
      font-size:18px;
      color:#fff;
      background:rgba(255,255,255,.15);
  }

}