/* =====================================================================
   FIAT Solutions Inc. — styles.css
   Palette: "Digital Teal"  |  Type: Arista Pro (wordmark) · Sora · IBM Plex
   ===================================================================== */

/* ---- Arista Pro (self-hosted) ------------------------------------------
   Drop your LICENSED Arista Pro web-font files into /assets/fonts/.
   Expected filenames (rename yours to match, or edit the src lines):
     AristaPro-Regular.woff2 / .woff
     AristaPro-Bold.woff2    / .woff
   Until the files are present the wordmark falls back to Sora.
------------------------------------------------------------------------ */
@font-face{
  font-family:'Arista Pro';
  src:url('../fonts/AristaPro-Regular.woff2') format('woff2'),
      url('../fonts/AristaPro-Regular.woff')  format('woff');
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Arista Pro';
  src:url('../fonts/AristaPro-Bold.woff2') format('woff2'),
      url('../fonts/AristaPro-Bold.woff')  format('woff');
  font-weight:700;font-style:normal;font-display:swap;
}

:root{
  --azure:#09668C;        /* Tech Azure — primary brand */
  --azure-deep:#074d6b;
  --teal:#119DA4;         /* Vibrant Teal — supporting */
  --teal-tint:rgba(17,157,164,.08);
  --silver:#BDBFC3;       /* Cool Platinum — borders, subtle text */
  --silver-tint:#E9EAEC;
  --obsidian:#0A2540;     /* Midnight Obsidian — text, dark sections */
  --gold:#FFD100;         /* Circuit Gold — CTA ONLY */
  --gold-deep:#E6BC00;
  --canvas:#FBFBFD;       /* Aether White — base background */

  --shadow-sm:0 1px 2px rgba(10,37,64,.06), 0 4px 16px rgba(10,37,64,.05);
  --shadow-md:0 8px 30px rgba(10,37,64,.10);
  --shadow-lg:0 20px 50px rgba(10,37,64,.16);
  --radius:14px;
  --radius-sm:10px;
  --maxw:1200px;

  --brand:'Arista Pro','Sora',system-ui,sans-serif; /* FIAT Solutions wordmark */
  --display:'Sora',system-ui,sans-serif;
  --body:'IBM Plex Sans',system-ui,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:84px}
