@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,300&family=DM+Mono:wght@400;500&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit}
input,select,textarea{font:inherit}

:root{
  --white:     #ffffff;
  --snow:      #f8fafa;
  --mist:      #f0f4f4;
  --pearl:     #e8eeee;
  --border:    #dde5e5;
  --mid:       #b0bec0;
  --muted:     #7a9090;
  --ink:       #0d1f1f;
  --teal:      #0a6e6e;
  --teal2:     #085a5a;
  --teal3:     #064848;
  --teal-lt:   rgba(10,110,110,0.08);
  --teal-gl:   rgba(10,110,110,0.12);
  --red:       #d42b2b;
  --red-lt:    rgba(212,43,43,0.08);
  --green:     #0d7a4e;
  --green-lt:  rgba(13,122,78,0.08);
  --amber:     #c47d0a;
  --amber-lt:  rgba(196,125,10,0.08);
  --blue:      #1a5fa8;
  --cyan:      #0891b2;

  --syne:  'Syne', sans-serif;
  --dm:    'DM Sans', sans-serif;
  --mono:  'DM Mono', monospace;

  --ease:    cubic-bezier(0.4,0,0.2,1);
  --spring:  cubic-bezier(0.34,1.56,0.64,1);
  --sh-sm:   0 1px 4px rgba(0,0,0,0.05),0 1px 2px rgba(0,0,0,0.04);
  --sh-md:   0 4px 20px rgba(0,0,0,0.07),0 2px 8px rgba(0,0,0,0.04);
  --sh-lg:   0 16px 48px rgba(0,0,0,0.09),0 4px 16px rgba(0,0,0,0.05);
  --sh-xl:   0 32px 80px rgba(0,0,0,0.12),0 8px 32px rgba(0,0,0,0.06);
}

html{scroll-behavior:smooth;font-size:16px}
body{
  background:var(--white);
  color:var(--ink);
  font-family:var(--dm);
  font-weight:300;
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* ── TYPOGRAPHY ── */
.label{
  font-family:var(--mono);
  font-size:0.62rem;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--teal);
  display:inline-flex;
  align-items:center;
  gap:0.6rem;
  margin-bottom:0.85rem;
}
.label::before{content:'';display:block;width:1.5rem;height:1.5px;background:var(--teal);flex-shrink:0}
.label.white{color:rgba(255,255,255,0.55)}.label.white::before{background:rgba(255,255,255,0.35)}
.label.center{justify-content:center}.label.center::before{display:none}
.label.red-l{color:var(--red)}.label.red-l::before{background:var(--red)}

.display{
  font-family:var(--syne);font-weight:800;
  line-height:0.93;letter-spacing:-0.03em;color:var(--ink);
}
.display.xl {font-size:clamp(3.2rem,6.5vw,6.5rem)}
.display.lg {font-size:clamp(2.6rem,5vw,5rem)}
.display.md {font-size:clamp(2rem,3.8vw,3.8rem)}
.display.sm {font-size:clamp(1.7rem,3vw,2.8rem)}
.display span{color:var(--teal)}
.display .red{color:var(--red)}
.display .white{color:var(--white)}

.body-lg{font-size:1.05rem;color:var(--muted);line-height:1.8;max-width:540px}
.body-md{font-size:0.92rem;color:var(--muted);line-height:1.75}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:0.5rem;
  font-family:var(--syne);font-weight:700;
  font-size:0.82rem;letter-spacing:0.01em;
  padding:0.85rem 1.75rem;border-radius:3px;
  transition:all 0.25s var(--ease);
  white-space:nowrap;
}
.btn-teal{background:var(--teal);color:var(--white)}
.btn-teal:hover{background:var(--teal2);transform:translateY(-2px);box-shadow:0 10px 28px rgba(10,110,110,0.28)}
.btn-red{background:var(--red);color:var(--white)}
.btn-red:hover{background:#b52424;transform:translateY(-2px);box-shadow:0 10px 28px rgba(212,43,43,0.28)}
.btn-ink{background:var(--ink);color:var(--white)}
.btn-ink:hover{background:#1a3333;transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--border)}
.btn-outline:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-lt)}
.btn-outline-white{background:transparent;color:var(--white);border:1.5px solid rgba(255,255,255,0.3)}
.btn-outline-white:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.5)}
.btn-ghost-teal{background:transparent;color:var(--teal);padding-left:0;padding-right:0;gap:0.3rem}
.btn-ghost-teal:hover{gap:0.6rem}
.btn-group{display:flex;gap:1rem;flex-wrap:wrap}

