/* =========================================================
   FieldMand — Construction management SaaS marketing site
   Design system: Safety amber + slate on white
   Author: front-end build
   ========================================================= */

/* ---------- Design tokens ---------- */
:root{
  --bg:#ffffff;
  --bg-soft:#f8fafc;
  --bg-slate:#f1f5f9;
  --ink:#0f172a;
  --ink-2:#1e293b;
  --slate:#475569;
  --muted:#64748b;
  --line:#e6eaf0;
  --line-2:#e2e8f0;

  --amber:#f59e0b;
  --amber-600:#d97706;
  --amber-700:#b45309;
  --amber-300:#fcd34d;
  --amber-100:#fef3c7;
  --amber-50:#fffbeb;

  --radius:14px;
  --radius-lg:22px;
  --radius-sm:10px;

  --shadow-sm:0 1px 2px rgba(15,23,42,.06), 0 1px 3px rgba(15,23,42,.05);
  --shadow:0 10px 30px -12px rgba(15,23,42,.18);
  --shadow-lg:0 30px 70px -24px rgba(15,23,42,.30);
  --shadow-amber:0 20px 46px -14px rgba(245,158,11,.5);

  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);

  --font-body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  --font-display:"Space Grotesk","Inter",system-ui,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--slate);
  background:var(--bg);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{margin:0;padding:0;list-style:none}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--amber-300);color:var(--ink)}

h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);line-height:1.08;margin:0;font-weight:700;letter-spacing:-.02em}
h1{font-size:clamp(2.4rem,5.4vw,4.1rem)}
h2{font-size:clamp(1.9rem,3.6vw,2.9rem)}
h3{font-size:1.28rem;letter-spacing:-.01em}
p{margin:0}

/* ---------- Layout helpers ---------- */
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:96px 0}
.section-sm{padding:64px 0}
.bg-soft{background:var(--bg-soft)}
.bg-slate{background:var(--bg-slate)}
.center{text-align:center}
.mw-720{max-width:720px;margin-left:auto;margin-right:auto}
.mw-640{max-width:640px;margin-left:auto;margin-right:auto}

.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display);
  font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--amber-700);
  background:var(--amber-50);
  border:1px solid var(--amber-100);
  padding:7px 14px;border-radius:999px;
}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--amber);box-shadow:0 0 0 4px rgba(245,158,11,.18)}
.section-head{margin-bottom:54px}
.section-head h2{margin-bottom:16px}
.section-head p{color:var(--muted);font-size:1.08rem}
.lead{font-size:1.18rem;color:var(--slate)}

