/* ════════════════════════════════════════════════════════════════
   AGENTE.LEGAL — Design System CSS
   Minimal · Bold · Luxury · Playful
   WCAG AA · 8px Grid
   ════════════════════════════════════════════════════════════════ */

/* ── PRIMITIVE COLOR TOKENS ───────────────────────────────────── */
:root {
  --o50:#F2F2F0;--o100:#E3E3DF;--o200:#C8C7C0;--o300:#ABAAA0;
  --o400:#8E8D82;--o500:#6B6A5F;--o600:#4A4940;--o700:#2E2D26;
  --o800:#1A1914;--o900:#0D0E0A;--o950:#080900;
  --s50:#FDF3EE;--s100:#FAE3D6;--s200:#F5C4A8;--s300:#EFA070;
  --s400:#E57A42;--s500:#C4622D;--s600:#A04E22;--s700:#7C3C1A;
  --c50:#FDFCFA;--c100:#FAF8F4;--c200:#F5F2EB;--c300:#EDE9DF;--c400:#E0DAD0;
  --jade:#2A9D6F;--jade-lt:#5ECBA1;--jade-dk:#1A6347;--jade-bg:#EEF9F3;
  --amber:#D4890A;--amber-lt:#F4BE5E;--amber-dk:#8B5A06;
  --rose:#C93A31;--rose-lt:#F4827A;--rose-dk:#7F221B;
  --sapphire:#2A7DC4;--sapphire-lt:#7EB8E8;--sapphire-dk:#1A4E7C;

  /* Semantic tokens — light mode */
  --bg:var(--c50);--surface:var(--c100);--subtle:var(--c200);
  --border:var(--c300);--border-s:var(--c400);--border-accent:var(--s500);
  --t1:var(--o900);--t2:var(--o600);--t3:var(--o400);
  --t-inv:var(--c50);--t-accent:var(--s600);
  --accent:var(--s500);--accent-h:var(--s600);
  --action-bg:var(--o900);--action-bg-h:var(--o700);
  --action-text:var(--c50);

  /* Typography */
  --fd:'Playfair Display',Georgia,serif;
  --fb:'Lora',Georgia,serif;
  --fu:'DM Sans','Helvetica Neue',sans-serif;
  --fm:'JetBrains Mono','Courier New',monospace;

  /* Shadows */
  --sh-xs:0 1px 2px rgba(13,14,10,.06);
  --sh-sm:0 2px 4px rgba(13,14,10,.08),0 1px 2px rgba(13,14,10,.04);
  --sh-md:0 4px 12px rgba(13,14,10,.10),0 2px 4px rgba(13,14,10,.06);
  --sh-lg:0 8px 24px rgba(13,14,10,.12),0 4px 8px rgba(13,14,10,.06);
  --sh-xl:0 16px 48px rgba(13,14,10,.15),0 8px 16px rgba(13,14,10,.08);
  --sh-a:0 8px 32px rgba(196,98,45,.22);

  /* Radius */
  --r-xs:4px;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:24px;--r-full:9999px;

  /* Motion */
  --ease-std:cubic-bezier(.4,0,.2,1);
  --ease-el:cubic-bezier(.16,1,.3,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
  --dur-fast:150ms;--dur-normal:250ms;--dur-slow:400ms;--dur-enter:800ms;

  /* Bootstrap override variables */
  --bs-primary:#C4622D;
  --bs-primary-rgb:196,98,45;
  --bs-secondary:#6B6A5F;
  --bs-success:#2A9D6F;
  --bs-danger:#C93A31;
  --bs-warning:#D4890A;
  --bs-info:#2A7DC4;
  --bs-body-bg:#FDFCFA;
  --bs-body-color:#0D0E0A;
  --bs-body-font-family:'Lora',Georgia,serif;
  --bs-border-color:#EDE9DF;
  --bs-border-radius:0.5rem;
  --bs-link-color:#A04E22;
  --bs-link-hover-color:#7C3C1A;
}

/* ── RESET & BASE ─────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{background:var(--bg);color:var(--t1);font-family:var(--fb);line-height:1.7;overflow-x:hidden;min-height:100vh;display:flex;flex-direction:column}
a{color:var(--t-accent);text-decoration:none;transition:color var(--dur-fast) var(--ease-std)}
a:hover{color:var(--s700)}
img{max-width:100%;display:block}
button{cursor:pointer;border:none;background:none;font-family:inherit}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--c200)}
::-webkit-scrollbar-thumb{background:var(--s400);border-radius:3px}
::selection{background:var(--s200);color:var(--s700)}
:focus-visible{outline:2px solid var(--s500);outline-offset:2px}

/* ── ANIMATIONS ───────────────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes shimmer{0%,100%{opacity:.5}50%{opacity:1}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes spin{to{transform:rotate(360deg)}}

.reveal{opacity:0;transform:translateY(20px);transition:opacity var(--dur-slow) var(--ease-el),transform var(--dur-slow) var(--ease-el)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}
@media(prefers-reduced-motion:reduce){
  .reveal,.d1,.d2,.d3,.d4{transition:none;opacity:1;transform:none}
  *{animation-duration:.01ms!important;transition-duration:.01ms!important}
}

/* Subtle noise overlay */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.018;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ── LAYOUT ───────────────────────────────────────────────────── */
.wrap{width:100%;max-width:1200px;margin:0 auto;padding:0 32px}
.wrap--sm{max-width:640px}
.wrap--md{max-width:860px}
section{padding:96px 0}

/* ── TYPOGRAPHY ───────────────────────────────────────────────── */
h1,h2,h3,h4,h5,h6{font-family:var(--fd);font-weight:400;line-height:1.15;letter-spacing:-.02em;color:var(--t1)}
h1{font-size:clamp(32px,5vw,56px)}
h2{font-size:clamp(26px,3.5vw,42px)}
h3{font-size:clamp(20px,2.5vw,28px)}
h4{font-size:20px;font-weight:600}
h5{font-size:16px;font-weight:600;font-family:var(--fu)}
h6{font-size:14px;font-weight:600;font-family:var(--fu)}
p{color:var(--t2);line-height:1.75}
.text-muted{color:var(--t3)!important}
.text-accent{color:var(--accent)}
.sec-tag{font-family:var(--fu);font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--s500);display:inline-flex;align-items:center;gap:8px;margin-bottom:16px}
.sec-tag::before{content:'';width:20px;height:1px;background:var(--s500)}