/* ── NAV ── */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  background:rgba(255,255,255,0.97);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--border);
  transition:box-shadow 0.3s;
}
#nav.scrolled{box-shadow:var(--sh-md)}
.nav-wrap{
  max-width:1280px;margin:0 auto;
  padding:0 3rem;height:72px;
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
}
.nav-logo{
  font-family:var(--syne);font-weight:800;
  font-size:1.2rem;letter-spacing:-0.02em;
  color:var(--ink);display:flex;align-items:center;gap:0.6rem;
}
.logo-cross{
  width:34px;height:34px;background:var(--teal);
  border-radius:4px;display:flex;align-items:center;justify-content:center;
  position:relative;flex-shrink:0;
}
.logo-cross::before,.logo-cross::after{
  content:'';position:absolute;background:var(--white);border-radius:1px;
}
.logo-cross::before{width:14px;height:4px}
.logo-cross::after{width:4px;height:14px}
.nav-links{display:flex;align-items:center;gap:0}
.nav-links a{
  font-family:var(--mono);font-size:0.63rem;
  letter-spacing:0.1em;text-transform:uppercase;
  color:var(--muted);padding:0.5rem 0.85rem;
  border-radius:3px;transition:all 0.2s;
  position:relative;
}
.nav-links a:hover,.nav-links a.active{color:var(--teal)}
.nav-links a.active::after{content:'';position:absolute;bottom:-1px;left:0.85rem;right:0.85rem;height:2px;background:var(--teal)}
.nav-right{display:flex;align-items:center;gap:0.75rem}
.nav-emergency{
  display:flex;align-items:center;gap:0.45rem;
  font-family:var(--mono);font-size:0.62rem;letter-spacing:0.08em;
  color:var(--red);border:1px solid rgba(212,43,43,0.25);
  padding:0.45rem 0.9rem;border-radius:3px;
  transition:all 0.2s;
}
.nav-emergency:hover{background:var(--red-lt);border-color:var(--red)}
.nav-emergency .pulse{width:7px;height:7px;background:var(--red);border-radius:50%;animation:navPulse 1.5s infinite}
@keyframes navPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.5;transform:scale(0.8)}}
.nav-cta{
  font-family:var(--syne);font-weight:700;font-size:0.78rem;
  background:var(--teal);color:var(--white);
  padding:0.52rem 1.15rem;border-radius:3px;
  transition:all 0.2s;
}
.nav-cta:hover{background:var(--teal2);transform:translateY(-1px)}
.hamburger{display:none;flex-direction:column;gap:5px}
.hamburger span{display:block;width:22px;height:1.5px;background:var(--ink);transition:all 0.3s;border-radius:1px}

/* Mobile menu */
.mob-nav{
  display:none;position:fixed;inset:0;background:var(--white);
  z-index:499;flex-direction:column;align-items:center;justify-content:center;
  gap:2rem;padding-top:72px;
}
.mob-nav.open{display:flex}
.mob-nav a{font-family:var(--syne);font-weight:700;font-size:2rem;color:var(--muted);transition:color 0.2s}
.mob-nav a:hover{color:var(--teal)}
.mob-nav .mob-emerg{color:var(--red)}

/* ── LAYOUT ── */
.section{padding:7rem 0}
.section.tight{padding:4.5rem 0}
.container{max-width:1280px;margin:0 auto;padding:0 3rem}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}

/* ── TICKER ── */
.ticker-strip{overflow:hidden;background:var(--teal);padding:0.7rem 0;white-space:nowrap}
.ticker-inner{display:inline-flex;animation:tick 32s linear infinite}
.ticker-inner:hover{animation-play-state:paused}
.t-item{
  font-family:var(--mono);font-size:0.66rem;letter-spacing:0.14em;
  text-transform:uppercase;color:rgba(255,255,255,0.7);
  padding:0 2.5rem;display:inline-flex;align-items:center;gap:2.5rem;
}
.t-item .sep{color:rgba(255,255,255,0.3);font-size:0.5rem}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── URGENT BANNER ── */
.urgent-band{
  background:var(--red);padding:0.65rem 0;
  display:flex;align-items:center;justify-content:center;gap:1rem;
}
.urgent-band span{
  font-family:var(--mono);font-size:0.65rem;letter-spacing:0.12em;
  text-transform:uppercase;color:rgba(255,255,255,0.9);
}
.urgent-band a{
  font-family:var(--mono);font-size:0.65rem;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--white);font-weight:600;
  text-decoration:underline;
}
.ub-dot{width:7px;height:7px;background:rgba(255,255,255,0.8);border-radius:50%;animation:navPulse 1.2s infinite}

