/* ============================================================
   STARLLY SOLUTIONS v4 — Enterprise Light Design
   Cream/white + Starlly purple. Professional, world-class.
   Fonts: DM Serif Display (headlines) + Sora (UI/body)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Sora:wght@300;400;500;600;700;800&display=swap');

:root {
  --cream:      #FDFBF7;
  --cream-1:    #F5F2EC;
  --cream-2:    #EDE9E0;
  --cream-3:    #E0DAD0;
  --p-700:      #4C1D95;
  --p-600:      #6D28D9;
  --p-500:      #8B5CF6;
  --p-400:      #A78BFA;
  --p-300:      #C4B5FD;
  --p-100:      #EDE9FE;
  --p-50:       #F5F3FF;
  --t-600:      #0F766E;
  --t-500:      #0D9488;
  --t-100:      #CCFBF1;
  --ink:        #18111F;
  --ink-mid:    #3B3048;
  --ink-light:  #6E6482;
  --border:     rgba(24,17,31,0.08);
  --border-m:   rgba(24,17,31,0.12);
  --border-p:   rgba(139,92,246,0.22);
  --font-serif: 'DM Serif Display', Georgia, serif;
  --font-ui:    'Sora', system-ui, sans-serif;
  --r-sm:    6px;
  --r-md:    10px;
  --r-lg:    16px;
  --r-xl:    24px;
  --r-full:  9999px;
  --sh-sm:   0 1px 4px rgba(24,17,31,0.06);
  --sh-md:   0 4px 20px rgba(24,17,31,0.08);
  --sh-lg:   0 12px 48px rgba(24,17,31,0.1);
  --sh-p:    0 8px 28px rgba(109,40,217,0.28);
  --ease:    cubic-bezier(0.4,0,0.2,1);
  --ease-o:  cubic-bezier(0,0,0.2,1);
  --dur:     0.2s;
  --dur-md:  0.38s;
  --dur-sl:  0.6s;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--font-ui);
  background:var(--cream);
  color:var(--ink-mid);
  line-height:1.72;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:var(--font-serif);font-weight:400;line-height:1.12;color:var(--ink);letter-spacing:-0.02em}
h4,h5{font-family:var(--font-ui);font-weight:700;color:var(--ink);letter-spacing:-0.01em}
h1{font-size:clamp(2.2rem,4vw,3.8rem);line-height:1.08;letter-spacing:-0.03em}
h2{font-size:clamp(2rem,4vw,3.2rem)}
h3{font-size:clamp(1.3rem,2.5vw,1.85rem)}
h4{font-size:1.05rem}
p{color:var(--ink-light);margin-bottom:.9rem;font-size:.975rem;line-height:1.78}
a{color:var(--p-600);text-decoration:none;transition:color var(--dur) var(--ease)}
a:hover{color:var(--p-700)}
ul{list-style:none}
img{max-width:100%;display:block}
strong{color:var(--ink);font-weight:600}

.container{max-width:1160px;margin:0 auto;padding:0 1.5rem}
.section{padding:6rem 0;position:relative;z-index:1}
.section-sm{padding:3.5rem 0;position:relative;z-index:1}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}

/* BUTTONS */
.btn{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.72rem 1.55rem;border-radius:8px;
  font-family:var(--font-ui);font-weight:600;font-size:.88rem;
  cursor:pointer;border:none;text-decoration:none;white-space:nowrap;
  letter-spacing:-.01em;transition:all var(--dur-md) var(--ease-o);
}
.btn-primary{background:var(--p-600);color:#fff;box-shadow:var(--sh-p)}
.btn-primary:hover{background:var(--p-700);color:#fff;transform:translateY(-1px);box-shadow:0 10px 32px rgba(109,40,217,.38)}
.btn-secondary{background:transparent;border:1.5px solid var(--p-500);color:var(--p-600)}
.btn-secondary:hover{background:var(--p-50);border-color:var(--p-600);color:var(--p-700);transform:translateY(-1px)}
.btn-ghost{background:white;border:1.5px solid var(--border-m);color:var(--ink);box-shadow:var(--sh-sm)}
.btn-ghost:hover{background:var(--cream-1);color:var(--ink);transform:translateY(-1px)}
.btn-sm{padding:.44rem 1rem;font-size:.82rem}

/* NAV */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(253,251,247,.9);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid var(--border);
  transition:all var(--dur) var(--ease);
}
#nav.scrolled{background:rgba(253,251,247,.98);box-shadow:var(--sh-md)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.nav-logo img{height:32px;width:auto}
.nav-menu{display:flex;align-items:center;gap:.05rem}
.nav-item{position:relative}
.nav-link{
  display:flex;align-items:center;gap:.28rem;
  padding:.4rem .78rem;color:var(--ink-light);
  font-size:.855rem;font-weight:500;border-radius:var(--r-sm);
  transition:all var(--dur) var(--ease);
}
.nav-link:hover,.nav-link.active{color:var(--ink);background:var(--cream-1)}
.nav-link svg{width:12px;height:12px;transition:transform var(--dur) var(--ease)}
.nav-item:hover .nav-link svg{transform:rotate(180deg)}
.nav-dropdown{
  position:absolute;top:calc(100% + 8px);left:0;min-width:205px;
  background:white;border:1px solid var(--border-m);border-radius:var(--r-lg);
  padding:.4rem;opacity:0;visibility:hidden;
  transform:translateY(-6px);transition:all var(--dur-md) var(--ease-o);
  z-index:100;box-shadow:var(--sh-lg);
}
.nav-item:hover .nav-dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.nav-dropdown a{display:block;padding:.5rem .88rem;color:var(--ink-mid);font-size:.84rem;border-radius:var(--r-sm);font-weight:500;transition:all var(--dur) var(--ease)}
.nav-dropdown a:hover{color:var(--p-600);background:var(--p-50)}
.nav-cta{margin-left:.75rem}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:.25rem}
.nav-toggle svg{width:22px;height:22px;color:var(--ink)}

