/* ===========================================================
   Uniply mockups — shared styles
   Used by all *_Mockup.html files in this folder.
   =========================================================== */

/* Always show vertical scrollbar so nav doesn't shift between pages
   (short pages would otherwise hide the scrollbar, snapping viewport
   width by ~15px and shifting the centered nav links). */
html { overflow-y: scroll; }

:root {
  /* INK / NEUTRALS — pulled to align with Uniply dark navy */
  --ink:#042938;             /* Uniply dark navy (from logo asset 06) */
  --ink-soft:#0F172A;        /* fallback slate for body */
  --slate:#475569;
  --slate-light:#64748B;
  --line:#E2E8F0;
  --tint:#F1F5F9;
  --tint-2:#F8FAFC;
  --cream:#F0F0F3;           /* Uniply off-white (from logo asset 03) */
  --bg:#FFFFFF;
  /* BRAND BLUES — pulled from Uniply brand (dominant: #2861B3) */
  --primary:#2861B3;         /* Uniply dominant blue — confirmed brand */
  --primary-700:#1F4D8F;     /* darker shade */
  --primary-50:#EAF1F9;
  --primary-100:#D2DFF1;
  --primary-light:#6F92C8;   /* Uniply secondary blue */
  --primary-light-50:#EEF3FA;
  /* ACCENT — kept in the Uniply blue family for brand consistency */
  --accent:#1F4D8F;          /* deep Uniply navy — same family as primary */
  --accent-50:#DCE6F4;       /* very light blue tint */
  /* SEMANTIC */
  --emerald:#059669;
  --emerald-50:#D1FAE5;
  --amber:#F59E0B;
  --amber-50:#FEF3C7;
  --rose:#E11D48;
  --rose-50:#FEE2E2;
  /* ELEVATION */
  --shadow-sm:0 1px 2px rgba(4,41,56,.06);
  --shadow-md:0 8px 28px rgba(4,41,56,.08);
  --shadow-lg:0 20px 48px rgba(4,41,56,.10);
  --radius:14px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink); background:var(--bg);
  -webkit-font-smoothing:antialiased; line-height:1.55;
}
a{color:inherit;text-decoration:none}
.wrap{max-width:1200px;margin:0 auto;padding:0 24px}

/* mockup banner */
.mockup-banner{
  background:#FEF3C7;border-bottom:1px solid #FCD34D;
  padding:8px 0;text-align:center;font-size:13px;color:#92400E;font-weight:500;
}
.mockup-banner a{color:#92400E;text-decoration:underline}

/* NAV */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--line);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:112px;position:relative}
.logo{display:inline-flex;align-items:center;line-height:0}
.logo img{display:block;height:72px;width:auto}
.logo.logo-sm img{height:54px}
.logo.logo-lg img{height:86px}
.nav-links{display:flex;gap:28px;font-size:14.5px;color:var(--slate);font-weight:500}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--primary)}
.nav-cta{display:flex;gap:10px;align-items:center}