/* ── STATS BAND ── */
.stats-band{background:var(--ink);padding:3.5rem 0;border-top:1px solid rgba(255,255,255,0.04)}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr)}
.stat-cell{padding:1.5rem 2rem;border-right:1px solid rgba(255,255,255,0.08);text-align:center}
.stat-cell:last-child{border-right:none}
.stat-n{font-family:var(--syne);font-weight:800;font-size:2.8rem;line-height:1;color:var(--white);display:block}
.stat-n span{color:var(--teal)}
.stat-l{font-family:var(--mono);font-size:0.58rem;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-top:0.4rem;display:block}

/* ── CARDS ── */
.svc-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:4px;overflow:hidden;
  transition:all 0.3s var(--ease);
  display:flex;flex-direction:column;
}
.svc-card:hover{box-shadow:var(--sh-lg);transform:translateY(-4px);border-color:var(--teal)}
.sc-top{padding:2.25rem 2rem 1.75rem;position:relative}
.sc-icon{
  width:56px;height:56px;
  background:var(--teal-lt);border:1px solid rgba(10,110,110,0.15);
  border-radius:8px;display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;margin-bottom:1.25rem;
}
.sc-num{position:absolute;top:1.5rem;right:1.75rem;font-family:var(--mono);font-size:0.52rem;letter-spacing:0.1em;color:var(--pearl)}
.sc-title{font-family:var(--syne);font-weight:700;font-size:1.1rem;color:var(--ink);margin-bottom:0.5rem}
.sc-text{font-size:0.875rem;color:var(--muted);line-height:1.72}
.sc-bottom{
  margin-top:auto;padding:1.25rem 2rem;
  border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
}
.sc-tag{font-family:var(--mono);font-size:0.58rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--teal)}
.sc-arrow{font-size:0.75rem;color:var(--teal);transition:transform 0.2s}
.svc-card:hover .sc-arrow{transform:translateX(4px)}

/* ── STATUS BADGES ── */
.badge{display:inline-flex;align-items:center;gap:0.35rem;font-family:var(--mono);font-size:0.58rem;letter-spacing:0.06em;padding:0.28rem 0.7rem;border-radius:20px;white-space:nowrap}
.badge .dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}
.b-teal{background:var(--teal-lt);color:var(--teal);border:1px solid rgba(10,110,110,0.18)}
.b-red{background:var(--red-lt);color:var(--red);border:1px solid rgba(212,43,43,0.2)}
.b-green{background:var(--green-lt);color:var(--green);border:1px solid rgba(13,122,78,0.2)}
.b-amber{background:var(--amber-lt);color:var(--amber);border:1px solid rgba(196,125,10,0.2)}
.b-blue{background:rgba(26,95,168,0.08);color:var(--blue);border:1px solid rgba(26,95,168,0.18)}
.b-teal .dot,.b-red .dot,.b-green .dot{animation:blink 1.5s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}

/* ── TRACKING BAR ── */
.track-bar{display:flex;background:var(--white);border:1.5px solid var(--border);border-radius:3px;overflow:hidden;box-shadow:var(--sh-sm);transition:border-color 0.2s}
.track-bar:focus-within{border-color:var(--teal);box-shadow:0 0 0 3px rgba(10,110,110,0.1)}
.track-input{flex:1;padding:1rem 1.25rem;background:none;border:none;outline:none;font-family:var(--mono);font-size:0.85rem;letter-spacing:0.04em;color:var(--ink)}
.track-input::placeholder{color:var(--mid)}
.track-go{background:var(--teal);color:var(--white);padding:0 1.75rem;font-family:var(--syne);font-weight:700;font-size:0.8rem;transition:background 0.2s;display:flex;align-items:center;gap:0.4rem}
.track-go:hover{background:var(--teal2)}