/* ── BUTTONS ──────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--fu);font-weight:500;letter-spacing:.02em;border-radius:var(--r-sm);transition:all var(--dur-fast) var(--ease-std);white-space:nowrap;cursor:pointer;border:none;text-decoration:none;flex-shrink:0}
.btn:focus-visible{outline:2px solid var(--s500);outline-offset:2px}
.btn-sm{height:36px;padding:0 16px;font-size:13px}
.btn-md{height:44px;padding:0 24px;font-size:14px}
.btn-lg{height:52px;padding:0 32px;font-size:15px}
.btn-xl{height:60px;padding:0 40px;font-size:16px}

/* Primary (Ink/dark) */
.btn-ink,.btn-primary{background:var(--o900);color:var(--c50);border:none;border-radius:var(--r-sm);padding:0 24px;height:44px}
.btn-ink:hover,.btn-primary:hover{background:var(--o700);transform:translateY(-1px);box-shadow:var(--sh-md);color:var(--c50)}
.btn-ink:active,.btn-primary:active{transform:none}
.btn-ink.btn-lg,.btn-primary.btn-lg{height:52px;padding:0 32px;font-size:15px}
.btn-ink.btn-xl,.btn-primary.btn-xl{height:60px;padding:0 40px;font-size:16px}
.btn-ink.btn-sm,.btn-primary.btn-sm{height:36px;padding:0 16px;font-size:13px}