/* Mobile nav — hamburger menu */
.nav-toggle{position:absolute;left:-9999px;opacity:0;pointer-events:none}
.nav-burger{display:none;cursor:pointer;padding:10px 12px;background:#fff;border:1px solid var(--line);border-radius:8px;flex-direction:column;gap:4px;align-items:center;justify-content:center}
.nav-burger span{display:block;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:transform .2s ease,opacity .2s ease}
.nav-toggle:checked ~ .nav-burger span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-toggle:checked ~ .nav-burger span:nth-child(2){opacity:0}
.nav-toggle:checked ~ .nav-burger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* buttons */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border-radius:10px;font-weight:600;font-size:14.5px;
  transition:all .15s ease; cursor:pointer; border:1px solid transparent;
  white-space:nowrap;
}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{background:#000}
.btn-ghost{color:var(--ink);border-color:var(--line);background:#fff}
.btn-ghost:hover{border-color:var(--ink)}
.btn-light{background:#fff;color:var(--ink)}
.btn-light:hover{background:var(--tint)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.3)}
.btn-outline:hover{border-color:#fff}

/* type */
h1{
  font-size:60px;line-height:1.04;letter-spacing:-.025em;font-weight:800;
  margin:0 0 20px;color:var(--ink);
}
h1 .grad{
  background:linear-gradient(120deg,var(--primary) 0%,var(--accent) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
h2{font-size:42px;line-height:1.1;letter-spacing:-.02em;font-weight:800;margin:0 0 16px;max-width:780px}
h3{font-size:21px;line-height:1.25;letter-spacing:-.01em;margin:0 0 10px;font-weight:700}
h4{font-size:18px;margin:0 0 8px;line-height:1.3;letter-spacing:-.01em;font-weight:700}
.lede{font-size:19px;color:var(--slate);max-width:620px;margin:0 0 28px}
.section-label{
  font-size:13px;font-weight:700;color:var(--primary);
  text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;
}
.section-lede{font-size:18px;color:var(--slate);max-width:720px;margin:0 0 40px}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--primary-50);color:var(--primary);
  padding:6px 12px;border-radius:999px;font-size:13px;font-weight:600;
  margin-bottom:20px;
}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 4px rgba(30,64,175,.15)}
.eyebrow.ai{background:var(--accent-50);color:var(--accent)}
.eyebrow.ai .dot{background:var(--accent);box-shadow:0 0 0 4px rgba(124,58,237,.15)}

/* badges */
.ai-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--accent-50);color:var(--accent);
  padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;
}
.ai-badge .pulse{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.4)}}

/* hero */
.hero{padding:72px 0 56px;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px}
.hero-meta{display:flex;gap:20px;font-size:13.5px;color:var(--slate-light);align-items:center;flex-wrap:wrap}
.hero-meta .check{color:var(--emerald)}

/* sections */
section.block{padding:96px 0;border-bottom:1px solid var(--line)}
section.block.tinted{background:var(--tint)}

/* card */
.card{
  background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px;
  transition:all .2s ease;
}
.card:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}

/* grids */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}

/* closing cta */
.cta-band{
  padding:80px 0;text-align:center;
  background:linear-gradient(135deg,var(--ink) 0%,#1E293B 50%,var(--primary-700) 100%);
  color:#fff;position:relative;overflow:hidden;
}
.cta-band:before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 20% 50%,rgba(124,58,237,.18) 0,transparent 50%);
  pointer-events:none;
}
.cta-band h2{color:#fff;margin:0 auto 14px;max-width:760px}
.cta-band p{color:rgba(255,255,255,.78);font-size:18px;margin:0 auto 32px;max-width:560px}
.cta-band-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;position:relative}

/* footer */
footer{padding:48px 0;color:var(--slate-light);font-size:13.5px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:32px;margin-bottom:32px}
.foot-grid h5{font-size:13px;color:var(--ink);margin:0 0 12px;text-transform:uppercase;letter-spacing:.06em;font-weight:700}
.foot-grid a{display:block;padding:4px 0;color:var(--slate)}
.foot-grid a:hover{color:var(--ink)}
.foot-end{padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}

/* responsive */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:32px}
  h1{font-size:42px}
  h2{font-size:32px}
  .grid-3,.grid-4,.foot-grid{grid-template-columns:1fr 1fr}

  /* Mobile nav drawer */
  .nav-inner{height:72px}
  .logo img{height:40px}
  .nav-burger{display:flex}
  .nav-cta{display:none}
  .nav-links{
    display:none;
    position:absolute;
    top:100%;
    left:-24px;right:-24px;
    background:#fff;
    flex-direction:column;
    gap:0;
    padding:8px 0;
    border-bottom:1px solid var(--line);
    box-shadow:0 12px 28px rgba(4,41,56,0.08);
    z-index:100;
    font-size:16px;
  }
  .nav-toggle:checked ~ .nav-links{display:flex}
  .nav-links a{
    padding:14px 24px;
    border-bottom:1px solid var(--line);
    color:var(--ink);
    font-weight:600;
  }
  .nav-links a:last-child{border-bottom:none}
  .nav-links a.active{background:var(--primary-50);color:var(--primary)}
}
@media (max-width:640px){
  .grid-2,.grid-3,.grid-4,.foot-grid{grid-template-columns:1fr}
  h1{font-size:36px}
  h2{font-size:26px}
  .lede{font-size:17px}
  section.block{padding:64px 0}
}