/* HERO */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding-top:64px;background:var(--cream);
  position:relative;overflow:hidden;
}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-bg::before{
  content:'';position:absolute;
  top:-10%;right:-5%;width:560px;height:560px;
  background:radial-gradient(ellipse,rgba(139,92,246,.09) 0%,transparent 65%);
}
.hero-bg::after{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(139,92,246,.11) 1.5px,transparent 1.5px);
  background-size:28px 28px;
  mask-image:radial-gradient(ellipse 55% 60% at 72% 38%,black 20%,transparent 72%);
}
/* Two-column hero grid — content left, illustration right */
.hero-inner{
  position:relative;z-index:1;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3rem;
  align-items:center;
  width:100%;
  padding:2rem 0;
}
.hero-content{max-width:560px}
.hero-illus{
  display:flex;align-items:center;justify-content:flex-end;
}
.hero-illus svg{
  width:100%;max-width:520px;height:auto;
  filter:drop-shadow(0 8px 40px rgba(109,40,217,0.10));
}
.hero-badge{
  display:inline-flex;align-items:center;gap:.42rem;
  padding:.3rem .9rem;background:var(--p-100);
  border:1px solid rgba(139,92,246,.25);border-radius:var(--r-full);
  font-size:.72rem;font-weight:700;color:var(--p-700);
  letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.4rem;
}
.hero-badge .dot{width:6px;height:6px;background:var(--t-500);border-radius:50%;animation:pulse 2.2s ease-in-out infinite}
.hero h1{margin-bottom:1.2rem}
.hero h1 em{font-style:italic;color:var(--p-600);position:relative;display:inline-block}
.hero h1 em::after{
  content:'';position:absolute;left:0;bottom:-3px;width:100%;height:5px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='5'%3E%3Cpath d='M0 3 Q12.5 0 25 3 Q37.5 6 50 3 Q62.5 0 75 3 Q87.5 6 100 3' stroke='%238B5CF6' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") repeat-x;
  background-size:100px 5px;opacity:.7;
}
.hero p{font-size:1.05rem;max-width:520px;margin-bottom:2rem;color:var(--ink-mid);line-height:1.7}
.hero-btns{display:flex;gap:.85rem;flex-wrap:wrap}
.hero-trust{
  display:flex;align-items:center;gap:1.5rem;
  margin-top:2.8rem;padding-top:2rem;
  border-top:1px solid var(--border);flex-wrap:wrap;
}
.hero-trust-item{display:flex;flex-direction:column}
.hero-trust-num{font-family:var(--font-serif);font-style:italic;font-size:1.9rem;color:var(--p-600);line-height:1}
.hero-trust-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-light);margin-top:.25rem}