.text-amber{color:var(--amber-600)}
.hl{position:relative;white-space:nowrap;z-index:0;color:var(--ink)}
.hl::after{content:"";position:absolute;left:-2px;right:-2px;bottom:.08em;height:.36em;background:linear-gradient(90deg,var(--amber-300),var(--amber));border-radius:4px;z-index:-1;opacity:.55;transform:skewX(-8deg)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-display);font-weight:600;font-size:.98rem;
  padding:13px 22px;border-radius:12px;border:1px solid transparent;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s,color .2s,border-color .2s;
  white-space:nowrap;line-height:1;
}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--amber);color:#3a2a05;box-shadow:var(--shadow-amber)}
.btn-primary:hover{transform:translateY(-2px);background:#fbb12e;box-shadow:0 26px 54px -14px rgba(245,158,11,.62)}
.btn-dark{background:var(--ink);color:#fff;box-shadow:0 14px 30px -14px rgba(15,23,42,.6)}
.btn-dark:hover{transform:translateY(-2px);background:#11203b}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line-2);box-shadow:var(--shadow-sm)}
.btn-ghost:hover{transform:translateY(-2px);border-color:#cbd5e1;box-shadow:var(--shadow)}
.btn-light{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.28);backdrop-filter:blur(4px)}
.btn-light:hover{background:rgba(255,255,255,.24);transform:translateY(-2px)}
.btn-lg{padding:16px 28px;font-size:1.04rem;border-radius:14px}
.btn-block{width:100%}
.link-arrow{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-display);font-weight:600;color:var(--amber-700)}
.link-arrow svg{width:16px;height:16px;transition:transform .25s var(--ease)}
.link-arrow:hover svg{transform:translateX(5px)}

/* ---------- Header / nav ---------- */
.site-header{position:sticky;top:0;z-index:60;transition:background .3s,box-shadow .3s,border-color .3s;border-bottom:1px solid transparent}
.site-header.scrolled{background:rgba(255,255,255,.86);backdrop-filter:saturate(180%) blur(14px);border-bottom-color:var(--line);box-shadow:0 6px 24px -18px rgba(15,23,42,.35)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:inline-flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:700;font-size:1.26rem;color:var(--ink);letter-spacing:-.02em}
.brand .logo-mark{width:38px;height:38px;flex:none}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a{font-weight:500;font-size:.98rem;color:var(--slate);position:relative;padding:6px 0;transition:color .2s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--amber);transition:width .28s var(--ease)}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-cta .login-link{font-family:var(--font-display);font-weight:600;color:var(--ink);font-size:.96rem}
.nav-cta .login-link:hover{color:var(--amber-700)}
.hamburger{display:none;width:46px;height:46px;border:1px solid var(--line-2);background:#fff;border-radius:11px;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.hamburger span{display:block;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s var(--ease),opacity .2s}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-drawer{position:fixed;inset:0 0 0 auto;width:min(86vw,360px);background:#fff;z-index:90;transform:translateX(100%);transition:transform .38s var(--ease);box-shadow:var(--shadow-lg);padding:26px;display:flex;flex-direction:column;gap:6px}
.mobile-drawer.open{transform:translateX(0)}
.mobile-drawer a{padding:15px 12px;border-radius:10px;font-family:var(--font-display);font-weight:600;color:var(--ink);font-size:1.05rem}
.mobile-drawer a:hover{background:var(--bg-slate)}
.mobile-drawer .btn{margin-top:8px}
.drawer-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.drawer-close{width:42px;height:42px;border:1px solid var(--line-2);background:#fff;border-radius:10px;font-size:1.3rem;color:var(--ink)}
.scrim{position:fixed;inset:0;background:rgba(15,23,42,.45);backdrop-filter:blur(2px);z-index:80;opacity:0;visibility:hidden;transition:opacity .3s}
.scrim.show{opacity:1;visibility:visible}

/* ---------- Hero ---------- */
.hero{position:relative;padding:74px 0 84px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:-2;background:
   radial-gradient(60% 50% at 78% 12%,rgba(245,158,11,.16),transparent 60%),
   radial-gradient(50% 45% at 8% 88%,rgba(15,23,42,.06),transparent 60%);}
.hero-grid{position:absolute;inset:0;z-index:-2;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:46px 46px;opacity:.5;mask-image:radial-gradient(120% 90% at 50% 0%,#000 35%,transparent 78%)}
.hero-inner{display:grid;grid-template-columns:1.04fr .96fr;gap:54px;align-items:center}
.hero-copy h1{margin:20px 0 22px}
.hero-copy .lead{max-width:560px;margin-bottom:30px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:26px}
.hero-note{display:flex;align-items:center;gap:18px;flex-wrap:wrap;color:var(--muted);font-size:.92rem}
.hero-note .dot{display:inline-flex;align-items:center;gap:7px}
.hero-note svg{width:16px;height:16px;color:var(--amber-600)}

/* floating dots */
.floaty{position:absolute;border-radius:50%;background:var(--amber);opacity:.5;z-index:-1;animation:floaty 7s var(--ease) infinite}
.floaty.f2{animation-duration:9s;background:var(--ink);opacity:.18}
.floaty.f3{animation-duration:11s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-22px)}}

/* ---------- Product mockup (SVG/HTML hybrid) ---------- */
.mock{position:relative;perspective:1600px}
.mock-window{
  background:#fff;border:1px solid var(--line-2);border-radius:18px;overflow:hidden;
  box-shadow:var(--shadow-lg);transform:rotateY(-9deg) rotateX(4deg);transform-style:preserve-3d;
  animation:floatcard 8s var(--ease) infinite;
}
@keyframes floatcard{0%,100%{transform:rotateY(-9deg) rotateX(4deg) translateY(0)}50%{transform:rotateY(-7deg) rotateX(3deg) translateY(-14px)}}
.mock-bar{display:flex;align-items:center;gap:7px;padding:13px 16px;background:var(--bg-soft);border-bottom:1px solid var(--line)}
.mock-bar i{width:11px;height:11px;border-radius:50%;background:#cbd5e1;display:block}
.mock-bar i:nth-child(1){background:#f87171}.mock-bar i:nth-child(2){background:#fbbf24}.mock-bar i:nth-child(3){background:#34d399}
.mock-bar .url{margin-left:10px;font-size:.72rem;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:7px;padding:4px 12px;font-family:var(--font-display)}
.mock-body{padding:18px;display:grid;grid-template-columns:128px 1fr;gap:16px;background:linear-gradient(180deg,#fff,#fcfdff)}
.mock-side{display:flex;flex-direction:column;gap:9px}
.mock-side .s-logo{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:.9rem;display:flex;align-items:center;gap:7px;margin-bottom:6px}
.mock-side .s-logo b{width:18px;height:18px;background:var(--amber);border-radius:6px;display:inline-block}
.ms-item{display:flex;align-items:center;gap:9px;font-size:.74rem;color:var(--muted);padding:7px 9px;border-radius:8px;font-weight:500}
.ms-item.active{background:var(--amber-50);color:var(--amber-700);font-weight:600}
.ms-item u{width:13px;height:13px;border-radius:4px;background:currentColor;opacity:.7;display:block;text-decoration:none}
.mock-main{display:flex;flex-direction:column;gap:13px}
.mm-head{display:flex;justify-content:space-between;align-items:center}
.mm-head h5{font-family:var(--font-display);font-size:.96rem;color:var(--ink);margin:0;font-weight:700}
.mm-head .pill{font-size:.64rem;font-weight:700;color:#065f46;background:#d1fae5;padding:4px 10px;border-radius:999px;font-family:var(--font-display)}
.mm-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.stat-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:11px 12px}
.stat-card .k{font-size:.62rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.stat-card .v{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:1.22rem;margin-top:3px}
.stat-card .v small{font-size:.6rem;color:var(--amber-700);font-weight:700}
.mm-bars{background:#fff;border:1px solid var(--line);border-radius:12px;padding:13px}
.mm-bars .lbl{font-size:.64rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px}
.bars{display:flex;align-items:flex-end;gap:9px;height:74px}
.bars span{flex:1;background:linear-gradient(180deg,var(--amber-300),var(--amber));border-radius:6px 6px 3px 3px;animation:grow 1.4s var(--ease) both}
.bars span:nth-child(even){background:linear-gradient(180deg,#cbd5e1,#94a3b8)}
@keyframes grow{from{height:6%}}
.mm-rows{display:flex;flex-direction:column;gap:8px}
.mm-row{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:9px 11px;font-size:.72rem;color:var(--ink-2);font-weight:500}
.mm-row .tick{width:18px;height:18px;border-radius:6px;background:var(--amber-50);border:1px solid var(--amber-100);display:flex;align-items:center;justify-content:center;color:var(--amber-700);flex:none}
.mm-row .tick svg{width:11px;height:11px}
.mm-row .who{margin-left:auto;width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,var(--amber),#fb923c);color:#fff;font-size:.6rem;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:var(--font-display)}

/* mobile mini card overlapping the window */
.mock-mobile{position:absolute;right:-14px;bottom:-30px;width:170px;background:#fff;border:1px solid var(--line-2);border-radius:20px;box-shadow:var(--shadow-lg);padding:13px;z-index:3;animation:floatcard2 7s var(--ease) infinite}
@keyframes floatcard2{0%,100%{transform:translateY(0) rotate(3deg)}50%{transform:translateY(-12px) rotate(3deg)}}
.mock-mobile .mh{display:flex;align-items:center;gap:7px;font-family:var(--font-display);font-weight:700;font-size:.72rem;color:var(--ink);margin-bottom:9px}
.mock-mobile .mh b{width:14px;height:14px;background:var(--amber);border-radius:5px}
.mock-mobile .ph{height:62px;border-radius:11px;background:linear-gradient(135deg,#0f172a,#1e293b);position:relative;overflow:hidden;margin-bottom:9px}
.mock-mobile .ph::after{content:"";position:absolute;inset:0;background:radial-gradient(60% 60% at 70% 30%,rgba(245,158,11,.5),transparent)}
.mock-mobile .cap{font-size:.62rem;color:var(--muted);font-weight:600;display:flex;align-items:center;gap:6px}
.mock-mobile .cap em{width:8px;height:8px;border-radius:50%;background:#34d399;font-style:normal}
.mock-mobile .mbtn{margin-top:9px;background:var(--amber);color:#3a2a05;border-radius:8px;text-align:center;font-family:var(--font-display);font-weight:700;font-size:.7rem;padding:7px}

/* ---------- Marquee / industries ---------- */
.trusted{padding:34px 0 8px}
.trusted p{text-align:center;color:var(--muted);font-size:.82rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:22px}
.chips{display:flex;flex-wrap:wrap;justify-content:center;gap:12px}
.chip{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line-2);border-radius:999px;padding:10px 18px;font-family:var(--font-display);font-weight:600;font-size:.92rem;color:var(--ink-2);box-shadow:var(--shadow-sm)}
.chip svg{width:17px;height:17px;color:var(--amber-600)}

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

.card{background:#fff;border:1px solid var(--line-2);border-radius:var(--radius-lg);padding:28px;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;position:relative;overflow:hidden}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:#dbe2ea}
.card h3{margin-bottom:9px}
.card p{font-size:.98rem;color:var(--muted)}
.card .ic{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;background:var(--amber-50);color:var(--amber-700);border:1px solid var(--amber-100)}
.card .ic svg{width:25px;height:25px}
.card.dark{background:var(--ink);border-color:#1e293b}
.card.dark h3{color:#fff}.card.dark p{color:#94a3b8}
.card.dark .ic{background:rgba(245,158,11,.16);border-color:rgba(245,158,11,.3);color:var(--amber-300)}

/* feature module card with index number */
.module{padding-top:30px}
.module .num{position:absolute;top:18px;right:22px;font-family:var(--font-display);font-weight:700;font-size:2.2rem;color:var(--bg-slate);line-height:1}
.module ul{margin-top:14px;display:flex;flex-direction:column;gap:8px}
.module ul li{display:flex;gap:9px;align-items:flex-start;font-size:.92rem;color:var(--slate)}
.module ul li svg{width:16px;height:16px;color:var(--amber-600);flex:none;margin-top:4px}

/* ---------- Split feature blocks ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split.rev .split-media{order:2}
.split-copy h2{margin-bottom:18px}
.split-copy .lead{margin-bottom:22px}
.feat-list{display:flex;flex-direction:column;gap:16px;margin-top:8px}
.feat-list li{display:flex;gap:14px;align-items:flex-start}
.feat-list .fi{width:40px;height:40px;border-radius:11px;background:var(--amber-50);border:1px solid var(--amber-100);color:var(--amber-700);display:flex;align-items:center;justify-content:center;flex:none}
.feat-list .fi svg{width:20px;height:20px}
.feat-list b{font-family:var(--font-display);color:var(--ink);display:block;margin-bottom:2px;font-size:1rem}
.feat-list span{font-size:.95rem;color:var(--muted)}

.media-photo{position:relative;border-radius:var(--radius-lg);overflow:hidden;min-height:380px;box-shadow:var(--shadow-lg);
  background-size:cover;background-position:center;}
.media-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,23,42,.05),rgba(15,23,42,.42))}
.media-photo .tagcard{position:absolute;left:18px;bottom:18px;right:18px;z-index:2;background:rgba(255,255,255,.94);backdrop-filter:blur(6px);border-radius:14px;padding:15px 17px;box-shadow:var(--shadow);display:flex;align-items:center;gap:13px}
.media-photo .tagcard .ti{width:42px;height:42px;border-radius:11px;background:var(--amber);color:#3a2a05;display:flex;align-items:center;justify-content:center;flex:none}
.media-photo .tagcard .ti svg{width:21px;height:21px}
.media-photo .tagcard b{font-family:var(--font-display);color:var(--ink);font-size:.96rem;display:block}
.media-photo .tagcard span{font-size:.82rem;color:var(--muted)}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:step}
.step{position:relative;background:#fff;border:1px solid var(--line-2);border-radius:var(--radius-lg);padding:30px 26px;transition:transform .3s var(--ease),box-shadow .3s}
.step:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.step .sn{width:46px;height:46px;border-radius:13px;background:var(--ink);color:#fff;font-family:var(--font-display);font-weight:700;display:flex;align-items:center;justify-content:center;font-size:1.15rem;margin-bottom:18px}
.step:nth-child(2) .sn{background:var(--amber);color:#3a2a05}
.step h3{margin-bottom:8px}
.step p{color:var(--muted);font-size:.96rem}
.step-line{position:absolute;top:53px;left:64px;right:-12px;height:2px;background:repeating-linear-gradient(90deg,var(--line-2) 0 8px,transparent 8px 16px)}

/* ---------- Roles ---------- */
.roles{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.role{background:#fff;border:1px solid var(--line-2);border-radius:16px;padding:22px 18px;text-align:center;transition:transform .3s var(--ease),box-shadow .3s,border-color .3s}
.role:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--amber-100)}
.role .ra{width:54px;height:54px;border-radius:50%;margin:0 auto 14px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--amber-50),#fff);border:1px solid var(--amber-100);color:var(--amber-700)}
.role .ra svg{width:26px;height:26px}
.role h4{font-family:var(--font-display);font-size:1.02rem;color:var(--ink);margin-bottom:6px}
.role p{font-size:.85rem;color:var(--muted)}

/* ---------- Stats band ---------- */
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;background:var(--ink);border-radius:var(--radius-lg);padding:42px 30px;color:#fff;position:relative;overflow:hidden}
.statband::before{content:"";position:absolute;inset:0;background:radial-gradient(50% 120% at 85% 0%,rgba(245,158,11,.28),transparent 60%)}
.statband .si{position:relative;text-align:center}
.statband .si .n{font-family:var(--font-display);font-weight:700;font-size:clamp(2.1rem,4vw,3rem);color:#fff;line-height:1}
.statband .si .n em{color:var(--amber-300);font-style:normal}
.statband .si .l{color:#cbd5e1;font-size:.92rem;margin-top:8px}

/* ---------- Pricing ---------- */
.toggle-wrap{display:flex;align-items:center;justify-content:center;gap:14px;margin:0 auto 14px}
.toggle{position:relative;width:62px;height:34px;border-radius:999px;background:var(--bg-slate);border:1px solid var(--line-2);padding:0;flex:none}
.toggle .knob{position:absolute;top:3px;left:3px;width:26px;height:26px;border-radius:50%;background:var(--amber);box-shadow:var(--shadow-sm);transition:transform .3s var(--ease)}
.toggle.annual .knob{transform:translateX(28px)}
.toggle-label{font-family:var(--font-display);font-weight:600;color:var(--muted);font-size:.96rem}
.toggle-label.on{color:var(--ink)}
.save-tag{font-size:.72rem;font-weight:700;color:var(--amber-700);background:var(--amber-50);border:1px solid var(--amber-100);padding:4px 10px;border-radius:999px;font-family:var(--font-display)}

.prices{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:start}
.price{background:#fff;border:1px solid var(--line-2);border-radius:var(--radius-lg);padding:30px;transition:transform .3s var(--ease),box-shadow .3s;display:flex;flex-direction:column;height:100%}
.price:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.price.feat{border-color:var(--amber);box-shadow:var(--shadow-amber);position:relative}
.price.feat::before{content:"Most popular";position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--amber);color:#3a2a05;font-family:var(--font-display);font-weight:700;font-size:.72rem;padding:5px 14px;border-radius:999px;white-space:nowrap}
.price .pname{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:1.2rem}
.price .pdesc{color:var(--muted);font-size:.9rem;margin-top:6px;min-height:40px}
.price .amount{margin:18px 0 4px;display:flex;align-items:baseline;gap:4px}
.price .amount .cur{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:1.3rem}
.price .amount .val{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:3rem;line-height:1;letter-spacing:-.03em}
.price .amount .per{color:var(--muted);font-size:.9rem}
.price .billed{font-size:.8rem;color:var(--muted);min-height:20px}
.price .btn{margin:22px 0}
.price ul{display:flex;flex-direction:column;gap:11px;margin-top:4px}
.price ul li{display:flex;gap:10px;align-items:flex-start;font-size:.92rem;color:var(--slate)}
.price ul li svg{width:17px;height:17px;color:var(--amber-600);flex:none;margin-top:3px}
.price ul li.muted{color:var(--muted)}
.price ul li.muted svg{color:#cbd5e1}

/* comparison table */
.cmp{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line-2);border-radius:var(--radius-lg);overflow:hidden;font-size:.94rem}
.cmp th,.cmp td{padding:15px 18px;text-align:left;border-bottom:1px solid var(--line)}
.cmp thead th{font-family:var(--font-display);color:var(--ink);background:var(--bg-soft)}
.cmp thead th:not(:first-child){text-align:center;width:18%}
.cmp td:not(:first-child){text-align:center}
.cmp tbody tr:last-child td{border-bottom:none}
.cmp .yes{color:var(--amber-700)}
.cmp .feat-col{background:var(--amber-50)}
.cmp svg{width:18px;height:18px;display:inline-block;vertical-align:middle}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.qa{background:#fff;border:1px solid var(--line-2);border-radius:16px;overflow:hidden;transition:box-shadow .3s,border-color .3s}
.qa.open{box-shadow:var(--shadow);border-color:#dbe2ea}
.qa button{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:21px 24px;background:none;border:0;text-align:left;font-family:var(--font-display);font-weight:600;color:var(--ink);font-size:1.05rem}
.qa .ico{width:30px;height:30px;border-radius:9px;background:var(--bg-slate);display:flex;align-items:center;justify-content:center;flex:none;transition:transform .3s var(--ease),background .3s,color .3s}
.qa .ico svg{width:16px;height:16px}
.qa.open .ico{background:var(--amber);color:#3a2a05;transform:rotate(45deg)}
.qa .ans{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.qa .ans p{padding:0 24px 22px;color:var(--muted);font-size:.98rem}

/* ---------- CTA band ---------- */
.cta-band{position:relative;border-radius:28px;overflow:hidden;padding:74px 40px;text-align:center;background-size:cover;background-position:center;color:#fff}
.cta-band::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(15,23,42,.92),rgba(15,23,42,.72)),radial-gradient(60% 120% at 80% 10%,rgba(245,158,11,.4),transparent 55%)}
.cta-band>*{position:relative;z-index:2}
.cta-band h2{color:#fff;margin-bottom:16px}
.cta-band p{color:#dbe2ea;max-width:560px;margin:0 auto 30px;font-size:1.1rem}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#94a3b8;padding:70px 0 32px;margin-top:0}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:46px;border-bottom:1px solid #1e293b}
.foot-brand .brand{color:#fff;margin-bottom:16px}
.foot-brand p{font-size:.94rem;max-width:300px;margin-bottom:20px}
.foot-social{display:flex;gap:10px}
.foot-social a{width:40px;height:40px;border-radius:11px;border:1px solid #1e293b;display:flex;align-items:center;justify-content:center;color:#cbd5e1;transition:background .2s,color .2s,transform .2s}
.foot-social a:hover{background:var(--amber);color:#3a2a05;transform:translateY(-2px);border-color:var(--amber)}
.foot-social svg{width:18px;height:18px}
.foot-col h5{font-family:var(--font-display);color:#fff;font-size:.84rem;text-transform:uppercase;letter-spacing:.1em;margin:0 0 18px}
.foot-col a{display:block;padding:7px 0;font-size:.94rem;transition:color .2s}
.foot-col a:hover{color:var(--amber-300)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;padding-top:26px;font-size:.86rem}
.foot-bottom a:hover{color:#fff}
.foot-legal{display:flex;gap:22px;flex-wrap:wrap}

/* ---------- Forms / auth ---------- */
.auth-wrap{min-height:calc(100vh - 74px);display:grid;grid-template-columns:1fr 1fr}
.auth-aside{position:relative;background:var(--ink);color:#fff;padding:56px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;background-size:cover;background-position:center}
.auth-aside::before{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(15,23,42,.94),rgba(15,23,42,.78)),radial-gradient(50% 80% at 90% 10%,rgba(245,158,11,.42),transparent 55%)}
.auth-aside>*{position:relative;z-index:2}
.auth-aside .brand{color:#fff}
.auth-quote{max-width:420px}
.auth-quote h2{color:#fff;font-size:1.9rem;margin-bottom:16px}
.auth-quote p{color:#cbd5e1}
.auth-points{display:flex;flex-direction:column;gap:14px;margin-top:8px}
.auth-points li{display:flex;gap:12px;align-items:center;color:#e2e8f0;font-size:.96rem}
.auth-points svg{width:20px;height:20px;color:var(--amber-300);flex:none}
.auth-main{display:flex;align-items:center;justify-content:center;padding:48px 28px;background:var(--bg)}
.auth-card{width:100%;max-width:420px}
.auth-card h1{font-size:2rem;margin-bottom:8px}
.auth-card .sub{color:var(--muted);margin-bottom:30px}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--font-display);font-weight:600;color:var(--ink);font-size:.9rem;margin-bottom:8px}
.field input,.field select,.field textarea{
  width:100%;padding:13px 15px;border:1px solid var(--line-2);border-radius:11px;background:#fff;font-family:inherit;font-size:1rem;color:var(--ink);transition:border-color .2s,box-shadow .2s;
}
.field input::placeholder,.field textarea::placeholder{color:#94a3b8}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 4px rgba(245,158,11,.16)}
.field textarea{min-height:130px;resize:vertical}
.field .hint{font-size:.8rem;color:var(--muted);margin-top:7px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.input-icon{position:relative}
.input-icon svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:#94a3b8}
.input-icon input{padding-left:44px}
.form-aux{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;font-size:.9rem}
.checkbox{display:flex;align-items:center;gap:9px;color:var(--slate);font-size:.9rem;cursor:pointer}
.checkbox input{width:17px;height:17px;accent-color:var(--amber-600)}
.divider{display:flex;align-items:center;gap:14px;color:var(--muted);font-size:.84rem;margin:24px 0}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--line-2)}
.social-btns{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.btn-social{display:flex;align-items:center;justify-content:center;gap:9px;padding:12px;border:1px solid var(--line-2);border-radius:11px;background:#fff;font-family:var(--font-display);font-weight:600;color:var(--ink);font-size:.92rem;transition:border-color .2s,box-shadow .2s,transform .2s}
.btn-social:hover{border-color:#cbd5e1;box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.btn-social svg{width:18px;height:18px}
.auth-switch{text-align:center;margin-top:26px;color:var(--muted);font-size:.94rem}
.auth-switch a{color:var(--amber-700);font-weight:600;font-family:var(--font-display)}
.dev-note{margin-top:24px;background:var(--amber-50);border:1px dashed var(--amber-300);border-radius:12px;padding:13px 15px;font-size:.82rem;color:var(--amber-700)}
.dev-note b{font-family:var(--font-display)}

/* ---------- Page hero (sub pages) ---------- */
.page-hero{position:relative;padding:72px 0 54px;text-align:center;overflow:hidden}
.page-hero .hero-grid{opacity:.45}
.page-hero h1{margin:18px auto 18px;max-width:880px}
.page-hero p{max-width:640px;margin:0 auto;font-size:1.15rem;color:var(--slate)}
.breadcrumb{display:inline-flex;gap:8px;align-items:center;font-size:.85rem;color:var(--muted);font-family:var(--font-display);font-weight:500}
.breadcrumb a:hover{color:var(--amber-700)}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.contact-card{background:#fff;border:1px solid var(--line-2);border-radius:var(--radius-lg);padding:34px;box-shadow:var(--shadow-sm)}
.contact-info{display:flex;flex-direction:column;gap:18px}
.ci-item{display:flex;gap:16px;align-items:flex-start;background:#fff;border:1px solid var(--line-2);border-radius:16px;padding:20px}
.ci-item .ci{width:46px;height:46px;border-radius:12px;background:var(--amber-50);border:1px solid var(--amber-100);color:var(--amber-700);display:flex;align-items:center;justify-content:center;flex:none}
.ci-item .ci svg{width:22px;height:22px}
.ci-item b{font-family:var(--font-display);color:var(--ink);display:block;margin-bottom:3px}
.ci-item span,.ci-item a{color:var(--muted);font-size:.95rem}
.ci-item a:hover{color:var(--amber-700)}

/* ---------- Legal / prose ---------- */
.prose{max-width:800px;margin:0 auto}
.prose .updated{color:var(--muted);font-size:.92rem;margin-bottom:36px;padding-bottom:20px;border-bottom:1px solid var(--line)}
.prose h2{font-size:1.5rem;margin:40px 0 14px}
.prose h3{font-size:1.12rem;margin:26px 0 10px}
.prose p{margin-bottom:16px;color:var(--slate)}
.prose ul{list-style:disc;padding-left:22px;margin-bottom:18px;display:flex;flex-direction:column;gap:8px}
.prose ul li{color:var(--slate)}
.prose a{color:var(--amber-700);font-weight:600}
.prose a:hover{text-decoration:underline}
.legal-toc{background:var(--bg-soft);border:1px solid var(--line-2);border-radius:16px;padding:24px 28px;margin-bottom:40px}
.legal-toc h4{font-family:var(--font-display);color:var(--ink);margin-bottom:14px;font-size:1rem}
.legal-toc ol{padding-left:20px;display:flex;flex-direction:column;gap:8px;color:var(--slate)}
.legal-toc a{color:var(--slate)}
.legal-toc a:hover{color:var(--amber-700)}

/* ---------- Reveal animations ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:46px}
  .mock{max-width:540px;margin:0 auto}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .roles{grid-template-columns:repeat(3,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
  .split{gap:40px}
}
@media (max-width:760px){
  body{font-size:16px}
  .section{padding:68px 0}
  .nav-links,.nav-cta .login-link,.nav-cta .btn{display:none}
  .hamburger{display:flex}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .roles{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:1fr}
  .step-line{display:none}
  .prices{grid-template-columns:1fr}
  .price.feat{order:-1}
  .split,.split.rev{grid-template-columns:1fr}
  .split.rev .split-media{order:0}
  .statband{grid-template-columns:repeat(2,1fr);gap:28px 18px}
  .auth-wrap{grid-template-columns:1fr}
  .auth-aside{display:none}
  .contact-grid{grid-template-columns:1fr;gap:30px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .field-row{grid-template-columns:1fr}
  .cmp{font-size:.82rem}
  .cmp th,.cmp td{padding:11px 9px}
  .cta-band{padding:54px 24px}
}
@media (max-width:430px){
  .roles{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .chips{gap:8px}
  .mock-mobile{display:none}
}