/* ── RESULT PANEL ── */
.result-panel{display:none;background:var(--white);border:1.5px solid var(--border);border-radius:4px;overflow:hidden;margin-top:1rem;box-shadow:var(--sh-md)}
.rp-head{background:var(--ink);padding:1.25rem 1.75rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:0.75rem}
.rp-id{font-family:var(--mono);font-size:0.75rem;letter-spacing:0.06em;color:rgba(255,255,255,0.75)}
.rp-body{padding:1.75rem;display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.step-list{display:flex;flex-direction:column}
.step{display:flex;gap:1rem;padding-bottom:1.5rem}
.step:last-child{padding-bottom:0}
.step-dc{display:flex;flex-direction:column;align-items:center}
.step-dot{width:13px;height:13px;border-radius:50%;flex-shrink:0;border:2px solid var(--border)}
.step-dot.done{background:var(--teal);border-color:var(--teal)}
.step-dot.now{background:transparent;border-color:var(--teal);box-shadow:0 0 0 3px rgba(10,110,110,0.15)}
.step-dot.wait{background:var(--mist);border-color:var(--border)}
.step-line{flex:1;width:1px;background:var(--border);margin:2px 0}
.step-dot.done+.step-line{background:var(--teal)}
.step-meta{padding-bottom:1rem}
.step-title{font-family:var(--syne);font-weight:700;font-size:0.875rem;color:var(--ink)}
.step-title.now{color:var(--teal)}
.step-title.wait{color:var(--mid)}
.step-loc{font-family:var(--mono);font-size:0.6rem;color:var(--muted);margin-top:0.1rem}
.step-time{font-family:var(--mono);font-size:0.57rem;color:var(--mid);margin-top:0.08rem}
.rp-map{background:var(--mist);border-radius:4px;overflow:hidden;height:220px}
.rp-map svg{width:100%;height:100%}
.rp-meta{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:1.25rem 1.75rem;border-top:1px solid var(--border);background:var(--snow)}
.rm-l{font-family:var(--mono);font-size:0.54rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);margin-bottom:0.25rem}
.rm-v{font-family:var(--syne);font-weight:700;font-size:0.88rem;color:var(--ink)}

/* ── MAP SVG ANIMS ── */
.route-draw{stroke:var(--teal);stroke-width:2;fill:none;stroke-dasharray:800;stroke-dashoffset:800;animation:drawRoute 3s ease forwards 0.5s}
.route-draw2{stroke:rgba(10,110,110,0.3);stroke-width:1.5;fill:none;stroke-dasharray:600;stroke-dashoffset:600;animation:drawRoute 2.5s ease forwards 1s}
@keyframes drawRoute{to{stroke-dashoffset:0}}
.map-pulse-dot{animation:mapBlink 2s ease-in-out infinite}
@keyframes mapBlink{0%,100%{r:5}50%{r:8}}
.map-ring-out{fill:none;animation:ringOut 2s ease-out infinite}
@keyframes ringOut{0%{r:8;opacity:1}100%{r:22;opacity:0}}

/* ── DASHBOARD ── */
.dash-shell{background:var(--white);border:1px solid var(--border);border-radius:6px;overflow:hidden;box-shadow:var(--sh-xl)}
.dash-chrome{background:var(--snow);padding:0.65rem 1.1rem;display:flex;align-items:center;gap:0.75rem;border-bottom:1px solid var(--border)}
.dc-dots{display:flex;gap:0.35rem}
.dc-dots span{width:10px;height:10px;border-radius:50%}
.dc-url{flex:1;background:var(--mist);border:1px solid var(--border);border-radius:12px;padding:0.28rem 1rem;font-family:var(--mono);font-size:0.58rem;letter-spacing:0.06em;color:var(--muted);text-align:center}
.dash-body{display:grid;grid-template-columns:200px 1fr 250px;height:380px}

/* sidebar */
.dash-sb{background:var(--ink);display:flex;flex-direction:column;padding:1.1rem;gap:0.15rem}
.dsb-logo{font-family:var(--syne);font-weight:800;font-size:0.8rem;color:var(--white);padding:0.65rem 0.6rem;margin-bottom:0.65rem;display:flex;align-items:center;gap:0.5rem}
.dsb-logo .cross{width:18px;height:18px;background:var(--teal);border-radius:3px;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}
.dsb-logo .cross::before,.dsb-logo .cross::after{content:'';position:absolute;background:var(--white);border-radius:1px}
.dsb-logo .cross::before{width:9px;height:2.5px}
.dsb-logo .cross::after{width:2.5px;height:9px}
.sb-grp-label{font-family:var(--mono);font-size:0.48rem;letter-spacing:0.16em;text-transform:uppercase;color:rgba(255,255,255,0.2);padding:0 0.6rem;margin:1rem 0 0.35rem}
.sb-item{display:flex;align-items:center;gap:0.6rem;padding:0.58rem 0.65rem;border-radius:3px;font-family:var(--mono);font-size:0.6rem;letter-spacing:0.04em;color:rgba(255,255,255,0.4);cursor:pointer;transition:all 0.2s}
.sb-item:hover{background:rgba(255,255,255,0.05);color:rgba(255,255,255,0.7)}
.sb-item.active{background:rgba(10,110,110,0.2);color:var(--teal)}
.sb-ic{font-size:0.82rem;width:15px;text-align:center}
.sb-badge{margin-left:auto;background:var(--red);color:var(--white);font-size:0.43rem;padding:0.1rem 0.38rem;border-radius:10px;font-weight:700}