/* SECTION LABEL */
.section-label{
  display:inline-flex;align-items:center;gap:.45rem;
  font-family:var(--font-ui);font-size:.7rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.13em;color:var(--p-600);
  margin-bottom:.8rem;
}
.section-label::before{content:'';width:16px;height:2px;background:linear-gradient(90deg,var(--p-500),var(--t-500));border-radius:2px}

/* CARDS */
.card{
  background:white;border:1px solid var(--border);border-radius:var(--r-lg);
  padding:2rem;transition:all var(--dur-md) var(--ease-o);
  position:relative;overflow:hidden;box-shadow:var(--sh-sm);
}
.card::after{
  content:'';position:absolute;top:0;left:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--p-500),transparent 80%);
  opacity:0;border-radius:3px 0 0 3px;transition:opacity var(--dur-md) var(--ease-o);
}
.card:hover{border-color:var(--border-p);transform:translateY(-3px);box-shadow:var(--sh-lg)}
.card:hover::after{opacity:1}
.card-icon{
  width:42px;height:42px;background:var(--p-100);
  border:1px solid rgba(139,92,246,.18);border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.1rem;color:var(--p-600);flex-shrink:0;
}
.card-icon svg{width:19px;height:19px}

/* METRICS BAR */
.metrics-bar{
  display:flex;border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);background:white;
  position:relative;z-index:1;
}
.metric-item{
  flex:1;padding:1.75rem 2rem;border-right:1px solid var(--border);
  position:relative;transition:background var(--dur) var(--ease);
}
.metric-item:last-child{border-right:none}
.metric-item::before{
  content:'';position:absolute;top:0;left:0;width:3px;height:100%;
  background:linear-gradient(180deg,var(--p-500),transparent);
  opacity:0;transition:opacity var(--dur) var(--ease);
}
.metric-item:hover{background:var(--p-50)}
.metric-item:hover::before{opacity:1}
.metric-num{
  font-family:var(--font-serif);font-style:italic;
  font-size:2.4rem;line-height:1;
  color:var(--p-700);
}
.metric-num-grad{
  font-family:var(--font-serif);font-style:italic;
  font-size:2.8rem;line-height:1;
  background:linear-gradient(135deg,var(--p-700) 0%,var(--p-500) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.metric-unit{font-size:.65rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--p-600);margin-top:.35rem}
.metric-desc{font-size:.8rem;color:var(--ink-light);margin-top:.2rem}

/* PROBLEM LIST */
.problem-list li{
  display:flex;align-items:flex-start;gap:.9rem;
  padding:1rem 0;border-bottom:1px solid var(--border);
  color:var(--ink-mid);font-size:.95rem;
}
.problem-list li:last-child{border-bottom:none}
.problem-icon{width:24px;height:24px;flex-shrink:0;color:var(--p-500);margin-top:2px}

/* TABLES */
.solutions-table{
  width:100%;border-collapse:collapse;background:white;
  border:1px solid var(--border-m);border-radius:var(--r-md);
  overflow:hidden;box-shadow:var(--sh-sm);
}
.solutions-table th{
  background:var(--p-50);padding:.9rem 1.1rem;text-align:left;
  font-family:var(--font-ui);font-size:.75rem;color:var(--p-700);
  text-transform:uppercase;letter-spacing:.09em;
  border-bottom:2px solid var(--border-p);font-weight:700;
}
.solutions-table td{
  padding:.9rem 1.1rem;color:var(--ink-mid);font-size:.875rem;
  border-bottom:1px solid var(--border);
}
.solutions-table tr:last-child td{border-bottom:none}
.solutions-table tr:hover td{background:var(--p-50)}

.compare-table{
  width:100%;border-collapse:collapse;border-radius:var(--r-md);
  overflow:hidden;border:1px solid var(--border-m);box-shadow:var(--sh-sm);
}
.compare-table th{
  padding:.9rem 1.1rem;font-family:var(--font-ui);font-size:.85rem;
  text-align:left;background:var(--p-50);color:var(--p-700);
  border-bottom:2px solid var(--border-p);font-weight:700;
}
.compare-table td{
  padding:.9rem 1.1rem;font-size:.875rem;color:var(--ink-mid);
  border-bottom:1px solid var(--border);background:white;
}
.compare-table tr:last-child td{border-bottom:none}
.compare-table th:first-child,.compare-table td:first-child{border-right:1px solid var(--border)}
.icon-check{color:var(--t-500)}
.icon-x{color:#EF4444}

/* BADGES */
.badge{
  display:inline-block;padding:.2rem .7rem;border-radius:var(--r-full);
  font-size:.72rem;font-weight:700;font-family:var(--font-ui);
  background:var(--p-100);border:1px solid rgba(139,92,246,.25);
  color:var(--p-700);margin:.1rem;letter-spacing:.02em;
}
.tag{
  display:inline-block;padding:.22rem .65rem;
  background:var(--t-100);border:1px solid rgba(13,148,136,.2);
  border-radius:var(--r-sm);font-size:.72rem;color:var(--t-600);
  font-weight:700;letter-spacing:.03em;font-family:var(--font-ui);
}

/* LEVERAGE CARDS */
.leverage-card{
  background:white;border:1px solid var(--border);border-radius:var(--r-lg);
  padding:1.75rem 2rem;display:flex;gap:1.25rem;align-items:flex-start;
  transition:all var(--dur-md) var(--ease-o);box-shadow:var(--sh-sm);
}
.leverage-card:hover{border-color:var(--border-p);box-shadow:var(--sh-md);transform:translateY(-2px)}
.leverage-number{
  font-family:var(--font-serif);font-style:italic;font-size:2.4rem;
  background:linear-gradient(135deg,var(--p-500),var(--p-300));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  line-height:1;flex-shrink:0;width:2.6rem;
}

/* BREADCRUMB */
.breadcrumb{
  display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;
  padding:1rem 0;font-size:.8rem;color:var(--ink-light);font-family:var(--font-ui);
}
.breadcrumb a{color:var(--ink-light);font-weight:500}
.breadcrumb a:hover{color:var(--p-600)}
.breadcrumb .sep{color:var(--border-m)}
.breadcrumb .current{color:var(--ink);font-weight:600}

/* PAGE HEADER */
.page-header{
  padding:104px 0 4rem;
  background:linear-gradient(165deg,var(--cream-1) 0%,var(--cream) 100%);
  border-bottom:1px solid var(--border);
  position:relative;overflow:hidden;
}
.page-header::before{
  content:'';position:absolute;top:-30%;right:0;
  width:480px;height:480px;
  background:radial-gradient(circle,rgba(139,92,246,.08) 0%,transparent 65%);
  pointer-events:none;
}
.page-header::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(139,92,246,.1) 1.5px,transparent 1.5px);
  background-size:22px 22px;
  mask-image:radial-gradient(ellipse 50% 55% at 80% 35%,black 15%,transparent 65%);
}