body{
  font-family:var(--body);color:var(--obsidian);background:var(--canvas);
  line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *{animation:none!important;transition:none!important}
}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--display);color:var(--obsidian);line-height:1.12;letter-spacing:-.01em;font-weight:700}
.eyebrow{
  font-family:var(--mono);font-size:.74rem;font-weight:500;letter-spacing:.18em;
  text-transform:uppercase;color:var(--teal);display:inline-flex;align-items:center;gap:.55rem;
}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--teal);display:inline-block}
.eyebrow.on-dark{color:#5fd0d6}
.eyebrow.on-dark::before{background:#5fd0d6}
a{color:var(--azure);text-decoration:none}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:96px 0}
.section-head{max-width:720px;margin-bottom:54px}
.section-head h2{font-size:clamp(1.9rem,3.4vw,2.7rem);margin:18px 0 16px}
.section-head p{font-size:1.08rem;color:#3a4a5e}

/* ---------- buttons ---------- */
.btn{
  font-family:var(--display);font-weight:600;font-size:.95rem;border:none;cursor:pointer;
  border-radius:999px;padding:.85rem 1.5rem;display:inline-flex;align-items:center;gap:.55rem;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;line-height:1;
}
.btn-cta{background:var(--gold);color:var(--obsidian);box-shadow:0 6px 18px rgba(255,209,0,.35)}
.btn-cta:hover{background:var(--gold-deep);transform:translateY(-2px);box-shadow:0 10px 26px rgba(255,209,0,.45)}
.btn-cta:active{transform:translateY(0)}
.btn-ghost{background:transparent;color:var(--azure);border:1.5px solid var(--silver)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-tint)}
.btn-ghost.on-dark{color:#fff;border-color:rgba(255,255,255,.32)}
.btn-ghost.on-dark:hover{border-color:#5fd0d6;color:#5fd0d6;background:rgba(255,255,255,.05)}

/* ---------- header / nav ---------- */
header{
  position:sticky;top:0;z-index:60;background:rgba(251,251,253,.86);
  backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--silver-tint);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px;gap:24px}
.logo{display:flex;align-items:center;gap:11px}
.logo-img{
  width:40px;height:40px;border-radius:10px;object-fit:cover;display:block;
  box-shadow:var(--shadow-sm);
}
.logo-word{font-family:var(--brand);font-weight:700;font-size:1.34rem;color:var(--azure);letter-spacing:.01em;line-height:1}
.logo-word small{display:block;font-family:var(--mono);font-size:.56rem;letter-spacing:.16em;color:var(--silver);font-weight:400;text-transform:uppercase;margin-top:2px}

.nav-menu{display:flex;align-items:center;gap:4px;list-style:none}
.nav-item{position:relative}
.nav-link{
  font-family:var(--display);font-weight:500;font-size:.95rem;color:var(--obsidian);
  padding:.6rem .9rem;border-radius:8px;display:inline-flex;align-items:center;gap:.35rem;cursor:pointer;
  transition:color .15s ease,background .15s ease;background:none;border:none;
}
.nav-link:hover,.nav-item:focus-within > .nav-link{color:var(--teal);background:var(--teal-tint)}
.nav-link .chev{width:13px;height:13px;transition:transform .2s ease}
.nav-item:hover .chev,.nav-item:focus-within .chev{transform:rotate(180deg)}
.nav-right{display:flex;align-items:center;gap:14px}

/* mega menu */
.mega{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);
  width:min(760px,92vw);background:#fff;border:1px solid var(--silver-tint);border-radius:16px;
  box-shadow:var(--shadow-lg);padding:26px;opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .18s ease, transform .18s ease;z-index:70;
}
.mega::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
.nav-item:hover .mega,.nav-item:focus-within .mega{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.mega-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:24px}
.mega-aside{background:linear-gradient(160deg,var(--azure),var(--azure-deep));border-radius:12px;padding:20px;color:#fff}
.mega-aside h4{color:#fff;font-size:1.05rem;margin-bottom:8px}
.mega-aside p{font-size:.86rem;color:rgba(255,255,255,.82);line-height:1.5}
.partner-badge{
  display:inline-flex;align-items:center;gap:9px;margin-top:16px;background:rgba(255,255,255,.12);
  border:1px solid rgba(95,208,214,.45);border-radius:999px;padding:.45rem .8rem;font-family:var(--mono);
  font-size:.72rem;letter-spacing:.06em;color:#d7f3f5;
}
.partner-badge .dot{width:7px;height:7px;border-radius:50%;background:#5fd0d6;box-shadow:0 0 0 3px rgba(95,208,214,.25)}
.mega-links{display:grid;grid-template-columns:1fr 1fr;gap:4px 16px;align-content:start}
.mega-link{display:flex;align-items:flex-start;gap:9px;padding:.5rem .55rem;border-radius:9px;transition:background .14s ease}
.mega-link:hover{background:var(--teal-tint)}
.mega-link svg{flex:0 0 auto;margin-top:2px;color:var(--teal)}
.mega-link span{font-family:var(--display);font-weight:500;font-size:.86rem;color:var(--obsidian)}
.mega-foot{margin-top:18px;padding-top:16px;border-top:1px solid var(--silver-tint);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.mega-foot span{font-size:.82rem;color:#56657a}
.mega-foot a{font-family:var(--display);font-weight:600;font-size:.85rem;color:var(--teal)}

.menu-toggle{display:none;background:none;border:1.5px solid var(--silver);border-radius:9px;width:42px;height:42px;cursor:pointer;align-items:center;justify-content:center}
.menu-toggle svg{color:var(--obsidian)}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;padding:104px 0 96px;background:linear-gradient(180deg,#fff 0%,var(--canvas) 60%)}
.hero-traces{position:absolute;inset:0;z-index:0;opacity:.5;pointer-events:none}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(2.4rem,5vw,3.9rem);font-weight:800;letter-spacing:-.025em;margin:22px 0 22px}
.hero h1 .accent{color:var(--azure)}
.hero p.lead{font-size:1.18rem;color:#3a4a5e;max-width:560px;margin-bottom:32px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-trust{margin-top:34px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-family:var(--mono);font-size:.76rem;letter-spacing:.04em;color:#56657a}
.hero-trust .pill{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--silver-tint);border-radius:999px;padding:.4rem .75rem;background:#fff}
.hero-trust .pill b{color:var(--azure);font-weight:600}

.hero-panel{background:#fff;border:1px solid var(--silver-tint);border-radius:18px;box-shadow:var(--shadow-md);padding:8px;position:relative}
.hero-panel .bar{display:flex;gap:6px;padding:10px 12px}
.hero-panel .bar i{width:10px;height:10px;border-radius:50%;background:var(--silver)}
.hero-panel .screen{background:linear-gradient(165deg,var(--azure),var(--obsidian));border-radius:12px;padding:22px;color:#fff;min-height:280px;display:flex;flex-direction:column;justify-content:space-between}
.hero-panel .screen .stat{font-family:var(--display)}
.hero-panel .screen .stat b{font-size:2.4rem;font-weight:700;display:block;color:#fff}
.hero-panel .screen .stat span{font-size:.78rem;color:rgba(255,255,255,.7);font-family:var(--mono);letter-spacing:.05em}
.hero-panel .rows{display:flex;flex-direction:column;gap:11px}
.hero-panel .row{display:flex;align-items:center;gap:12px}
.hero-panel .row .ic{width:34px;height:34px;border-radius:9px;background:rgba(255,255,255,.1);display:grid;place-items:center;flex:0 0 auto}
.hero-panel .row .meta{flex:1}
.hero-panel .row .meta .t{font-size:.82rem;color:#fff;font-weight:500}
.hero-panel .row .meta .ln{height:5px;border-radius:3px;background:rgba(255,255,255,.18);margin-top:6px}
.hero-panel .row .ok{font-family:var(--mono);font-size:.66rem;color:#9be7a0;letter-spacing:.08em}
.hero-panel .node{position:absolute;width:16px;height:16px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 5px rgba(255,209,0,.22);top:-7px;right:30px}

/* ---------- core business ---------- */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.vcard{
  background:#fff;border:1px solid var(--silver-tint);border-radius:var(--radius);padding:28px;
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;position:relative;overflow:hidden;
}
.vcard::after{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--teal);transition:width .25s ease}
.vcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:#cfe6e8}
.vcard:hover::after{width:100%}
.vcard .ic{width:50px;height:50px;border-radius:12px;background:var(--teal-tint);color:var(--teal);display:grid;place-items:center;margin-bottom:18px}
.vcard h3{font-size:1.16rem;margin-bottom:9px}
.vcard p{font-size:.95rem;color:#46566a}

/* ---------- social proof ---------- */
.clients{background:var(--obsidian);color:#fff}
.clients .section-head h2{color:#fff}
.clients .section-head p{color:rgba(255,255,255,.7)}
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:48px}
.stat-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:26px}
.stat-card b{font-family:var(--display);font-size:2.1rem;font-weight:700;color:#fff;display:block}
.stat-card .lbl{font-family:var(--mono);font-size:.74rem;letter-spacing:.08em;color:#5fd0d6;text-transform:uppercase;margin-bottom:12px}
.stat-card p{font-size:.9rem;color:rgba(255,255,255,.72);margin-top:6px}
.logo-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.logo-cell {
  height: 95px; /* Increased slightly from 78px to comfortably fit both image and text */
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 8px; /* This creates a clean, uniform gap between the image and the text */
  box-sizing: border-box;
  overflow: hidden;
}

/* Base style for the logos */
.logo-cell img {
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 42px; /* Adjusted down slightly to leave room for the text label */
  object-fit: contain; 
  transition: transform .2s ease, filter .2s ease; 
  filter: brightness(0.8); 
}

/* Style for the small text under the logo */
.logo-cell p {
  margin: 0; /* Removes default paragraph spacing */
  font-family: var(--mono);
  font-size: .65rem;
  letter-spacing: .05em;
  color: rgba(255, 255, 255, .5);
  text-align: center;
  text-transform: uppercase; /* Optional: makes it look crisp and clean */
  transition: color .2s ease, transform .2s ease;
}

/* Hover reaction: Both the image AND the text react together when the cell is hovered */
.logo-cell:hover img {
  transform: scale(1.05); 
  filter: brightness(1.2); 
}

.logo-cell:hover p {
  color: #5fd0d6; /* Your accent color from earlier */
  transform: translateY(1px); /* Subtly nudges the text down as the image scales up */
}

/* The new dedicated partner logo cell */
.logo-partner {
  width: 140px;  /* Fixed uniform width for every partner slot */
  height: 80px;  /* Fixed uniform height for every partner slot */
  display: flex;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
  overflow: hidden;
  background: transparent; /* No placeholder artifacts */
}

/* Accommodates diverse logo dimensions uniformly */
.logo-partner img {
  /* Restricts the logo from ever spilling out, regardless of its original aspect ratio */
  max-width: 100%;
  max-height: 100%;
  
  /* Hard limits the actual visual scale so different shapes look balanced next to each other */
  width: auto;
  height: auto;
  object-fit: contain; 
  
  /* Smooth transition animations for the hover effects */
  transition: transform .25s cubic-bezier(0.4, 0, 0.2, 1), filter .25s ease; 
  
  /* Slight default dimming so they sit evenly in the background */
  
}

/* Hover Effect: Triggered cleanly on the image itself */
.logo-partner:hover img {
  transform: scale(1.06); /* Clean, uniform pop/zoom */
  filter: brightness(1.2) grayscale(0); /* Restores full brightness and true colors */
}
/* ---------- solutions ---------- */
.sol-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.sol-card{background:#fff;border:1px solid var(--silver-tint);border-radius:var(--radius);padding:24px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
.sol-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:#cfe6e8}
.sol-card .num{font-family:var(--mono);font-size:.72rem;color:var(--silver);letter-spacing:.1em}
.sol-card .ic{width:46px;height:46px;border-radius:11px;background:var(--azure);color:#fff;display:grid;place-items:center;margin:12px 0 16px}
.sol-card h3{font-size:1.04rem;margin-bottom:8px}
.sol-card p{font-size:.88rem;color:#46566a}
.partner-callout{
  display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
  margin-top:30px;background:linear-gradient(160deg,var(--azure),var(--azure-deep));border-radius:var(--radius);
  padding:24px 28px;color:#fff;
}
.partner-callout .pc-txt h4{color:#fff;font-size:1.18rem;margin-bottom:4px}
.partner-callout .pc-txt p{color:rgba(255,255,255,.78);font-size:.92rem}
.partner-chip{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.12);border:1px solid rgba(95,208,214,.5);border-radius:999px;padding:.6rem 1.1rem;font-family:var(--display);font-weight:600;font-size:.9rem;color:#d7f3f5;white-space:nowrap}
.partner-chip .dot{width:8px;height:8px;border-radius:50%;background:#5fd0d6;box-shadow:0 0 0 4px rgba(95,208,214,.25)}

/* ---------- services ---------- */
.services{background:linear-gradient(180deg,#fff,var(--canvas))}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.svc-card{background:#fff;border:1px solid var(--silver-tint);border-radius:var(--radius);padding:28px;display:flex;gap:18px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
.svc-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:#cfe6e8}
.svc-card .ic{width:52px;height:52px;border-radius:13px;flex:0 0 auto;background:var(--teal-tint);color:var(--teal);display:grid;place-items:center}
.svc-card h3{font-size:1.12rem;margin-bottom:4px}
.svc-card .tag{font-family:var(--mono);font-size:.74rem;color:var(--azure);letter-spacing:.03em;margin-bottom:10px;display:block}
.svc-card p{font-size:.92rem;color:#46566a}

/* ---------- company ---------- */
.company-intro{text-align:center;max-width:760px;margin:0 auto 56px}
.company-intro h2{font-size:clamp(2rem,4vw,3rem);margin:18px 0 22px}
.scroll-anchor{font-family:var(--mono);font-size:.78rem;letter-spacing:.12em;color:var(--teal);display:inline-flex;flex-direction:column;align-items:center;gap:6px;margin-top:8px}
.scroll-anchor svg{animation:bob 1.8s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}
.ww-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}
.ww-card{background:#fff;border:1px solid var(--silver-tint);border-radius:var(--radius);padding:34px}
.ww-card .eyebrow{margin-bottom:14px}
.ww-card h3{font-size:1.5rem;margin-bottom:14px}
.ww-card p{font-size:1rem;color:#3a4a5e}
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.mv-card{border-radius:var(--radius);padding:34px;color:#fff;position:relative;overflow:hidden}
.mv-card.mission{background:linear-gradient(160deg,var(--azure),var(--azure-deep))}
.mv-card.vision{background:linear-gradient(160deg,var(--teal),#0c7b81)}
.mv-card .eyebrow{color:#fff}
.mv-card .eyebrow::before{background:#fff}
.mv-card h3{color:#fff;font-size:1.05rem;margin-bottom:14px;opacity:.85}
.mv-card p{font-family:var(--display);font-weight:600;font-size:1.4rem;line-height:1.32;color:#fff}
.mv-card .ghost{position:absolute;right:-20px;bottom:-30px;font-family:var(--brand);font-weight:700;font-size:9rem;color:rgba(255,255,255,.08);line-height:1;pointer-events:none}

/* ---------- footer ---------- */
footer{background:var(--obsidian);color:rgba(255,255,255,.72);padding:64px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:36px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-brand .logo-word{color:#fff}
.foot-brand p{margin-top:16px;font-size:.92rem;max-width:300px;color:rgba(255,255,255,.6)}
.foot-col h5{font-family:var(--display);color:#fff;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:16px}
.foot-col a{display:block;color:rgba(255,255,255,.66);font-size:.92rem;padding:5px 0;transition:color .15s ease}
.foot-col a:hover{color:#5fd0d6}
.foot-contact .mail{font-family:var(--display);color:#fff;font-weight:600;font-size:1.02rem;word-break:break-all}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;padding-top:24px;font-size:.82rem;color:rgba(255,255,255,.5)}
.foot-bottom .legal{display:flex;gap:18px}

/* ---------- modal ---------- */
.modal-overlay{position:fixed;inset:0;z-index:200;background:rgba(10,37,64,.6);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;padding:24px}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:18px;width:min(560px,100%);max-height:92vh;overflow:auto;box-shadow:var(--shadow-lg);animation:pop .22s ease}
@keyframes pop{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
.modal-head{background:linear-gradient(160deg,var(--azure),var(--obsidian));color:#fff;padding:28px 30px;position:relative}
.modal-head .eyebrow{color:#5fd0d6;margin-bottom:10px}
.modal-head .eyebrow::before{background:#5fd0d6}
.modal-head h3{color:#fff;font-size:1.5rem;margin-bottom:8px}
.modal-head p{font-size:.92rem;color:rgba(255,255,255,.78)}
.modal-close{position:absolute;top:18px;right:18px;width:36px;height:36px;border-radius:9px;border:none;background:rgba(255,255,255,.14);color:#fff;cursor:pointer;display:grid;place-items:center;transition:background .15s ease}
.modal-close:hover{background:rgba(255,255,255,.26)}
.modal-body{padding:28px 30px 30px}
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--display);font-weight:500;font-size:.86rem;margin-bottom:7px}
.field input,.field textarea,.field select{
  width:100%;border:1.5px solid var(--silver);border-radius:10px;padding:.7rem .85rem;font-family:var(--body);
  font-size:.95rem;color:var(--obsidian);background:#fff;transition:border-color .15s ease,box-shadow .15s ease;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-tint)}
.field textarea{resize:vertical;min-height:96px}
.two{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden} /* honeypot */
.modal-note{font-size:.82rem;color:#56657a;margin-top:6px;display:flex;align-items:center;gap:7px}
.modal-note a{color:var(--teal);font-weight:600}
.modal-actions{margin-top:8px}
.modal-actions .btn-cta{width:100%;justify-content:center}
.form-status{display:none;margin-top:14px;padding:.7rem .9rem;border-radius:10px;font-size:.9rem}
.form-status.show{display:block}
.form-status.ok{background:rgba(17,157,164,.1);color:#0c6469;border:1px solid rgba(17,157,164,.35)}
.form-status.err{background:rgba(214,69,69,.08);color:#a32626;border:1px solid rgba(214,69,69,.3)}

/* focus visibility */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,.nav-link:focus-visible{
  outline:3px solid var(--teal);outline-offset:2px;border-radius:6px;
}

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

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .hero-inner{grid-template-columns:1fr;gap:40px}
  .hero-panel{max-width:480px}
  .sol-grid{grid-template-columns:repeat(2,1fr)}
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr;gap:28px}
}
@media (max-width:880px){
  .menu-toggle{display:flex}
  .nav-menu{
    position:absolute;top:72px;left:0;right:0;background:#fff;border-bottom:1px solid var(--silver-tint);
    flex-direction:column;align-items:stretch;gap:0;padding:10px 18px 18px;box-shadow:var(--shadow-md);display:none;
  }
  .nav-menu.open{display:flex}
  .nav-link{width:100%;justify-content:space-between;padding:.85rem .6rem}
  .nav-item{border-bottom:1px solid var(--silver-tint)}
  .nav-item:last-child{border-bottom:none}
  .mega{position:static;transform:none;width:100%;box-shadow:none;border:none;padding:6px 4px 14px;opacity:1;visibility:visible;pointer-events:auto;display:none}
  .nav-item.expanded .mega{display:block}
  .mega-grid{grid-template-columns:1fr}
  .nav-item:hover .chev,.nav-item:focus-within .chev{transform:none}
  .nav-item.expanded .chev{transform:rotate(180deg)}
  .nav-right .btn-cta{display:none}
}
@media (max-width:680px){
  .section{padding:68px 0}
  .stat-row,.svc-grid,.ww-grid,.mv-grid,.card-grid,.sol-grid{grid-template-columns:1fr}
  .logo-strip{grid-template-columns:repeat(3,1fr)}
  .foot-grid{grid-template-columns:1fr}
  .two{grid-template-columns:1fr}
  .wrap{padding:0 20px}
}