/* main dash */
.dash-main{padding:1.25rem;display:flex;flex-direction:column;gap:0.9rem;background:var(--snow);overflow:hidden}
.dk-row{display:grid;grid-template-columns:repeat(3,1fr);gap:0.75rem}
.dk{background:var(--white);border:1px solid var(--border);border-radius:4px;padding:0.9rem 1rem;position:relative;overflow:hidden;transition:all 0.2s}
.dk:hover{border-color:var(--teal)}
.dk-accent{position:absolute;bottom:0;left:0;right:0;height:2.5px}
.dk-accent.teal{background:var(--teal)}
.dk-accent.red{background:var(--red)}
.dk-accent.green{background:var(--green)}
.dk-l{font-family:var(--mono);font-size:0.5rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);margin-bottom:0.4rem}
.dk-v{font-family:var(--syne);font-weight:800;font-size:1.6rem;color:var(--ink);line-height:1}
.dk-c{font-family:var(--mono);font-size:0.55rem;margin-top:0.2rem}
.dk-c.up{color:var(--green)}.dk-c.crit{color:var(--red)}.dk-c.ok{color:var(--teal)}
.dash-chart{background:var(--white);border:1px solid var(--border);border-radius:4px;padding:0.9rem 1rem;flex:1}
.chart-lbl{font-family:var(--mono);font-size:0.5rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);margin-bottom:0.6rem}
.bars{display:flex;align-items:flex-end;gap:5px;height:82px}
.bar-g{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px}
.bar-f{width:100%;border-radius:2px 2px 0 0;background:linear-gradient(to top,var(--teal),rgba(10,110,110,0.35));min-height:4px}
.bar-d{font-family:var(--mono);font-size:0.42rem;color:var(--mid)}

/* right panel */
.dash-rp{background:var(--white);border-left:1px solid var(--border);padding:1rem;display:flex;flex-direction:column;gap:0.55rem;overflow:hidden}
.drp-l{font-family:var(--mono);font-size:0.52rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);margin-bottom:0.1rem}
.pkg-row{background:var(--snow);border:1px solid var(--border);border-radius:3px;padding:0.6rem 0.7rem;display:flex;align-items:center;gap:0.6rem;transition:all 0.2s;cursor:pointer}
.pkg-row:hover{border-color:var(--teal);background:var(--mist)}
.pkg-ic{font-size:0.9rem;flex-shrink:0}
.pkg-info-id{font-family:var(--mono);font-size:0.58rem;color:var(--ink);font-weight:500}
.pkg-info-dest{font-family:var(--mono);font-size:0.5rem;color:var(--muted);margin-top:0.07rem}

/* ── COMPLIANCE SECTION ── */
.compliance-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:4px;overflow:hidden}
.comp-item{background:var(--white);padding:2rem;transition:background 0.25s}
.comp-item:hover{background:var(--snow)}
.comp-badge{display:inline-flex;align-items:center;gap:0.5rem;font-family:var(--mono);font-size:0.6rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--teal);background:var(--teal-lt);border:1px solid rgba(10,110,110,0.15);padding:0.3rem 0.7rem;border-radius:2px;margin-bottom:0.85rem}
.comp-title{font-family:var(--syne);font-weight:700;font-size:1rem;color:var(--ink);margin-bottom:0.35rem}
.comp-text{font-size:0.86rem;color:var(--muted);line-height:1.7}

/* ── FEATURE CARD ── */
.feat-card{background:var(--white);border:1px solid var(--border);border-radius:4px;padding:2.25rem 2rem;position:relative;overflow:hidden;transition:all 0.3s var(--ease)}
.feat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--teal);transform:scaleX(0);transform-origin:left;transition:transform 0.35s var(--ease)}
.feat-card:hover{box-shadow:var(--sh-lg);transform:translateY(-4px)}
.feat-card:hover::before{transform:scaleX(1)}
.fc-icon{width:50px;height:50px;background:var(--teal-lt);border:1px solid rgba(10,110,110,0.15);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.35rem;margin-bottom:1.2rem}
.fc-num{position:absolute;top:1.5rem;right:1.75rem;font-family:var(--mono);font-size:0.52rem;letter-spacing:0.1em;color:var(--pearl)}
.fc-title{font-family:var(--syne);font-weight:700;font-size:1.05rem;color:var(--ink);margin-bottom:0.45rem}
.fc-text{font-size:0.875rem;color:var(--muted);line-height:1.72}