/* Accent (Sienna/fire) */
.btn-fire,.btn-accent{background:var(--s500);color:#fff;border:none;border-radius:var(--r-sm);padding:0 24px;height:44px}
.btn-fire:hover,.btn-accent:hover{background:var(--s600);transform:translateY(-1px);box-shadow:var(--sh-a);color:#fff}
.btn-fire:active,.btn-accent:active{transform:none}
.btn-fire.btn-lg{height:52px;padding:0 32px;font-size:15px}
.btn-fire.btn-xl{height:60px;padding:0 40px;font-size:16px}
.btn-fire.btn-sm{height:36px;padding:0 16px;font-size:13px}

/* Ghost */
.btn-ghost,.btn-outline-primary{background:transparent;color:var(--o900);border:1.5px solid var(--c400);border-radius:var(--r-sm);padding:0 22px;height:44px;font-family:var(--fu);font-weight:500}
.btn-ghost:hover,.btn-outline-primary:hover{border-color:var(--o900);background:var(--c200);color:var(--o900)}
.btn-ghost.btn-lg,.btn-outline-primary.btn-lg{height:52px;padding:0 30px;font-size:15px}

/* Secondary */
.btn-secondary{background:var(--o600);color:var(--c50);border:none;border-radius:var(--r-sm);padding:0 24px;height:44px}
.btn-secondary:hover{background:var(--o700);color:var(--c50)}
.btn-outline-secondary{background:transparent;color:var(--t2);border:1.5px solid var(--border-s);border-radius:var(--r-sm);padding:0 22px;height:44px;font-family:var(--fu)}
.btn-outline-secondary:hover{border-color:var(--o600);color:var(--o900);background:var(--c200)}

/* Danger */
.btn-danger{background:var(--rose);color:#fff;border:none;border-radius:var(--r-sm);padding:0 24px;height:44px}
.btn-danger:hover{background:var(--rose-dk);color:#fff}
.btn-outline-danger{background:transparent;color:var(--rose);border:1.5px solid var(--rose);border-radius:var(--r-sm);padding:0 22px;height:44px;font-family:var(--fu)}
.btn-outline-danger:hover{background:var(--rose);color:#fff}

/* Full width */
.btn.w-100{width:100%;justify-content:center}
.btn-fire.w-100{width:100%}
.btn-ink.w-100{width:100%}

/* ── CHIPS & BADGES ───────────────────────────────────────────── */
.chip{display:inline-flex;align-items:center;gap:5px;font-family:var(--fu);font-size:11px;font-weight:500;padding:4px 10px;border-radius:var(--r-full);letter-spacing:.04em}
.chip-neutral{background:var(--c200);color:var(--t2);border:1px solid var(--border)}
.chip-fire{background:var(--s50);color:var(--s700);border:1px solid rgba(196,98,45,.2)}
.chip-success{background:var(--jade-bg);color:var(--jade-dk)}
.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:var(--r-full);font-family:var(--fu);font-size:11px;font-weight:500;letter-spacing:.04em}
.badge.bg-primary,.badge.bg-secondary{background:var(--s50)!important;color:var(--s700);border:1px solid rgba(196,98,45,.2)}
.badge.bg-success{background:var(--jade-bg)!important;color:var(--jade-dk)}
.badge.bg-warning{background:#FEF7E6!important;color:var(--amber-dk)}
.badge.bg-danger{background:#FDEEED!important;color:var(--rose-dk)}
.badge.bg-info{background:#EAF3FB!important;color:var(--sapphire-dk)}
.badge.fs-6{font-size:13px!important;padding:6px 14px}

/* ── FORMS ────────────────────────────────────────────────────── */
.form-group{margin-bottom:20px}
.form-label{font-family:var(--fu);font-size:13px;font-weight:500;color:var(--t1);margin-bottom:6px;display:block;letter-spacing:.01em}
.form-control,.form-select{width:100%;height:44px;padding:0 16px;font-family:var(--fb);font-size:15px;color:var(--t1);background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-sm);transition:border-color var(--dur-fast) var(--ease-std),box-shadow var(--dur-fast) var(--ease-std);outline:none}
.form-control:focus,.form-select:focus{border-color:var(--s500);box-shadow:0 0 0 3px rgba(196,98,45,.1);background:#fff}
.form-control::placeholder{color:var(--t3);font-style:italic;font-family:var(--fb)}
.form-control.is-invalid{border-color:var(--rose)}
.form-control.is-valid{border-color:var(--jade)}
textarea.form-control{height:auto;min-height:120px;padding:12px 16px;resize:vertical;line-height:1.7}
.form-text{font-family:var(--fu);font-size:12px;color:var(--t3);margin-top:5px}
.form-check{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px}
.form-check-input{width:16px;height:16px;flex-shrink:0;margin-top:3px;accent-color:var(--s500);border:1.5px solid var(--border);border-radius:3px;cursor:pointer}
.form-check-label{font-family:var(--fu);font-size:14px;color:var(--t2);cursor:pointer;line-height:1.5}
.invalid-feedback{font-family:var(--fu);font-size:12px;color:var(--rose);margin-top:5px}
.input-group{display:flex;gap:0}
.input-group .form-control{border-radius:var(--r-sm) 0 0 var(--r-sm);flex:1}
.input-group .btn{border-radius:0 var(--r-sm) var(--r-sm) 0;height:44px;flex-shrink:0}

/* ── NAV ──────────────────────────────────────────────────────── */
#nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:18px 0;transition:all var(--dur-normal) var(--ease-std)}
#nav.scrolled{background:rgba(253,252,250,.94);backdrop-filter:blur(18px) saturate(180%);border-bottom:1px solid var(--border);padding:12px 0;box-shadow:0 1px 8px rgba(13,14,10,.06)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:32px}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.nav-mark{width:34px;height:34px;background:var(--o900);border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--dur-fast) var(--ease-std)}
.nav-logo:hover .nav-mark{background:var(--s500)}
.nav-mark span{font-family:var(--fd);font-size:15px;font-weight:700;color:#fff}
.nav-wordmark{font-family:var(--fu);font-size:16px;font-weight:600;color:var(--t1)}
.nav-wordmark b{color:var(--s500)}
.nav-links{display:flex;align-items:center;gap:2px;list-style:none}
.nav-links a{font-family:var(--fu);font-size:13px;font-weight:500;color:var(--t2);padding:7px 14px;border-radius:6px;transition:all var(--dur-fast) var(--ease-std);display:block;text-decoration:none}
.nav-links a:hover{color:var(--t1);background:var(--c200)}
.nav-links a[aria-current]{color:var(--s600)}
.nav-right{display:flex;align-items:center;gap:10px}
.nav-login{font-family:var(--fu);font-size:13px;font-weight:500;color:var(--t2);padding:8px 14px;border-radius:6px;transition:all var(--dur-fast) var(--ease-std);text-decoration:none}
.nav-login:hover{color:var(--t1);background:var(--c200)}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;background:none;border:none}
.hamburger span{display:block;width:22px;height:2px;background:var(--t2);border-radius:99px;transition:all var(--dur-normal) var(--ease-std)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile menu */
.mob-menu{display:none;position:fixed;inset:0;background:var(--c50);z-index:999;flex-direction:column;padding:76px 24px 32px;gap:4px;opacity:0;pointer-events:none;transition:opacity var(--dur-normal) var(--ease-std)}
.mob-menu.open{opacity:1;pointer-events:all}
.mob-menu a{font-family:var(--fu);font-size:17px;font-weight:500;color:var(--t1);padding:14px 0;border-bottom:1px solid var(--border);text-decoration:none;transition:color var(--dur-fast) var(--ease-std)}
.mob-menu a:hover{color:var(--s500)}
.mob-close{position:absolute;top:18px;right:20px;width:40px;height:40px;border-radius:50%;background:var(--c200);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--t2);border:none;cursor:pointer;transition:background var(--dur-fast) var(--ease-std)}
.mob-close:hover{background:var(--c300)}

/* Navbar spacer for fixed nav */
.nav-spacer{height:72px}

/* ── CARDS ────────────────────────────────────────────────────── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:box-shadow var(--dur-normal) var(--ease-std)}
.card:hover{box-shadow:var(--sh-md)}
.card-header{padding:20px 24px;border-bottom:1px solid var(--border);background:var(--bg)}
.card-header.bg-primary{background:var(--o900)!important;color:var(--c50)!important}
.card-header.bg-primary h3,.card-header.bg-primary h4,.card-header.bg-primary p{color:var(--c50)!important}
.card-header.bg-light{background:var(--subtle)!important;color:var(--t1)!important}
.card-body{padding:24px}
.card-footer{padding:16px 24px;border-top:1px solid var(--border);background:var(--subtle)}
.card.border-primary{border-color:var(--s400)!important}
.card.border-success{border-color:var(--jade)!important}
.card.shadow-sm{box-shadow:var(--sh-sm)}
.card h3.card-title,.card h4.card-title{font-family:var(--fd);font-size:20px;font-weight:600;color:var(--t1)}
.list-group-item{padding:10px 0;border:none;border-bottom:1px solid var(--border);background:transparent;font-family:var(--fb);font-size:14px;color:var(--t2)}
.list-group-flush .list-group-item:last-child{border-bottom:none}

/* ── ALERTS ───────────────────────────────────────────────────── */
.alert{padding:14px 18px;border-radius:var(--r-md);margin-bottom:20px;font-family:var(--fu);font-size:14px;border:1px solid transparent}
.alert-info{background:#EAF3FB;color:var(--sapphire-dk);border-color:rgba(42,125,196,.2)}
.alert-success{background:var(--jade-bg);color:var(--jade-dk);border-color:rgba(42,157,111,.2)}
.alert-warning{background:#FEF7E6;color:var(--amber-dk);border-color:rgba(212,137,10,.2)}
.alert-danger{background:#FDEEED;color:var(--rose-dk);border-color:rgba(201,58,49,.2)}

/* ── TABLE ────────────────────────────────────────────────────── */
.table{width:100%;border-collapse:collapse;font-family:var(--fu);font-size:14px}
.table th{background:var(--subtle);font-weight:600;padding:12px 16px;color:var(--t1);text-align:left;border-bottom:2px solid var(--border)}
.table td{padding:12px 16px;vertical-align:middle;border-bottom:1px solid var(--border);color:var(--t2)}
.table-hover tbody tr:hover{background:var(--c200)}

/* ── PROGRESS ─────────────────────────────────────────────────── */
.progress{height:6px;border-radius:var(--r-full);background:var(--c300);overflow:hidden}
.progress-bar{height:100%;background:var(--s500);border-radius:var(--r-full)}

/* ── DROPDOWN ─────────────────────────────────────────────────── */
.dropdown-menu{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--sh-lg);padding:6px}
.dropdown-item{font-family:var(--fu);font-size:13px;color:var(--t2);padding:8px 14px;border-radius:6px;transition:all var(--dur-fast) var(--ease-std)}
.dropdown-item:hover{background:var(--subtle);color:var(--t1)}
.dropdown-divider{border-color:var(--border)}

/* ── FOOTER ───────────────────────────────────────────────────── */
footer,.site-footer{background:var(--o950);border-top:1px solid rgba(255,255,255,.06);padding:72px 0 48px;margin-top:auto}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand{font-family:var(--fu);font-size:18px;font-weight:600;color:rgba(255,255,255,.88);margin-bottom:10px}
.footer-brand b{color:var(--s400)}
.footer-tagline{font-family:var(--fb);font-size:13px;font-style:italic;color:rgba(255,255,255,.32);line-height:1.7;max-width:240px;margin-bottom:16px}
.footer-badges{display:flex;gap:6px;flex-wrap:wrap}
.fb-badge{font-family:var(--fm);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.22);border:1px solid rgba(255,255,255,.1);padding:3px 8px;border-radius:3px}
.footer-col-h{font-family:var(--fu);font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--s400);margin-bottom:14px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-links a{font-family:var(--fu);font-size:13px;color:rgba(255,255,255,.38);transition:color var(--dur-fast) var(--ease-std);text-decoration:none}
.footer-links a:hover{color:rgba(255,255,255,.78)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:28px;display:flex;justify-content:space-between;align-items:flex-start;gap:24px;flex-wrap:wrap}
.footer-legal{font-family:var(--fu);font-size:11px;color:rgba(255,255,255,.2);line-height:1.75;max-width:580px}
.footer-copy{font-family:var(--fm);font-size:10px;color:rgba(255,255,255,.18);letter-spacing:.05em;white-space:nowrap;flex-shrink:0}

/* Legacy footer (inner pages using Bootstrap) */
footer.bg-light{background:var(--o950)!important;color:rgba(255,255,255,.5)!important}
footer.bg-light h5{color:rgba(255,255,255,.88)!important;font-family:var(--fu)!important}
footer.bg-light .text-muted{color:rgba(255,255,255,.38)!important}
footer.bg-light a{color:rgba(255,255,255,.38)!important}
footer.bg-light a:hover{color:rgba(255,255,255,.78)!important}
footer.bg-light hr{border-color:rgba(255,255,255,.08)!important}
footer.bg-light .text-center{color:rgba(255,255,255,.3)!important}

/* ── HERO SECTION ─────────────────────────────────────────────── */
#hero,.hero-section-full{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding-top:80px;background:var(--bg)}
.hero-bg{position:absolute;inset:0;background:linear-gradient(155deg,var(--c50) 0%,var(--c100) 45%,var(--c200) 100%)}
.hero-grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(196,98,45,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(196,98,45,.035) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 20%,transparent 75%)}
.hero-glow{position:absolute;top:-20%;right:-5%;width:65%;height:130%;background:radial-gradient(ellipse at 60% 40%,rgba(196,98,45,.07) 0%,transparent 60%);pointer-events:none}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;padding:120px 0 80px}
.hero-inner--center{grid-template-columns:1fr;text-align:center;max-width:760px;margin:0 auto;justify-items:center;padding:140px 0 100px}
.hero-eyebrow{display:flex;align-items:center;gap:10px;margin-bottom:24px}
.hero-eyebrow::after{content:'';flex:1;max-width:56px;height:1px;background:var(--s500);opacity:.5}
.hero-h1{font-family:var(--fd);font-size:clamp(38px,5vw,64px);font-weight:400;line-height:1.04;letter-spacing:-.03em;color:var(--t1);margin-bottom:22px}
.hero-h1 em{font-style:italic;color:var(--s500)}
.hero-sub{font-family:var(--fb);font-size:clamp(15px,1.4vw,18px);color:var(--t2);line-height:1.75;max-width:480px;margin-bottom:36px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.hero-inner--center .hero-sub{max-width:100%;text-align:center}
.hero-inner--center .hero-actions{justify-content:center}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;margin-top:56px}
.h-stat{background:var(--surface);padding:20px;text-align:center;transition:background var(--dur-fast) var(--ease-std)}
.h-stat:hover{background:var(--c200)}
.h-stat-n{font-family:var(--fd);font-size:clamp(18px,2.5vw,28px);font-weight:400;color:var(--s500);line-height:1;margin-bottom:5px}
.h-stat-l{font-family:var(--fu);font-size:10px;color:var(--t3);letter-spacing:.04em}

/* Bootstrap hero (legacy) */
.hero-section{background:linear-gradient(155deg,var(--o900) 0%,var(--o800) 60%,var(--o700) 100%)!important;color:#fff;padding:80px 0;margin-bottom:0}
.hero-section h1{font-family:var(--fd);color:#fff!important}
.hero-section .lead{font-family:var(--fb);color:rgba(255,255,255,.8)}

/* ── MARQUEE ──────────────────────────────────────────────────── */
.marquee-wrap{background:var(--o900);overflow:hidden;padding:13px 0;border-top:1px solid rgba(255,255,255,.06)}
.marquee-track{display:flex;width:max-content;animation:marquee 36s linear infinite}
.marquee-track:hover{animation-play-state:paused}
.marquee-item{display:inline-flex;align-items:center;gap:10px;padding:0 26px;font-family:var(--fm);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.38);flex-shrink:0}
.marquee-item::after{content:'◆';font-size:4px;color:var(--s400)}

/* ── FEATURES SECTION ─────────────────────────────────────────── */
#features,.features-section{background:var(--bg)}
.features-head{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:end;margin-bottom:56px}
.features-h2{font-family:var(--fd);font-size:clamp(26px,3vw,42px);font-weight:400;line-height:1.12;letter-spacing:-.02em}
.features-h2 em{font-style:italic;color:var(--s500)}
.features-aside{color:var(--t2);font-size:15px;line-height:1.8}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.feat-block{background:var(--surface);padding:36px 28px;position:relative;overflow:hidden;transition:background var(--dur-normal) var(--ease-std)}
.feat-block:hover{background:var(--c200)}
.feat-block::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--s500),transparent);opacity:0;transition:opacity var(--dur-normal) var(--ease-std)}
.feat-block:hover::before{opacity:1}
.feat-n{font-family:var(--fm);font-size:10px;letter-spacing:.14em;color:var(--s500);opacity:.65;margin-bottom:18px;text-transform:uppercase}
.feat-icon{width:48px;height:48px;border:1px solid var(--border);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;margin-bottom:18px;font-size:20px;transition:border-color var(--dur-fast) var(--ease-std)}
.feat-block:hover .feat-icon{border-color:var(--s400)}
.feat-h3{font-family:var(--fd);font-size:20px;font-weight:600;line-height:1.2;color:var(--t1);margin-bottom:10px}
.feat-body{font-size:14px;color:var(--t2);line-height:1.8;margin-bottom:16px}
.feat-proof{font-family:var(--fu);font-size:12px;color:var(--jade);display:flex;align-items:flex-start;gap:5px;line-height:1.5}
.feat-proof::before{content:'✓';font-weight:700;flex-shrink:0;font-size:11px;margin-top:1px}

/* ── PRICING SECTION ──────────────────────────────────────────── */
#pricing,.pricing-section{background:var(--bg)}
.pricing-head{text-align:center;margin-bottom:52px}
.pricing-h2{font-family:var(--fd);font-size:clamp(26px,3vw,44px);font-weight:400;line-height:1.1;letter-spacing:-.02em;margin-bottom:12px}
.pricing-h2 em{font-style:italic;color:var(--s500)}
.pricing-sub{font-family:var(--fb);font-size:16px;color:var(--t2);max-width:480px;margin:0 auto;line-height:1.75}
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:start}
.plan{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:32px;position:relative;transition:box-shadow var(--dur-normal) var(--ease-std)}
.plan:hover{box-shadow:var(--sh-lg)}
.plan-feat{border:1.5px solid var(--s500);box-shadow:0 0 0 4px rgba(196,98,45,.06)}
.plan-badge{position:absolute;top:-1px;left:50%;transform:translateX(-50%);font-family:var(--fu);font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;background:var(--s500);color:#fff;padding:4px 14px;border-radius:0 0 var(--r-sm) var(--r-sm)}
.plan-name{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--s500);margin-bottom:14px}
.plan-price{font-family:var(--fd);font-size:44px;font-weight:300;color:var(--t1);line-height:1;margin-bottom:3px}
.plan-price sup{font-size:18px;vertical-align:top;margin-top:10px;display:inline-block}
.plan-price sub{font-size:13px;color:var(--t2);font-family:var(--fu);font-weight:400}
.plan-per{font-family:var(--fu);font-size:11px;color:var(--t3);margin-bottom:4px}
.plan-hr{border:none;border-top:1px solid var(--border);margin:18px 0}
.plan-feats{list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:24px}
.plan-feats li{display:flex;align-items:flex-start;gap:7px;font-family:var(--fu);font-size:13px;color:var(--t2);line-height:1.5}
.plan-feats li::before{content:'✓';color:var(--jade);font-weight:700;flex-shrink:0;font-size:11px;margin-top:1px}
.plan-cta{display:block;width:100%;text-align:center;font-family:var(--fu);font-size:13.5px;font-weight:500;padding:13px 20px;border-radius:var(--r-sm);transition:all var(--dur-fast) var(--ease-std);text-decoration:none;letter-spacing:.02em;cursor:pointer;border:none}
.plan-cta-out{border:1.5px solid var(--border);color:var(--t1);background:none}
.plan-cta-out:hover{border-color:var(--o900);background:var(--c200);color:var(--t1)}
.plan-cta-fill{background:var(--s500);color:#fff}
.plan-cta-fill:hover{background:var(--s600);box-shadow:var(--sh-a);transform:translateY(-1px);color:#fff}

/* ── PRICING CARDS (Bootstrap legacy) ────────────────────────── */
.pricing-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:all var(--dur-normal) var(--ease-std)}
.pricing-card:hover{transform:translateY(-3px);box-shadow:var(--sh-lg)}
.pricing-card.popular{border:1.5px solid var(--s500);box-shadow:0 0 0 4px rgba(196,98,45,.06)}
.pricing-card.popular::before{display:none}
.pricing-card .display-4{font-family:var(--fd)!important;font-size:42px!important;font-weight:300!important;color:var(--t1)!important}

/* ── SECURITY / TRUST ─────────────────────────────────────────── */
.security-section{background:var(--c200)}
.security-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:32px;text-align:center;transition:all var(--dur-normal) var(--ease-std)}
.security-card:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.security-card i.display-4{font-size:2.5rem!important;color:var(--jade)}

/* ── DASHBOARD ────────────────────────────────────────────────── */
.dashboard-container,.subscription-container{padding:0}
.page-header{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--border)}
.page-header h1{font-family:var(--fd);font-size:32px;font-weight:400}
.page-header .text-muted{font-family:var(--fb);font-size:15px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:24px;transition:all var(--dur-normal) var(--ease-std)}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.stat-card .stat-number{font-family:var(--fd);font-size:36px;font-weight:400;color:var(--s500)}
.stat-card .stat-label{font-family:var(--fu);font-size:12px;color:var(--t3);letter-spacing:.04em;text-transform:uppercase}
.step-card{background:var(--surface);border:1.5px solid var(--s400);border-radius:var(--r-md);text-align:center;padding:24px;transition:all var(--dur-normal) var(--ease-std)}
.step-card:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.step-number{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--o900);color:var(--c50);border-radius:50%;font-family:var(--fd);font-size:18px;font-weight:400;margin:0 auto 16px}

/* Dashboard icon circles */
.bg-primary.text-white.p-3.rounded-circle{background:var(--s50)!important;color:var(--s500)!important}
.text-success.fw-bold{color:var(--jade)!important}

/* ── SECURITY DASHBOARD ───────────────────────────────────────── */
.security-metric{text-align:center;padding:24px}
.security-metric i{font-size:2.5rem;margin-bottom:12px;color:var(--s500)}
.security-metric .metric-value{font-family:var(--fd);font-size:32px;font-weight:400;color:var(--t1)}
.security-metric .metric-label{font-family:var(--fu);font-size:12px;color:var(--t3);letter-spacing:.04em}
.risk-level{display:inline-flex;align-items:center;padding:4px 12px;border-radius:var(--r-full);font-family:var(--fu);font-size:12px;font-weight:500}
.risk-level.low{background:var(--jade-bg);color:var(--jade-dk)}
.risk-level.medium{background:#FEF7E6;color:var(--amber-dk)}
.risk-level.high{background:#FDEEED;color:var(--rose-dk)}
.risk-level.critical{background:rgba(102,16,242,.08);color:#4B1080}

/* ── DOCUMENT GENERATOR ───────────────────────────────────────── */
.document-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:32px}
.field-group{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border)}
.field-group:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.field-label{font-family:var(--fu);font-size:13px;font-weight:600;color:var(--t1);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.field-required::after{content:"*";color:var(--rose);margin-left:4px}
.clause-option{padding:14px;border:1.5px solid var(--border);border-radius:var(--r-md);margin-bottom:10px;transition:all var(--dur-fast) var(--ease-std);cursor:pointer}
.clause-option:hover{border-color:var(--s400);background:var(--s50)}
.clause-option.selected{border-color:var(--s500);background:var(--s50)}

/* ── CTA SECTION ──────────────────────────────────────────────── */
.cta-section{background:var(--o900);padding:96px 0;text-align:center;position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 55% 80% at 50% 50%,rgba(196,98,45,.08) 0%,transparent 70%)}
.cta-section.bg-light{background:var(--o900)!important;border-radius:0}
.cta-section h2{font-family:var(--fd);color:var(--c50)!important}
.cta-section p{color:rgba(255,255,255,.55)!important}
.cta-section .btn-primary{background:var(--s500);color:#fff}
.cta-section .btn-primary:hover{background:var(--s400);box-shadow:var(--sh-a)}

/* ── TRUST ROW ────────────────────────────────────────────────── */
.trust-row{display:flex;justify-content:center;gap:24px;margin-top:28px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:5px;font-family:var(--fu);font-size:12px;color:var(--t3)}
.trust-item::before{content:'✓';color:var(--jade);font-weight:700}

/* ── TESTIMONIALS ─────────────────────────────────────────────── */
.testi-section{background:var(--o900);position:relative;overflow:hidden;padding:96px 0}
.testi-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 70% at 50% 50%,rgba(196,98,45,.055) 0%,transparent 70%);pointer-events:none}
.testi-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-lg);padding:28px;position:relative;transition:all var(--dur-normal) var(--ease-std)}
.testi-card:hover{background:rgba(255,255,255,.07);border-color:rgba(196,98,45,.3)}
.testi-card::before{content:'\201C';font-family:var(--fd);font-size:72px;color:var(--s400);opacity:.14;position:absolute;top:10px;left:18px;line-height:1}
.testi-q{font-family:var(--fb);font-size:14px;font-style:italic;line-height:1.85;color:rgba(255,255,255,.72);margin-bottom:20px;padding-top:10px;position:relative;z-index:1}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-av{width:40px;height:40px;border-radius:50%;background:rgba(196,98,45,.2);color:var(--s300);font-family:var(--fu);font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid rgba(196,98,45,.3)}
.testi-name{font-family:var(--fu);font-size:13px;font-weight:600;color:rgba(255,255,255,.88)}
.testi-role{font-family:var(--fm);font-size:9px;color:rgba(255,255,255,.3);letter-spacing:.06em;margin-top:2px}
.testimonial-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-lg);padding:24px;position:relative}
.testimonial-card::before{content:'"';font-family:var(--fd);font-size:60px;color:var(--s400);opacity:.2;position:absolute;top:-10px;left:16px;line-height:1}