/* FORM */
.form-group{margin-bottom:1.1rem}
.form-label{
  display:block;margin-bottom:.4rem;
  font-size:.8rem;font-weight:600;color:var(--ink);
  font-family:var(--font-ui);
}
.form-control{
  width:100%;padding:.68rem .95rem;background:white;
  border:1.5px solid var(--border-m);border-radius:var(--r-md);
  color:var(--ink);font-family:var(--font-ui);font-size:.9rem;
  transition:all var(--dur) var(--ease);outline:none;
}
.form-control:focus{border-color:var(--p-500);box-shadow:0 0 0 3px rgba(139,92,246,.12)}
.form-control::placeholder{color:var(--ink-light);opacity:.55}
select.form-control option{background:white;color:var(--ink)}
textarea.form-control{resize:vertical;min-height:100px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}

/* STEPS */
.steps-list{counter-reset:step}
.step-item{
  display:flex;gap:1.4rem;align-items:flex-start;
  padding:1.4rem 0;border-bottom:1px solid var(--border);
}
.step-item:last-child{border-bottom:none}
.step-num{
  counter-increment:step;width:36px;height:36px;flex-shrink:0;
  background:var(--p-600);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-ui);font-weight:700;font-size:.8rem;
  color:#fff;box-shadow:var(--sh-p);
}
.step-num::before{content:counter(step,decimal-leading-zero)}