/* ── INFO CARD ── */
.info-card{background:var(--white);border:1px solid var(--border);border-radius:4px;padding:1.5rem;display:flex;gap:1.1rem;align-items:flex-start;transition:all 0.25s}
.info-card:hover{box-shadow:var(--sh-md);border-color:var(--teal)}
.ic-icon{width:42px;height:42px;background:var(--teal-lt);border:1px solid rgba(10,110,110,0.12);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.ic-label{font-family:var(--mono);font-size:0.56rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--teal);margin-bottom:0.26rem}
.ic-value{font-family:var(--syne);font-weight:700;font-size:0.92rem;color:var(--ink)}
.ic-value a{color:inherit;transition:color 0.2s}.ic-value a:hover{color:var(--teal)}
.ic-sub{font-size:0.78rem;color:var(--muted);margin-top:0.12rem}
.ic-icon.red-ic{background:var(--red-lt);border-color:rgba(212,43,43,0.15)}

/* ── PROCESS STEPS ── */
.process-tl{position:relative;padding-left:2rem}
.process-tl::before{content:'';position:absolute;left:0;top:0;bottom:0;width:1px;background:var(--border)}
.ptl-item{position:relative;padding-bottom:2.25rem}
.ptl-item:last-child{padding-bottom:0}
.ptl-dot{position:absolute;left:-2.44rem;top:0.18rem;width:13px;height:13px;background:var(--teal);border-radius:50%;border:2.5px solid var(--white);box-shadow:0 0 0 1.5px var(--teal)}
.ptl-lbl{font-family:var(--mono);font-size:0.58rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--teal);margin-bottom:0.2rem}
.ptl-title{font-family:var(--syne);font-weight:700;font-size:0.975rem;color:var(--ink);margin-bottom:0.25rem}
.ptl-text{font-size:0.875rem;color:var(--muted);line-height:1.7}

/* ── FAQ ── */
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;text-align:left;padding:1.35rem 0;font-family:var(--syne);font-weight:600;font-size:0.95rem;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:color 0.2s}
.faq-q:hover{color:var(--teal)}
.faq-ic{width:25px;height:25px;border:1.5px solid var(--border);border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:0.9rem;color:var(--teal);flex-shrink:0;transition:all 0.3s}
.faq-item.open .faq-ic{transform:rotate(45deg);background:var(--teal);color:var(--white);border-color:var(--teal)}
.faq-ans{font-size:0.9rem;color:var(--muted);line-height:1.75;max-height:0;overflow:hidden;transition:max-height 0.4s var(--ease),padding 0.3s}
.faq-item.open .faq-ans{max-height:250px;padding-bottom:1.5rem}

/* ── CONTACT FORM ── */
.contact-form{display:flex;flex-direction:column;gap:1rem}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.cf-group{display:flex;flex-direction:column;gap:0.4rem}
.cf-group label{font-family:var(--mono);font-size:0.56rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted)}
.cf-group input,.cf-group select,.cf-group textarea{
  width:100%;padding:0.85rem 1rem;
  background:var(--white);border:1.5px solid var(--border);border-radius:3px;
  outline:none;font-size:0.9rem;color:var(--ink);transition:all 0.2s;
}
.cf-group input::placeholder,.cf-group textarea::placeholder{color:var(--mid)}
.cf-group input:focus,.cf-group select:focus,.cf-group textarea:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(10,110,110,0.08)}
.cf-group input.err{border-color:var(--red)}
.cf-group select{cursor:pointer}
.cf-group textarea{min-height:115px;resize:vertical}
.cf-submit{background:var(--teal);color:var(--white);font-family:var(--syne);font-weight:700;font-size:0.88rem;padding:1rem 2rem;border-radius:3px;transition:all 0.25s;display:flex;align-items:center;justify-content:center;gap:0.5rem}
.cf-submit:hover{background:var(--teal2);transform:translateY(-2px);box-shadow:0 10px 28px rgba(10,110,110,0.28)}

/* ── CTA SECTIONS ── */
.cta-dark{background:var(--ink);padding:6rem 0;position:relative;overflow:hidden}
.cta-dark::before{content:'';position:absolute;right:-80px;top:-80px;width:500px;height:500px;border-radius:50%;background:var(--teal);opacity:0.04}
.cta-teal{background:var(--teal);padding:6rem 0;position:relative;overflow:hidden}
.cta-teal::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 50%,rgba(255,255,255,0.05),transparent 60%)}
.cta-red{background:var(--red);padding:4rem 0;position:relative;overflow:hidden}