/* ── AUTH PAGES ───────────────────────────────────────────────── */
.auth-wrap{min-height:calc(100vh - 72px);display:flex;align-items:center;justify-content:center;padding:48px 16px}
.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--sh-xl);width:100%;max-width:460px;overflow:hidden}
.auth-card-header{padding:32px 36px 24px;border-bottom:1px solid var(--border);background:var(--bg)}
.auth-card-header h2{font-family:var(--fd);font-size:26px;font-weight:400;letter-spacing:-.02em;margin-bottom:6px}
.auth-card-header p{font-family:var(--fu);font-size:13px;color:var(--t3);margin:0}
.auth-card-body{padding:32px 36px}
.auth-divider{display:flex;align-items:center;gap:14px;margin:20px 0;font-family:var(--fu);font-size:12px;color:var(--t3)}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-footer{text-align:center;margin-top:24px;font-family:var(--fu);font-size:13px;color:var(--t3)}
.auth-footer a{color:var(--s600);font-weight:500}
.auth-footer a:hover{color:var(--s700)}
.oauth-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;height:44px;border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--bg);font-family:var(--fu);font-size:14px;font-weight:500;color:var(--t1);cursor:pointer;transition:all var(--dur-fast) var(--ease-std);text-decoration:none;margin-bottom:10px}
.oauth-btn:hover{border-color:var(--o600);background:var(--subtle);color:var(--t1)}

