/* =========================================================
   Betterwork Art Gallery CRM — Salesforce-inspired light theme
   DM Sans · Glassmorphism · 2026 UI · premium motion
   ========================================================= */

:root {
  --sf-blue:#0176D3; --sf-sky:#1B96FF; --sf-navy:#032D60; --sf-deep:#014486;
  --sf-cloud:#00A1E0; --sf-ice:#EAF5FE; --sf-mist:#D8EDFF; --sf-orange:#FE9339;
  --sf-teal:#04E1CB; --sf-ink:#081B33;
  --glass-bg:rgba(255,255,255,0.62); --glass-brd:rgba(255,255,255,0.7);
  --ease:cubic-bezier(0.22,1,0.36,1);
}

*{font-family:'DM Sans',system-ui,sans-serif;}
html{scroll-behavior:smooth;scroll-padding-top:90px;}
body{background:linear-gradient(180deg,#fff 0%,#f4faff 40%,#fff 100%);}
::selection{background:var(--sf-sky);color:#fff;}

/* ---------- Aurora ---------- */
.aurora{position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none;}
.aurora__blob{position:absolute;border-radius:50%;filter:blur(90px);opacity:.45;will-change:transform;}
.aurora__blob--1{width:520px;height:520px;top:-120px;left:-80px;background:radial-gradient(circle,var(--sf-sky),transparent 70%);animation:drift 18s var(--ease) infinite alternate;}
.aurora__blob--2{width:480px;height:480px;top:30%;right:-120px;background:radial-gradient(circle,var(--sf-teal),transparent 70%);opacity:.3;animation:drift 22s var(--ease) infinite alternate-reverse;}
.aurora__blob--3{width:420px;height:420px;bottom:-120px;left:35%;background:radial-gradient(circle,var(--sf-mist),transparent 70%);animation:drift 26s var(--ease) infinite alternate;}
@keyframes drift{from{transform:translate(0,0) scale(1);}to{transform:translate(60px,40px) scale(1.15);}}

/* ---------- Glass primitives ---------- */
.glass-card{background:var(--glass-bg);backdrop-filter:blur(18px) saturate(160%);-webkit-backdrop-filter:blur(18px) saturate(160%);border:1px solid var(--glass-brd);box-shadow:0 8px 32px rgba(1,118,211,.12);}
.glass-nav{background:rgba(255,255,255,.7);backdrop-filter:blur(16px) saturate(160%);-webkit-backdrop-filter:blur(16px) saturate(160%);border-bottom:1px solid rgba(1,118,211,.08);border-radius:0 0 18px 18px;}
#header.scrolled .glass-nav{box-shadow:0 6px 24px rgba(3,45,96,.10);background:rgba(255,255,255,.88);}

/* ---------- Nav ---------- */
.nav-link{position:relative;transition:color .2s;}
.nav-link::after{content:'';position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--sf-blue);transition:width .3s var(--ease);border-radius:2px;}
.nav-link:hover{color:var(--sf-blue);}
.nav-link:hover::after{width:100%;}
.mobile-link{display:block;padding:10px 12px;border-radius:10px;font-weight:600;color:var(--sf-navy);transition:background .2s;}
.mobile-link:hover{background:var(--sf-ice);}

/* ---------- Buttons ---------- */
.btn-primary,.btn-ghost,.btn-white,.btn-outline-white{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:15px;padding:11px 22px;border-radius:12px;transition:all .25s var(--ease);cursor:pointer;white-space:nowrap;border:1px solid transparent;}
.btn-lg{padding:14px 28px;font-size:16px;border-radius:14px;}
.btn-primary{background:linear-gradient(135deg,var(--sf-blue),var(--sf-sky));color:#fff;box-shadow:0 8px 22px rgba(1,118,211,.35);}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(1,118,211,.45);}
.btn-ghost{background:rgba(255,255,255,.7);color:var(--sf-navy);border-color:var(--sf-mist);backdrop-filter:blur(8px);}
.btn-ghost:hover{background:#fff;border-color:var(--sf-blue);color:var(--sf-blue);transform:translateY(-2px);}
.btn-white{background:#fff;color:var(--sf-blue);box-shadow:0 8px 22px rgba(0,0,0,.15);}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(0,0,0,.22);}
.btn-outline-white{background:transparent;color:#fff;border-color:rgba(255,255,255,.5);}
.btn-outline-white:hover{background:rgba(255,255,255,.12);border-color:#fff;}

.pulse-dot{width:8px;height:8px;border-radius:50%;background:var(--sf-teal);box-shadow:0 0 0 0 rgba(4,225,203,.7);animation:pulse 2s infinite;flex:none;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(4,225,203,.6);}70%{box-shadow:0 0 0 8px rgba(4,225,203,0);}100%{box-shadow:0 0 0 0 rgba(4,225,203,0);}}

/* ---------- Typography ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--sf-blue);background:var(--sf-ice);border:1px solid var(--sf-mist);padding:7px 14px;border-radius:999px;}
.section-title{font-family:'DM Sans',sans-serif;font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:800;letter-spacing:-.02em;color:var(--sf-navy);line-height:1.12;text-align:center;}
.section-sub{margin:16px auto 0;max-width:660px;text-align:center;color:#4b5e74;font-size:1.05rem;line-height:1.65;}
.text-grad{background:linear-gradient(120deg,var(--sf-blue),var(--sf-cloud),var(--sf-teal));-webkit-background-clip:text;background-clip:text;color:transparent;}
.trust-chip{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.7);border:1px solid var(--sf-mist);padding:7px 14px;border-radius:999px;font-size:13px;color:var(--sf-navy);}

/* ---------- Hero ---------- */
.value-chip{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--sf-mist);padding:8px 14px;border-radius:12px;font-size:14px;font-weight:600;color:var(--sf-navy);box-shadow:0 4px 14px rgba(1,118,211,.08);}
.vc-ico{display:grid;place-items:center;width:22px;height:22px;border-radius:7px;font-size:11px;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--sf-blue),var(--sf-cloud));}
.mini-stat{font-size:1.8rem;font-weight:800;color:var(--sf-navy);letter-spacing:-.02em;}
.mini-label{font-size:.85rem;color:#7a8aa0;margin-top:2px;}

/* hero photo */
.hero-photo{padding:10px;border-radius:24px;margin:0;}
.hero-photo img{display:block;width:100%;height:auto;aspect-ratio:3/2;object-fit:cover;border-radius:16px;}

/* product mockup */
.mockup{border-radius:20px;overflow:hidden;}
.mockup__bar{display:flex;align-items:center;gap:7px;padding:12px 16px;background:rgba(255,255,255,.85);border-bottom:1px solid var(--sf-mist);}
.mockup__bar>span{width:11px;height:11px;border-radius:50%;background:#e2e8f0;}
.mockup__bar>span:nth-child(1){background:#ff5f57;}.mockup__bar>span:nth-child(2){background:#febc2e;}.mockup__bar>span:nth-child(3){background:#28c840;}
.mockup__url{margin-left:10px;font-size:12px;color:#94a3b8;background:#f1f5fb;padding:4px 12px;border-radius:8px;flex:1;}
.mockup__body{padding:18px;background:linear-gradient(160deg,#fbfdff,#eef6ff);}
.mockup__row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.mockup__card{background:#fff;border:1px solid #e8f0fb;border-radius:14px;padding:14px;box-shadow:0 4px 14px rgba(1,118,211,.06);}
.mc-label{font-size:11px;font-weight:600;color:#7a8aa0;text-transform:uppercase;letter-spacing:.04em;}
.mc-big{font-size:1.7rem;font-weight:800;line-height:1.1;margin-top:2px;}
.mc-sub{font-size:11px;color:#94a3b8;margin-top:1px;}
.mc-bar{height:6px;border-radius:5px;background:#e8f0fb;margin-top:10px;overflow:hidden;}
.mc-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--sf-blue),var(--sf-sky));border-radius:5px;animation:grow 1.4s var(--ease) both;}
@keyframes grow{from{width:0!important;}}
.mc-spark{display:flex;align-items:flex-end;gap:5px;height:34px;margin-top:8px;}
.mc-spark i{flex:1;background:linear-gradient(180deg,var(--sf-teal),var(--sf-cloud));border-radius:3px;opacity:.85;}
.mc-spark i:nth-child(1){height:40%;}.mc-spark i:nth-child(2){height:60%;}.mc-spark i:nth-child(3){height:45%;}.mc-spark i:nth-child(4){height:75%;}.mc-spark i:nth-child(5){height:90%;}.mc-spark i:nth-child(6){height:100%;}
.mockup__list{margin-top:12px;display:flex;flex-direction:column;gap:8px;}
.ml-row{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid #e8f0fb;border-radius:11px;padding:10px 12px;font-size:12.5px;color:#43536a;}
.ml-row em{color:#7a8aa0;font-style:normal;}
.ml-dot{width:8px;height:8px;border-radius:50%;background:var(--sf-blue);flex:none;}
.ml-dot--green{background:#10b981;}.ml-dot--orange{background:var(--sf-orange);}
.ml-tag{margin-left:auto;font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:999px;background:var(--sf-ice);color:var(--sf-blue);}
.ml-tag--green{background:#dcfce7;color:#15803d;}.ml-tag--orange{background:#fff1e0;color:#c2620f;}
.floating-stat{position:absolute;display:flex;align-items:center;gap:10px;padding:11px 15px;border-radius:16px;animation:floaty 5s ease-in-out infinite;}
.floating-stat--tl{top:-22px;left:-22px;}
.floating-stat--br{bottom:-22px;right:-22px;animation-delay:1.5s;}
.fs-ico{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-size:16px;background:var(--sf-ice);color:var(--sf-blue);}
.fs-ico--green{background:#dcfce7;color:#15803d;}
@keyframes floaty{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}

/* trust strip */
.trust-strip{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:14px 32px;padding:18px 26px;border-radius:18px;}
.trust-strip__item{display:flex;align-items:center;gap:9px;}
.stars-xs{font-size:12.5px;font-weight:700;color:var(--sf-navy);white-space:nowrap;}
.badge-pill{font-size:13px;font-weight:600;color:var(--sf-navy);background:var(--sf-ice);border:1px solid var(--sf-mist);padding:6px 12px;border-radius:999px;}

/* ---------- Marquees ---------- */
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);}
.marquee__track{display:flex;gap:18px;width:max-content;animation:scroll-x 30s linear infinite;}
.marquee__track--slow{animation-duration:42s;}
.marquee__track--reverse{animation:scroll-x-rev 46s linear infinite;}
.marquee:hover .marquee__track{animation-play-state:paused;}
@keyframes scroll-x{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@keyframes scroll-x-rev{from{transform:translateX(-50%);}to{transform:translateX(0);}}
.logo-pill{flex:none;display:inline-flex;align-items:center;gap:10px;padding:13px 24px;border-radius:14px;font-weight:700;font-size:16px;color:var(--sf-navy);background:rgba(255,255,255,.7);border:1px solid var(--sf-mist);backdrop-filter:blur(6px);}
.ip-ico{width:22px;height:22px;flex:none;}
.ip-mono{font-weight:800;letter-spacing:-.5px;}
.client-pill{flex:none;display:grid;place-items:center;min-width:190px;height:74px;padding:0 30px;border-radius:18px;font-weight:700;font-size:1.25rem;letter-spacing:-.02em;color:var(--sf-navy);background:#fff;border:1px solid #e8f0fb;box-shadow:0 6px 18px rgba(3,45,96,.05);transition:transform .25s var(--ease),box-shadow .25s var(--ease);}
.client-pill:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(1,118,211,.14);color:var(--sf-blue);}

/* ---------- Feature tiles / icons ---------- */
.feat-tile{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--sf-blue),var(--sf-cloud));box-shadow:0 8px 20px rgba(1,118,211,.3);}
.feat-tile svg{width:26px;height:26px;}
.feat-tile--green{background:linear-gradient(135deg,#10b981,var(--sf-teal));box-shadow:0 8px 20px rgba(16,185,129,.3);}
.feat-tile--lg{width:66px;height:66px;border-radius:18px;}
.feat-tile--lg svg{width:32px;height:32px;}

/* ---------- Feature hero ---------- */
.feature-hero{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;background:var(--glass-bg);backdrop-filter:blur(18px);border:1px solid var(--glass-brd);border-radius:28px;padding:44px;box-shadow:0 14px 44px rgba(1,118,211,.12);}
.feature-hero__title{font-size:1.9rem;font-weight:800;letter-spacing:-.02em;color:var(--sf-navy);margin:18px 0 10px;}
.feature-hero__desc{color:#4b5e74;line-height:1.65;font-size:1.05rem;}
.feat-checklist{margin-top:18px;display:flex;flex-direction:column;gap:11px;}
.feat-checklist li{position:relative;padding-left:30px;color:#43536a;font-weight:500;}
.feat-checklist li::before{content:'✓';position:absolute;left:0;top:-1px;width:20px;height:20px;border-radius:50%;background:var(--sf-ice);color:var(--sf-blue);font-size:12px;font-weight:800;display:grid;place-items:center;}

/* match card */
.match-card{background:#fff;border:1px solid #e8f0fb;border-radius:20px;padding:20px;box-shadow:0 16px 40px rgba(3,45,96,.12);}
.match-head{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:#7a8aa0;text-transform:uppercase;letter-spacing:.03em;margin-bottom:14px;}
.match-dot{width:8px;height:8px;border-radius:50%;background:var(--sf-teal);box-shadow:0 0 0 4px rgba(4,225,203,.2);}
.match-row{display:flex;align-items:center;gap:12px;padding:11px;border-radius:13px;background:#f8fbff;border:1px solid #eef5fc;margin-bottom:9px;}
.match-av{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-weight:800;font-size:13px;color:#fff;background:linear-gradient(135deg,var(--sf-blue),var(--sf-sky));flex:none;}
.match-av.av2{background:linear-gradient(135deg,#10b981,var(--sf-teal));}
.match-av.av3{background:linear-gradient(135deg,var(--sf-orange),#f59e0b);}
.match-info{flex:1;line-height:1.25;}
.match-info strong{display:block;font-size:14px;color:var(--sf-navy);}
.match-info span{font-size:12px;color:#94a3b8;}
.match-score{font-size:1.15rem;font-weight:800;color:var(--sf-blue);}
.match-score.s2{color:#10b981;}.match-score.s3{color:var(--sf-orange);}
.match-cta{margin-top:6px;width:100%;padding:12px;border:none;border-radius:13px;background:linear-gradient(135deg,var(--sf-navy),var(--sf-blue));color:#fff;font-weight:700;font-size:14px;cursor:pointer;transition:transform .2s;}
.match-cta:hover{transform:translateY(-2px);}

/* ---------- Bento grid ---------- */
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.bento-card{background:var(--glass-bg);backdrop-filter:blur(16px);border:1px solid var(--glass-brd);border-radius:20px;padding:26px;transition:transform .3s var(--ease),box-shadow .3s var(--ease);position:relative;overflow:hidden;}
.bento-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(27,150,255,.08),transparent 60%);opacity:0;transition:opacity .3s;}
.bento-card:hover{transform:translateY(-6px);box-shadow:0 20px 44px rgba(1,118,211,.16);}
.bento-card:hover::before{opacity:1;}
.bento-card h3{font-size:1.12rem;font-weight:700;color:var(--sf-navy);margin:16px 0 8px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.bento-card p{color:#5a6b80;line-height:1.6;font-size:.95rem;}
.bento-card--accent{background:linear-gradient(160deg,#ecfdf5,#fff);border-color:#bbf7d0;}
.new-pill{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:#fff;background:linear-gradient(135deg,#10b981,var(--sf-teal));padding:3px 9px;border-radius:999px;}

/* why cards */
.why-card{background:var(--glass-bg);backdrop-filter:blur(16px);border:1px solid var(--glass-brd);border-radius:22px;padding:30px;box-shadow:0 8px 28px rgba(1,118,211,.08);transition:transform .3s var(--ease),box-shadow .3s var(--ease);}
.why-card:hover{transform:translateY(-6px);box-shadow:0 20px 44px rgba(1,118,211,.16);}
.why-card h3{font-size:1.2rem;font-weight:700;color:var(--sf-navy);margin:16px 0 8px;}
.why-card p{color:#5a6b80;line-height:1.6;}

/* ---------- AI list ---------- */
.ai-item{display:flex;gap:16px;}
.ai-check{flex:none;width:44px;height:44px;border-radius:13px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--sf-blue),var(--sf-cloud));box-shadow:0 6px 16px rgba(1,118,211,.35);}
.ai-check svg{width:22px;height:22px;}
.ai-item h4{font-weight:700;color:var(--sf-navy);margin-bottom:3px;}
.ai-item p{color:#5a6b80;line-height:1.55;font-size:.97rem;}

/* ---------- Testimonials slider ---------- */
.t-slider{position:relative;margin-top:48px;overflow:hidden;border-radius:24px;}
.t-slider__track{display:flex;transition:transform .55s var(--ease);}
figure.t-card{display:flex;flex-direction:column;box-sizing:border-box;flex:0 0 calc(100% - 16px);margin:0 8px;padding:30px;border-radius:22px;background:var(--glass-bg);backdrop-filter:blur(16px);border:1px solid var(--glass-brd);box-shadow:0 8px 28px rgba(1,118,211,.08);}
@media(min-width:768px){figure.t-card{flex:0 0 calc(50% - 16px);}}
.t-card .stars{color:var(--sf-orange);letter-spacing:3px;font-size:1.05rem;}
.t-card blockquote{margin:14px 0 18px;font-size:1.05rem;line-height:1.7;color:var(--sf-ink);}
.t-card figcaption{display:flex;align-items:center;gap:12px;color:#5a6b80;font-size:.9rem;}
.t-card figcaption strong{display:block;color:var(--sf-navy);font-size:.98rem;}
.t-card figcaption em{font-style:normal;font-size:.85rem;color:#94a3b8;}
.t-av{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--sf-blue),var(--sf-sky));flex:none;}
.t-av.av2{background:linear-gradient(135deg,#10b981,var(--sf-teal));}
.t-av.av3{background:linear-gradient(135deg,var(--sf-orange),#f59e0b);}
.t-av.av4{background:linear-gradient(135deg,#8b5cf6,#6366f1);}
.t-av.av5{background:linear-gradient(135deg,#ec4899,#f43f5e);}
.t-arrow{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:#fff;color:var(--sf-navy);border:1px solid var(--sf-mist);cursor:pointer;transition:all .2s;z-index:3;box-shadow:0 6px 18px rgba(3,45,96,.12);}
.t-arrow:hover{background:var(--sf-blue);color:#fff;transform:translateY(-50%) scale(1.08);}
.t-arrow--prev{left:-4px;}.t-arrow--next{right:-4px;}
.t-dots{display:flex;gap:8px;justify-content:center;margin-top:24px;}
.t-dots button{width:9px;height:9px;border-radius:999px;border:none;background:var(--sf-mist);cursor:pointer;transition:all .3s var(--ease);}
.t-dots button.active{width:26px;background:var(--sf-blue);}

/* ---------- Pricing ---------- */
.price-card{background:var(--glass-bg);backdrop-filter:blur(16px);border:1px solid var(--glass-brd);border-radius:24px;padding:34px 28px;position:relative;transition:transform .3s var(--ease),box-shadow .3s var(--ease);display:flex;flex-direction:column;}
.price-card:hover{transform:translateY(-6px);box-shadow:0 20px 44px rgba(1,118,211,.15);}
.price-card--featured{background:linear-gradient(160deg,var(--sf-navy),var(--sf-deep));border-color:var(--sf-blue);box-shadow:0 24px 50px rgba(3,45,96,.35);}
.price-card--featured .price-name,.price-card--featured .price-amt{color:#fff;}
.price-card--featured .price-amt span{color:rgba(255,255,255,.65);}
.price-card--featured .price-desc{color:rgba(255,255,255,.75);}
.price-card--featured .price-list li{color:rgba(255,255,255,.9);}
.price-card--featured .price-list li::before{color:var(--sf-teal);}
.price-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--sf-teal),var(--sf-cloud));color:#003;font-size:12px;font-weight:800;padding:6px 16px;border-radius:999px;letter-spacing:.03em;box-shadow:0 6px 16px rgba(4,225,203,.4);}
.price-name{font-size:1.15rem;font-weight:800;color:var(--sf-navy);letter-spacing:.02em;text-transform:uppercase;}
.price-amt{font-size:2.3rem;font-weight:800;color:var(--sf-navy);margin:8px 0;letter-spacing:-.02em;}
.price-amt span{font-size:.95rem;font-weight:600;color:#7a8aa0;}
.price-desc{color:#5a6b80;min-height:48px;font-size:.95rem;}
.price-list{margin:18px 0 0;display:flex;flex-direction:column;gap:10px;flex:1;}
.price-list li{position:relative;padding-left:26px;color:#43536a;font-size:.95rem;}
.price-list li::before{content:'✓';position:absolute;left:0;color:var(--sf-blue);font-weight:800;}

/* ---------- FAQ ---------- */
.faq-item{background:var(--glass-bg);backdrop-filter:blur(12px);border:1px solid var(--glass-brd);border-radius:16px;padding:4px 22px;transition:box-shadow .2s;}
.faq-item[open]{box-shadow:0 10px 28px rgba(1,118,211,.12);}
.faq-item summary{list-style:none;cursor:pointer;padding:18px 0;font-weight:600;color:var(--sf-navy);display:flex;justify-content:space-between;align-items:center;gap:16px;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{content:'+';font-size:1.5rem;font-weight:400;color:var(--sf-blue);transition:transform .25s var(--ease);flex:none;}
.faq-item[open] summary::after{transform:rotate(45deg);}
.faq-item p{padding:0 0 20px;color:#5a6b80;line-height:1.65;}

/* ---------- Dashboard screenshot frame ---------- */
.dash-frame{margin:40px auto 0;max-width:1000px;padding:12px;border-radius:22px;}
.dash-frame img{display:block;width:100%;height:auto;border-radius:14px;}
.dash-frame figcaption{text-align:center;color:#5a6b80;font-size:.9rem;margin-top:12px;}
.dash-frame figcaption strong{color:var(--sf-blue);}

/* ---------- CTA banner ---------- */
.cta-banner{position:relative;overflow:hidden;text-align:center;padding:64px 32px 88px;border-radius:32px;background:linear-gradient(135deg,var(--sf-navy),var(--sf-blue) 70%,var(--sf-cloud));box-shadow:0 30px 60px rgba(3,45,96,.35);}
.cta-banner::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(4,225,203,.25),transparent 50%),radial-gradient(circle at 80% 80%,rgba(27,150,255,.3),transparent 50%);}
.cta-banner>*{position:relative;z-index:1;}

/* CTA waves animation */
.cta-waves{position:absolute;left:0;right:0;bottom:0;width:100%;height:80px;z-index:0!important;margin:0;}
.cta-waves svg{width:100%;height:100%;}
.waves-parallax>use{animation:wave-move 25s cubic-bezier(.55,.5,.45,.5) infinite;}
.waves-parallax>use:nth-child(1){animation-delay:-2s;animation-duration:7s;}
.waves-parallax>use:nth-child(2){animation-delay:-3s;animation-duration:10s;}
.waves-parallax>use:nth-child(3){animation-delay:-4s;animation-duration:13s;}
.waves-parallax>use:nth-child(4){animation-delay:-5s;animation-duration:20s;}
@keyframes wave-move{0%{transform:translate3d(-90px,0,0);}100%{transform:translate3d(85px,0,0);}}

/* ---------- Contact ---------- */
.contact-row{display:flex;align-items:center;gap:12px;font-size:1.02rem;}
.contact-ico{width:40px;height:40px;flex:none;display:grid;place-items:center;border-radius:12px;background:var(--sf-ice);border:1px solid var(--sf-mist);}

/* ---------- Footer ---------- */
.footer-wrap{background:linear-gradient(160deg,var(--sf-navy),#021d40);color:#fff;}
.footer-logo-chip{display:inline-flex;align-items:center;background:#fff;padding:8px 14px;border-radius:12px;margin-bottom:16px;box-shadow:0 6px 18px rgba(0,0,0,.18);}
.badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.95);border:1px solid rgba(255,255,255,.2);padding:9px 16px;border-radius:14px;font-size:14px;color:var(--sf-navy);transition:transform .2s;}
.badge:hover{transform:translateY(-3px);}
.badge .stars-xs{color:var(--sf-navy);}
.badge strong{color:var(--sf-navy);}
.footer-h{font-weight:700;color:#fff;margin-bottom:14px;font-size:.95rem;}
.footer-list{display:flex;flex-direction:column;gap:9px;}
.footer-list a{color:rgba(255,255,255,.62);font-size:.95rem;transition:color .2s;}
.footer-list a:hover{color:#fff;}

/* ---------- HubSpot form ---------- */
.hs-form-frame{width:100%;}
.hs-form-frame input[type="text"],.hs-form-frame input[type="email"],.hs-form-frame input[type="tel"],.hs-form-frame select,.hs-form-frame textarea{border-radius:12px!important;border:1px solid var(--sf-mist)!important;padding:12px 14px!important;}

/* ========================= MODAL ========================= */
.modal{position:fixed;inset:0;z-index:100;display:none;}
.modal.is-open{display:block;}
.modal__overlay{position:absolute;inset:0;background:rgba(3,45,96,.45);backdrop-filter:blur(6px);animation:fade .3s var(--ease);}
.modal__panel{position:absolute;width:min(1100px,94vw);max-height:92vh;overflow:auto;border-radius:26px;background:rgba(255,255,255,.85);backdrop-filter:blur(24px) saturate(160%);border:1px solid rgba(255,255,255,.7);box-shadow:0 40px 90px rgba(3,45,96,.4);top:50%;left:50%;transform:translate(-50%,-50%) scale(.96);opacity:0;animation:modalIn .4s var(--ease) forwards;}
@keyframes modalIn{to{transform:translate(-50%,-50%) scale(1);opacity:1;}}
@keyframes fade{from{opacity:0;}to{opacity:1;}}
.modal__close{position:absolute;top:16px;right:16px;z-index:5;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.9);border:1px solid var(--sf-mist);color:var(--sf-navy);cursor:pointer;transition:all .2s;}
.modal__close:hover{background:var(--sf-blue);color:#fff;transform:rotate(90deg);}
.modal__grid{display:grid;grid-template-columns:1fr 1fr;min-height:520px;}
.modal__left{position:relative;padding:34px;background:linear-gradient(160deg,var(--sf-navy),var(--sf-blue));color:#fff;border-radius:26px 0 0 26px;display:flex;flex-direction:column;}
.modal__brand{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);padding:8px 14px;border-radius:999px;align-self:flex-start;}
.slider{position:relative;flex:1;margin-top:24px;overflow:hidden;border-radius:18px;}
.slider__track{display:flex;height:100%;transition:transform .55s var(--ease);}
.slide{flex:0 0 100%;position:relative;display:flex;flex-direction:column;}
.slide img{width:100%;height:300px;object-fit:cover;border-radius:16px;}
.slide__body{padding:20px 4px 0;}
.slide__body h3{font-size:1.5rem;font-weight:800;letter-spacing:-.02em;}
.slide__body p{margin-top:8px;color:rgba(255,255,255,.82);line-height:1.6;font-size:.97rem;}
.slider__arrow{position:absolute;top:130px;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.9);color:var(--sf-navy);border:none;cursor:pointer;transition:all .2s;z-index:3;}
.slider__arrow:hover{background:#fff;transform:translateY(-50%) scale(1.1);}
.slider__arrow--prev{left:10px;}.slider__arrow--next{right:10px;}
.slider__dots{display:flex;gap:8px;justify-content:center;margin-top:18px;}
.slider__dots button{width:9px;height:9px;border-radius:999px;border:none;background:rgba(255,255,255,.4);cursor:pointer;transition:all .3s var(--ease);}
.slider__dots button.active{width:26px;background:#fff;}
.modal__right{padding:38px 34px;display:flex;flex-direction:column;overflow:auto;}
.modal__form-head h2{font-size:1.7rem;font-weight:800;letter-spacing:-.02em;color:var(--sf-navy);}
.modal__form-head p{margin-top:8px;color:#5a6b80;line-height:1.6;font-size:.97rem;margin-bottom:18px;}
.modal__legal{margin-top:auto;padding-top:18px;font-size:12px;color:#8595a8;}

/* ---------- Section CTA ---------- */
.section-cta{display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:48px;text-align:center;}
.section-cta__note{font-size:13px;color:#7a8aa0;}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal.in-view{opacity:1;transform:none;}
.reveal-delay-1{transition-delay:.12s;}
.reveal-delay-2{transition-delay:.24s;}

/* ---------- Responsive ---------- */
@media(max-width:1024px){.feature-hero{grid-template-columns:1fr;}.bento{grid-template-columns:repeat(2,1fr);}}
@media(max-width:860px){
  .modal__panel{width:96vw;max-height:94vh;border-radius:22px;}
  .modal__grid{grid-template-columns:1fr;min-height:0;}
  /* prioritise the lead/contact form: show it first */
  .modal__right{order:-1;padding:26px 20px 22px;}
  .modal__left{order:1;border-radius:0;padding:22px 20px 26px;}
  .modal__form-head{padding-right:40px;}
  .modal__form-head h2{font-size:1.4rem;}
  .modal__form-head p{font-size:.92rem;margin-bottom:14px;}
  .modal__brand{font-size:11px;padding:7px 12px;}
  .slider{margin-top:16px;}
  .slide img{height:170px;}
  .slide__body h3{font-size:1.25rem;}
  .slide__body p{font-size:.9rem;}
  .slider__arrow{top:85px;width:36px;height:36px;}
  .modal__close{top:10px;right:10px;width:36px;height:36px;}
  .modal__legal{padding-top:14px;}
}
@media(max-width:640px){.bento{grid-template-columns:1fr;}.mockup__row{grid-template-columns:1fr;}.feature-hero{padding:28px;}.floating-stat--tl{left:0;top:-16px;}.floating-stat--br{right:0;bottom:-16px;}}

@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;}.reveal{opacity:1;transform:none;}}