/* ── PAGE HERO ── */
.page-hero{padding-top:72px;background:var(--ink);position:relative;overflow:hidden;min-height:400px;display:flex;align-items:center}
.ph-dots{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,0.04) 1px,transparent 1px);background-size:32px 32px}
.ph-teal-glow{position:absolute;right:-120px;top:-120px;width:600px;height:600px;border-radius:50%;background:var(--teal);opacity:0.07}
.ph-inner{position:relative;z-index:2;padding:5rem 0}
.ph-inner .label{color:rgba(255,255,255,0.45)}.ph-inner .label::before{background:rgba(255,255,255,0.3)}
.ph-inner h1{font-family:var(--syne);font-weight:800;font-size:clamp(2.8rem,5.5vw,5rem);line-height:0.93;letter-spacing:-0.03em;color:var(--white);margin-bottom:1rem}
.ph-inner h1 span{color:var(--teal)}
.ph-inner p{font-size:1rem;color:rgba(255,255,255,0.45);max-width:500px}
.breadcrumb{background:var(--snow);border-bottom:1px solid var(--border)}
.bc-w{max-width:1280px;margin:0 auto;padding:0.75rem 3rem;display:flex;align-items:center;gap:0.5rem;font-family:var(--mono);font-size:0.6rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--mid)}
.bc-w a{color:var(--muted);transition:color 0.2s}.bc-w a:hover{color:var(--teal)}
.bc-w .sep{color:var(--border)}.bc-w .cur{color:var(--teal)}

/* ── TEMP MONITOR WIDGET ── */
.temp-widget{
  background:var(--white);border:1px solid var(--border);border-radius:6px;
  padding:1.25rem;box-shadow:var(--sh-md);
}
.tw-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.tw-title{font-family:var(--mono);font-size:0.6rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted)}
.tw-temp{font-family:var(--syne);font-weight:800;font-size:2rem;line-height:1}
.tw-temp.cold{color:var(--blue)}.tw-temp.warm{color:var(--amber)}
.tw-bar{height:8px;background:var(--mist);border-radius:4px;overflow:hidden;margin:0.5rem 0}
.tw-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,#1a5fa8,#0891b2);animation:fillBar 2s ease-out}
@keyframes fillBar{from{width:0}to{width:inherit}}
.tw-range{display:flex;justify-content:space-between;font-family:var(--mono);font-size:0.52rem;color:var(--mid)}

/* ── PHOTO STRIP ── */
.photo-strip{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:4px;height:340px}
.ps-item{overflow:hidden;position:relative;background:var(--mist)}
.ps-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.55s ease;filter:brightness(0.88)}
.ps-item:hover img{transform:scale(1.05);filter:brightness(0.95)}
.ps-label{position:absolute;bottom:0;left:0;right:0;padding:1rem;background:linear-gradient(to top,rgba(13,31,31,0.85),transparent);font-family:var(--syne);font-weight:700;font-size:0.82rem;color:var(--white)}

/* ── PHONE MOCKUP ── */
.phone-wrap{width:232px;height:476px;background:var(--white);border:8px solid var(--ink);border-radius:34px;overflow:hidden;box-shadow:var(--sh-xl);position:relative;flex-shrink:0}
.phone-notch{position:absolute;top:0;left:50%;transform:translateX(-50%);width:85px;height:20px;background:var(--ink);border-radius:0 0 12px 12px;z-index:10}
.phone-screen{height:100%;background:var(--snow);display:flex;flex-direction:column;padding:1.1rem 0.8rem 0.8rem;overflow:hidden}
.psc-top{margin-top:1.1rem;margin-bottom:0.75rem;display:flex;align-items:center;justify-content:space-between}
.psc-title{font-family:var(--syne);font-weight:800;font-size:0.9rem;color:var(--ink)}
.psc-map{height:110px;background:var(--mist);border-radius:8px;position:relative;overflow:hidden;margin-bottom:0.7rem}
.psc-map svg{width:100%;height:100%}
.psc-label{font-family:var(--mono);font-size:0.52rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);margin-bottom:0.45rem}
.psc-card{background:var(--white);border:1px solid var(--border);border-radius:6px;padding:0.6rem 0.7rem;margin-bottom:0.4rem;display:flex;align-items:center;gap:0.5rem}
.psc-status-dot{width:6px;height:6px;border-radius:50%;background:var(--teal);flex-shrink:0;animation:blink 1.5s infinite}
.psc-id{font-family:var(--mono);font-size:0.56rem;color:var(--ink);font-weight:500}
.psc-sub{font-family:var(--mono);font-size:0.48rem;color:var(--muted);margin-top:0.08rem}
.psc-prog{height:3px;background:var(--mist);border-radius:2px;margin-top:0.35rem;overflow:hidden}
.psc-bar{height:100%;background:var(--teal);border-radius:2px;width:65%;animation:pscGrow 1.2s ease-out}
@keyframes pscGrow{from{width:0}to{width:65%}}
.psc-btn{background:var(--teal);color:var(--white);font-family:var(--syne);font-weight:700;font-size:0.7rem;border-radius:7px;padding:0.6rem;text-align:center;margin-top:0.35rem}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(26px);transition:opacity 0.7s var(--ease),transform 0.7s var(--ease)}
.reveal.fl{transform:translateX(-26px)}
.reveal.fr{transform:translateX(26px)}
.reveal.sc{transform:scale(0.96)}
.reveal.visible{opacity:1;transform:none}
.d1{transition-delay:0.08s}.d2{transition-delay:0.16s}.d3{transition-delay:0.24s}.d4{transition-delay:0.32s}.d5{transition-delay:0.4s}