/* FAQ */
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{
  width:100%;background:none;border:none;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;
  padding:1.1rem 0;font-family:var(--font-ui);font-weight:600;
  font-size:.96rem;color:var(--ink);text-align:left;
  transition:color var(--dur) var(--ease);
}
.faq-q:hover{color:var(--p-600)}
.faq-q svg{width:17px;height:17px;flex-shrink:0;color:var(--p-500);transition:transform var(--dur) var(--ease)}
.faq-q.open svg{transform:rotate(180deg)}
.faq-a{display:none;padding:0 0 1.1rem;color:var(--ink-light);font-size:.92rem;line-height:1.72}
.faq-a.open{display:block}

/* CTA BANNER */
.cta-banner{
  background:linear-gradient(135deg,var(--p-600) 0%,var(--p-700) 55%,#3B0764 100%);
  border-radius:var(--r-xl);padding:4rem;text-align:center;
  position:relative;overflow:hidden;box-shadow:var(--sh-p);
}
.cta-banner::before{
  content:'';position:absolute;top:-60px;left:50%;transform:translateX(-50%);
  width:460px;height:360px;
  background:radial-gradient(circle,rgba(255,255,255,.13) 0%,transparent 65%);
  pointer-events:none;
}
.cta-banner::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(255,255,255,.07) 1px,transparent 1px);
  background-size:22px 22px;
}
.cta-banner h2{margin-bottom:.7rem;color:white}
.cta-banner p{max-width:480px;margin:0 auto 1.8rem;color:rgba(255,255,255,.75)}
.cta-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}
.cta-banner .btn-primary{background:white;color:var(--p-700);box-shadow:0 4px 18px rgba(0,0,0,.18)}
.cta-banner .btn-primary:hover{background:var(--cream-1);color:var(--p-700)}
.cta-banner .btn-secondary{border-color:rgba(255,255,255,.45);color:white}
.cta-banner .btn-secondary:hover{background:rgba(255,255,255,.12);color:white}

/* CASE STUDY CARDS */
.case-card{
  background:white;border:1px solid var(--border);border-radius:var(--r-lg);
  overflow:hidden;transition:all var(--dur-md) var(--ease-o);
  box-shadow:var(--sh-sm);display:flex;flex-direction:column;
}
.case-card:hover{border-color:var(--border-p);transform:translateY(-3px);box-shadow:var(--sh-lg)}
.case-card-header{
  padding:1.4rem 1.6rem 1rem;border-bottom:1px solid var(--border);
  background:var(--p-50);
}
.case-card-body{padding:1.5rem 1.6rem;flex:1;display:flex;flex-direction:column}
.case-card-tag{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.09em;color:var(--p-600);margin-bottom:.6rem;
  font-family:var(--font-ui);
}
.case-card-tag svg{width:14px;height:14px}
.case-card h4{color:var(--ink);margin-bottom:.5rem;font-size:1rem}
.case-stat{
  display:flex;align-items:baseline;gap:.3rem;
  margin-top:auto;padding-top:1rem;border-top:1px solid var(--border);
}
.case-stat-num{font-family:var(--font-serif);font-style:italic;font-size:1.7rem;color:var(--p-600);line-height:1}
.case-stat-label{font-size:.78rem;color:var(--ink-light);font-weight:500}