/* ── UTILITIES ────────────────────────────────────────────────── */
.text-gradient{background:linear-gradient(135deg,var(--s500) 0%,var(--s400) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.fade-in{animation:fadeUp .6s var(--ease-el) both}
.text-primary{color:var(--s500)!important}
.text-success{color:var(--jade)!important}
.text-danger{color:var(--rose)!important}
.text-warning{color:var(--amber)!important}
.text-info{color:var(--sapphire)!important}
.bg-primary{background:var(--s500)!important}
.bg-light{background:var(--subtle)!important}
.bg-dark{background:var(--o900)!important}
.border-primary{border-color:var(--s400)!important}
.border-success{border-color:var(--jade)!important}

/* ── INNER PAGE WRAPPER ───────────────────────────────────────── */
.page-container{max-width:1200px;margin:0 auto;padding:40px 32px}

/* ── RESPONSIVE ───────────────────────────────────────────────── */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:48px;padding-top:96px}
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .features-head{grid-template-columns:1fr}
  .feat-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .plans{grid-template-columns:1fr;max-width:400px;margin:0 auto}
}
@media(max-width:768px){
  section{padding:72px 0}
  .wrap{padding:0 20px}
  .nav-links,.nav-login{display:none}
  .hamburger{display:flex}
  .mob-menu{display:flex}
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .feat-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;gap:12px}
  .hero-inner--center .hero-actions{flex-direction:column;align-items:center;width:100%}
  .hero-inner--center .hero-actions .btn{width:100%;max-width:320px;justify-content:center}
  .auth-card-header,.auth-card-body{padding:24px}
  .page-container{padding:24px 20px}
}
@media(max-width:480px){
  section{padding:56px 0}
  .wrap{padding:0 16px}
  .hero-h1{font-size:34px}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .hero-actions .btn{width:100%;justify-content:center}
  .hero-stats{grid-template-columns:1fr 1fr}
  .auth-card{border-radius:var(--r-lg)}
}