/* ── FOOTER ── */
footer{background:var(--ink);padding:5rem 0 0}
.fg{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:4rem;border-bottom:1px solid rgba(255,255,255,0.06)}
.f-logo{font-family:var(--syne);font-weight:800;font-size:1.2rem;letter-spacing:-0.02em;color:var(--white);display:flex;align-items:center;gap:0.6rem;margin-bottom:1rem}
.flc{width:28px;height:28px;background:var(--teal);border-radius:3px;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}
.flc::before,.flc::after{content:'';position:absolute;background:var(--white);border-radius:1px}
.flc::before{width:12px;height:3px}.flc::after{width:3px;height:12px}
.f-desc{font-size:0.875rem;color:rgba(255,255,255,0.4);line-height:1.75;margin-bottom:1.5rem}
.f-cert{display:flex;gap:0.5rem;flex-wrap:wrap}
.f-cert span{font-family:var(--mono);font-size:0.52rem;letter-spacing:0.1em;color:rgba(255,255,255,0.35);background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.08);padding:0.25rem 0.6rem;border-radius:2px}
.f-col h4{font-family:var(--mono);font-size:0.56rem;letter-spacing:0.16em;text-transform:uppercase;color:rgba(255,255,255,0.22);margin-bottom:1.2rem}
.f-col a{display:block;font-size:0.875rem;color:rgba(255,255,255,0.42);margin-bottom:0.55rem;transition:color 0.2s}
.f-col a:hover{color:var(--teal)}
.f-bottom{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 0;flex-wrap:wrap;gap:1rem}
.f-copy{font-family:var(--mono);font-size:0.57rem;letter-spacing:0.06em;color:rgba(255,255,255,0.18)}
.f-live{display:flex;align-items:center;gap:0.5rem;font-family:var(--mono);font-size:0.57rem;letter-spacing:0.06em;color:rgba(255,255,255,0.18)}
.f-ldot{width:6px;height:6px;background:var(--green);border-radius:50%;animation:blink 1.5s infinite}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .g4{grid-template-columns:1fr 1fr}
  .stats-row{grid-template-columns:1fr 1fr}
  .stat-cell:nth-child(2){border-right:none}
  .stat-cell:nth-child(3){border-right:1px solid rgba(255,255,255,0.08)}
  .stat-cell:nth-child(3),.stat-cell:nth-child(4){border-top:1px solid rgba(255,255,255,0.08)}
  .fg{grid-template-columns:1fr 1fr}
  .dash-body{grid-template-columns:1fr;height:auto}
  .dash-sb,.dash-rp{display:none}
}
@media(max-width:768px){
  .nav-links,.nav-right{display:none}
  .hamburger{display:flex}
  .container{padding:0 1.5rem}
  .section{padding:5rem 0}
  .g2,.g3{grid-template-columns:1fr}
  .g4{grid-template-columns:1fr}
  .stats-row{grid-template-columns:1fr 1fr}
  .fg{grid-template-columns:1fr}
  .f-bottom{flex-direction:column;text-align:center}
  .ph-inner{padding:3.5rem 0}
  .cf-row{grid-template-columns:1fr}
  .rp-body{grid-template-columns:1fr}
  .photo-strip{grid-template-columns:1fr;height:auto}
  .ps-item{height:220px}
  .compliance-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .stats-row{grid-template-columns:1fr}
  .stat-cell{border-right:none!important;border-top:1px solid rgba(255,255,255,0.08)}
  .stat-cell:first-child{border-top:none}
  .btn-group{flex-direction:column;align-items:flex-start}
}