/* FOOTER */
footer{
  background:var(--ink);border-top:1px solid rgba(255,255,255,.06);
  padding:5rem 0 2.5rem;position:relative;z-index:1;
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;
  gap:2.5rem;margin-bottom:3.5rem;
}
.footer-brand img{height:28px;filter:brightness(0) invert(1)}
.footer-brand p{
  font-size:.855rem;color:rgba(255,255,255,.4);
  line-height:1.7;max-width:250px;margin-top:.9rem;
}
.footer-social{display:flex;gap:.45rem;margin-top:1.35rem;flex-wrap:wrap}
.footer-social-link{
  width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r-md);color:rgba(255,255,255,.35);
  transition:all var(--dur) var(--ease);
}
.footer-social-link:hover{background:rgba(139,92,246,.2);border-color:rgba(139,92,246,.4);color:var(--p-300)}
.footer-social-link svg{width:14px;height:14px}
.footer-col h5{
  font-size:.74rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:rgba(255,255,255,.8);margin-bottom:1rem;
}
.footer-col a{
  display:block;padding:.28rem 0;font-size:.855rem;
  color:rgba(255,255,255,.38);font-weight:400;
  transition:all var(--dur) var(--ease);
}
.footer-col a:hover{color:rgba(255,255,255,.88);transform:translateX(3px)}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:1.75rem;border-top:1px solid rgba(255,255,255,.07);
  font-size:.76rem;color:rgba(255,255,255,.28);flex-wrap:wrap;gap:.75rem;
}
.footer-bottom a{color:rgba(255,255,255,.28)}
.footer-bottom a:hover{color:var(--p-400)}

/* DIVIDER */
.divider{height:1px;background:var(--border);margin:2rem 0}

/* NOTIF */
.notif{
  position:fixed;top:78px;right:1.5rem;z-index:9999;
  padding:.9rem 1.4rem;border-radius:var(--r-md);
  background:white;border:1px solid var(--border-p);
  color:var(--p-700);font-size:.875rem;font-weight:600;
  transform:translateX(120%);transition:transform .4s var(--ease-o);
  max-width:300px;box-shadow:var(--sh-lg);
}
.notif.show{transform:translateX(0)}
.notif-error{border-color:rgba(239,68,68,.3);color:#DC2626}

/* ANIMATIONS */
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(.82);opacity:.5}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes floatA{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@keyframes floatB{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes spinSlow{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

.animate-fadeUp{animation:fadeUp .6s var(--ease-o) both}
.animate-fadeIn{animation:fadeIn .5s var(--ease-o) both}
.float-a{animation:floatA 4s ease-in-out infinite}
.float-b{animation:floatB 5.5s ease-in-out infinite .6s}
.spin-slow{animation:spinSlow 18s linear infinite}
.delay-1{animation-delay:.1s}.delay-2{animation-delay:.2s}
.delay-3{animation-delay:.3s}.delay-4{animation-delay:.42s}
.delay-5{animation-delay:.55s}

.reveal{opacity:0;transform:translateY(22px);transition:opacity var(--dur-sl) var(--ease-o),transform var(--dur-sl) var(--ease-o)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* MOBILE */
@media(max-width:900px){
  .nav-menu{display:none;position:fixed;inset:64px 0 0;background:white;padding:1rem;overflow-y:auto;flex-direction:column;border-top:1px solid var(--border)}
  .nav-menu.open{display:flex}
  .nav-toggle{display:flex}
  .nav-dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;background:var(--cream-1);margin-top:.2rem}
  .nav-cta{display:none}
  .hero-inner{grid-template-columns:1fr;gap:2.5rem;padding:2rem 0}
  .hero-illus{justify-content:center}
  .hero-illus svg{max-width:440px}
  .hero-content{max-width:100%}
}
@media(max-width:1100px){.footer-grid{grid-template-columns:1fr 1fr 1fr}.footer-brand{grid-column:1/-1}}
@media(max-width:768px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .footer-brand{grid-column:1/-1}
  .cta-banner{padding:2.5rem 1.5rem}
  .solutions-table{font-size:.8rem}
  .solutions-table th,.solutions-table td{padding:.75rem}
  .metrics-bar{flex-wrap:wrap}
  .metric-item{flex:0 0 50%;border-bottom:1px solid var(--border)}
  .hero-inner{grid-template-columns:1fr;gap:2rem;padding:1.5rem 0}
  .hero-illus{justify-content:center}
  .hero-illus svg{max-width:420px}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
  .footer-brand{grid-column:unset}
  .hero-btns{flex-direction:column}
  .cta-buttons{flex-direction:column;align-items:center}
  .metric-item{flex:0 0 100%}
}
