/********** Centok Pharma — Bespoke Light Editorial + Parallax (home) **********/
:root{
    --bg:#ffffff; --bg2:#eef7fd; --bg3:#f5faff;
    --navy:#163669; --navy-d:#0f2748;
    --cy:#41BEEE; --cy-d:#1f9fd1; --cy-soft:#e4f5fd;
    --tx:#51617a; --mut:#8492a8; --dim:#aab6c8;
    --heading:#142a4d;
    --line:rgba(22,54,105,.10); --line2:rgba(22,54,105,.16);
    --disp:'Space Grotesk', sans-serif; --body:'Inter', sans-serif;
    --grad:linear-gradient(120deg, #163669 0%, #2a6fb0 55%, #41BEEE 120%);
    --grad-cy:linear-gradient(120deg, #41BEEE, #1f9fd1);
    --sh-xs:0 6px 22px rgba(22,54,105,.06);
    --sh:0 24px 60px rgba(22,54,105,.12);
    --sh-lg:0 40px 90px rgba(22,54,105,.18);
    --pad:clamp(20px,6vw,120px);
}
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{ margin:0; background:var(--bg); color:var(--tx); font-family:var(--body); font-size:16px; line-height:1.75; overflow-x:hidden; -webkit-font-smoothing:antialiased; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--cy); color:#03233a; }

.bx-wrap{ max-width:1360px; margin:0 auto; padding-left:var(--pad); padding-right:var(--pad); }
.disp{ font-family:var(--disp); font-weight:600; letter-spacing:-.03em; line-height:1.05; color:var(--heading); }
.kick{ display:inline-flex; align-items:center; gap:12px; font-family:var(--disp); font-size:13px; letter-spacing:.26em; text-transform:uppercase; color:var(--cy-d); font-weight:600; }
.kick::before{ content:""; width:34px; height:2px; background:var(--grad-cy); border-radius:2px; }
.muted{ color:var(--mut); }
.idx{ font-family:var(--disp); font-size:clamp(3rem,7vw,6rem); font-weight:600; color:transparent; -webkit-text-stroke:1.4px rgba(22,54,105,.14); line-height:.8; }

#spinner{ display:none !important; }

/* ---- Header ---- */
.bx-header{ position:fixed; top:0; left:0; right:0; z-index:1000; transition:.4s; }
.bx-header.scrolled{ background:rgba(255,255,255,.85); backdrop-filter:blur(14px); box-shadow:0 10px 30px rgba(22,54,105,.07); }
.bx-header .bar{ display:flex; align-items:center; justify-content:space-between; padding:20px var(--pad); transition:.4s; }
.bx-header.scrolled .bar{ padding:12px var(--pad); }
.bx-logo img{ height:78px; width:auto; transition:.4s; }
.bx-header.scrolled .bx-logo img{ height:62px; }
.bx-menu{ display:flex; align-items:center; gap:38px; }
.bx-menu a{ font-family:var(--disp); font-weight:500; font-size:15px; color:var(--navy); position:relative; padding:6px 0; }
.bx-menu a::after{ content:""; position:absolute; left:0; bottom:0; width:0; height:2px; background:var(--grad-cy); transition:.35s; }
.bx-menu a:hover::after, .bx-menu a.active::after{ width:100%; }
.bx-menu a.bx-cta-link{ padding:15px 30px; color:#fff; }
.bx-menu a.bx-cta-link::after{ display:none; }
.bx-cta-link{ display:inline-flex; align-items:center; justify-content:center; gap:9px; font-family:var(--disp); font-weight:600; font-size:15px; line-height:1; background:var(--grad-cy); color:#fff !important; padding:15px 30px; border-radius:100px; box-shadow:0 12px 26px rgba(65,190,238,.32); transition:.35s; white-space:nowrap; }
.bx-cta-link:hover{ transform:translateY(-2px); box-shadow:0 18px 36px rgba(65,190,238,.45); }
.bx-burger{ display:none; background:none; border:none; color:var(--navy); font-size:26px; }
@media (max-width:900px){
    .bx-menu{ position:fixed; inset:0 0 0 auto; width:min(80vw,320px); flex-direction:column; align-items:flex-start; justify-content:center; gap:26px; padding:40px; background:#fff; box-shadow:-20px 0 60px rgba(22,54,105,.15); transform:translateX(105%); transition:.4s; z-index:1001; }
    .bx-menu.open{ transform:none; }
    .bx-burger{ display:block; z-index:1002; }
}

/* Left social rail */
.bx-rail{ position:fixed; left:26px; bottom:0; z-index:900; display:flex; flex-direction:column; align-items:center; gap:18px; }
.bx-rail::after{ content:""; width:1px; height:90px; background:var(--line2); }
.bx-rail a{ color:var(--mut); font-size:15px; transition:.3s; }
.bx-rail a:hover{ color:var(--cy-d); transform:translateY(-2px); }
@media (max-width:1100px){ .bx-rail{ display:none; } }

/* ---- Hero ---- */
.bx-hero{ position:relative; min-height:100vh; display:flex; align-items:center; overflow:hidden; padding-top:120px; background:radial-gradient(1100px 600px at 78% 20%, var(--bg2), transparent 60%), var(--bg); }
.bx-hero .bx-wrap{ position:relative; z-index:3; width:100%; }
.bx-hero-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:40px; align-items:center; }
.bx-hero-title{ font-family:var(--disp); font-weight:600; letter-spacing:-.035em; line-height:.98; font-size:clamp(3rem,8.5vw,7.2rem); margin:26px 0 24px; color:var(--heading); }
.bx-hero-title .out{ color:transparent; -webkit-text-stroke:1.5px rgba(22,54,105,.32); }
.bx-hero-title .rotator{ background:var(--grad-cy); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.bx-hero-sub{ color:var(--tx); font-size:clamp(1rem,1.4vw,1.18rem); max-width:520px; margin-bottom:38px; }
.bx-hero-actions{ display:flex; align-items:center; gap:28px; flex-wrap:wrap; }
.bx-arrow-link{ display:inline-flex; align-items:center; gap:14px; font-family:var(--disp); font-weight:600; font-size:16px; color:var(--navy); }
.bx-arrow-link.muted{ color:var(--mut); }
.bx-arrow-link .circ{ width:56px; height:56px; border-radius:50%; border:1.5px solid var(--line2); display:flex; align-items:center; justify-content:center; color:var(--cy-d); transition:.4s; }
.bx-arrow-link:hover .circ{ background:var(--grad-cy); color:#fff; border-color:transparent; transform:rotate(-45deg); }
.bx-hero-stats{ display:flex; gap:44px; margin-top:70px; flex-wrap:wrap; }
.bx-hero-stats .s .n{ font-family:var(--disp); font-weight:600; font-size:2.4rem; line-height:1; color:var(--heading); }
.bx-hero-stats .s .n span{ color:var(--cy-d); }
.bx-hero-stats .s .t{ color:var(--mut); font-size:.86rem; margin-top:6px; }
.bx-hero-stats .vline{ width:1px; background:var(--line2); }

/* Hero visual — DNA helix */
.bx-heroviz{ position:relative; aspect-ratio:1; max-width:480px; margin-left:auto; display:flex; align-items:center; justify-content:center; }
.bx-heroviz .hv-glow{ position:absolute; inset:10%; border-radius:50%; background:radial-gradient(circle at 50% 42%, rgba(65,190,238,.4), rgba(65,190,238,0) 66%); filter:blur(12px); z-index:0; }
.bx-heroviz .hv-ring{ position:absolute; border-radius:50%; }
.bx-heroviz .hv-ring.r1{ inset:0; border:1px dashed rgba(65,190,238,.32); animation:spin 42s linear infinite; }
.bx-heroviz .hv-ring.r2{ inset:13%; border:1px solid rgba(22,54,105,.10); animation:spin 30s linear infinite reverse; }
.bx-heroviz .hv-dna{ position:relative; z-index:2; height:94%; width:auto; filter:drop-shadow(0 22px 44px rgba(31,159,209,.28)); animation:hvFloat 6s ease-in-out infinite; }
@keyframes hvFloat{ 0%,100%{ transform:translateY(0) rotate(0deg);} 50%{ transform:translateY(-16px) rotate(2deg);} }
@keyframes spin{ to{ transform:rotate(360deg);} }
.bx-hero-glow{ position:absolute; z-index:1; border-radius:50%; filter:blur(34px); pointer-events:none; }
.bx-hero-glow.g1{ width:520px; height:520px; right:-120px; top:6%; background:radial-gradient(circle, rgba(65,190,238,.28), transparent 68%); }
.bx-hero-glow.g2{ width:440px; height:440px; left:-160px; bottom:-120px; background:radial-gradient(circle, rgba(22,54,105,.12), transparent 68%); }
/* Particle network canvas */
.bx-particles{ position:absolute; inset:0; width:100%; height:100%; z-index:0; pointer-events:none; }

/* DNA helix background motif */
.bx-dna{ position:absolute; z-index:0; right:-70px; top:50%; width:700px; transform:translateY(-50%) rotate(90deg); transform-origin:center; opacity:.45; pointer-events:none; animation:dnaFloat 12s ease-in-out infinite; }
@keyframes dnaFloat{ 0%,100%{ transform:translateY(-50%) rotate(90deg);} 50%{ transform:translateY(-54%) rotate(90deg);} }
@media (max-width:900px){ .bx-dna{ opacity:.18; right:-220px; } }

/* floating decorative shapes */
.bx-shape{ position:absolute; z-index:1; border-radius:26px; background:linear-gradient(135deg, rgba(65,190,238,.16), rgba(22,54,105,.06)); border:1px solid var(--line); backdrop-filter:blur(2px); }
.bx-shape.dot{ border-radius:50%; }
.bx-scrollcue{ position:absolute; bottom:30px; left:var(--pad); z-index:3; display:flex; align-items:center; gap:12px; color:var(--mut); font-size:12px; letter-spacing:.2em; text-transform:uppercase; }
.bx-scrollcue .line{ width:2px; height:46px; background:var(--line2); position:relative; overflow:hidden; }
.bx-scrollcue .line::after{ content:""; position:absolute; top:-50%; left:0; width:100%; height:50%; background:var(--cy); animation:scrolldown 1.8s ease-in-out infinite; }
@keyframes scrolldown{ 0%{ top:-50%;} 100%{ top:100%;} }
@media (max-width:900px){ .bx-hero-grid{ grid-template-columns:1fr; } .bx-heroviz{ margin:30px auto 0; max-width:300px; } .bx-scrollcue{ display:none; } .bx-shape{ display:none; } }

/* ---- Marquee ---- */
.bx-marquee{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:28px 0; overflow:hidden; background:var(--bg3); }
.bx-marquee .row{ display:flex; gap:56px; white-space:nowrap; width:max-content; animation:mq 26s linear infinite; align-items:center; }
.bx-marquee .row span{ font-family:var(--disp); font-weight:700; font-size:clamp(1.8rem,4.2vw,3.2rem); color:var(--navy); -webkit-text-stroke:0; letter-spacing:-.02em; }
.bx-marquee .row span.fill{ color:var(--cy); -webkit-text-stroke:0; font-size:1.3rem; }
@keyframes mq{ to{ transform:translateX(-50%);} }

/* ---- Section base ---- */
.bx-sec{ padding:clamp(80px,11vw,150px) 0; position:relative; overflow:hidden; }
.bx-sec.alt{ background:var(--bg3); }
.bx-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:30px; flex-wrap:wrap; margin-bottom:60px; }
.bx-head h2{ font-family:var(--disp); font-weight:600; letter-spacing:-.03em; line-height:1.04; font-size:clamp(2.2rem,4.6vw,3.7rem); margin:14px 0 0; max-width:15ch; color:var(--heading); }

/* About — asymmetric */
.bx-about-grid{ display:grid; grid-template-columns:.95fr 1.05fr; gap:clamp(30px,6vw,90px); align-items:center; }
@media(max-width:800px){ .bx-about-grid{ grid-template-columns:1fr; gap:52px; } .bx-about-media .bx-float{ left:12px; bottom:-22px; padding:16px 22px; } .bx-about-media .frameline{ right:-8px; top:-10px; width:55%; height:60%; } }
.bx-about-media{ position:relative; }
.bx-about-media img{ width:100%; border-radius:18px; box-shadow:var(--sh); }
.bx-about-media .frameline{ position:absolute; inset:-18px -18px auto auto; width:62%; height:70%; border:2px solid var(--cy); border-left:none; border-bottom:none; border-radius:0 18px 0 0; opacity:.6; }
.bx-float{ position:absolute; left:-28px; bottom:-28px; background:#fff; border-radius:16px; padding:20px 26px; box-shadow:var(--sh); }
.bx-float .n{ font-family:var(--disp); font-weight:600; font-size:2.4rem; background:var(--grad-cy); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; line-height:1; }
.bx-float .t{ color:var(--mut); font-size:.85rem; margin-top:4px; }
.bx-about-body p{ color:var(--tx); font-size:1.05rem; margin:22px 0; }
.bx-check{ list-style:none; padding:0; margin:0 0 32px; display:grid; gap:14px; }
.bx-check li{ display:flex; gap:14px; align-items:center; color:var(--heading); font-weight:500; }
.bx-check li i{ color:#fff; background:var(--grad-cy); width:24px; height:24px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:11px; }

/* Capabilities — sticky split */
.bx-cap-grid{ display:grid; grid-template-columns:.8fr 1.2fr; gap:clamp(30px,6vw,80px); align-items:start; }
.bx-cap-side{ position:sticky; top:120px; }
.bx-cap-side p{ color:var(--tx); margin:18px 0 30px; }
.bx-caprow{ display:grid; grid-template-columns:auto 1fr auto; gap:26px; align-items:center; padding:34px 6px; border-top:1px solid var(--line); transition:.4s; border-radius:14px; }
.bx-caprow:last-child{ border-bottom:1px solid var(--line); }
.bx-caprow .num{ font-family:var(--disp); font-weight:600; color:var(--dim); font-size:1.1rem; transition:.4s; }
.bx-caprow h3{ font-family:var(--disp); font-weight:600; font-size:clamp(1.4rem,2.4vw,2rem); margin:0 0 6px; color:var(--heading); transition:.4s; }
.bx-caprow p{ color:var(--mut); margin:0; max-width:52ch; }
.bx-caprow .go{ width:48px; height:48px; border-radius:50%; border:1.5px solid var(--line2); display:flex; align-items:center; justify-content:center; color:var(--mut); transition:.4s; }
.bx-caprow:hover{ padding-left:24px; padding-right:24px; background:linear-gradient(90deg, var(--cy-soft), transparent); }
.bx-caprow:hover .num, .bx-caprow:hover h3{ color:var(--cy-d); }
.bx-caprow:hover .go{ background:var(--grad-cy); color:#fff; border-color:transparent; transform:rotate(-45deg); }
@media (max-width:900px){ .bx-cap-grid{ grid-template-columns:1fr; } .bx-cap-side{ position:static; } .bx-caprow{ grid-template-columns:auto 1fr; } .bx-caprow .go{ display:none; } }

/* Products — staggered */
.bx-prod-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(20px,3vw,40px); }
.product-card{ position:relative; border-radius:18px; overflow:hidden; background:#fff; box-shadow:var(--sh-xs); border:1px solid var(--line); transition:transform .4s, box-shadow .4s; }
.product-card:hover{ box-shadow:var(--sh-lg); }
.bx-prod-grid > *:nth-child(even){ margin-top:70px; }
.product-card .pm{ position:relative; overflow:hidden; aspect-ratio:16/12; background:var(--bg2); }
.product-card .pm img{ width:100%; height:100%; object-fit:cover; transition:.7s; }
.product-card:hover .pm img{ transform:scale(1.06); }
.product-card .pcap{ display:flex; align-items:center; justify-content:space-between; padding:22px 24px; }
.product-card .pcap h4{ font-family:var(--disp); font-weight:600; font-size:1.25rem; margin:0; color:var(--heading); }
.product-card .pcap .cat{ font-size:12px; color:var(--cy-d); letter-spacing:.1em; text-transform:uppercase; font-weight:600; }
.product-card .pnum{ position:absolute; top:16px; left:18px; font-family:var(--disp); font-weight:600; color:#fff; font-size:.9rem; z-index:2; text-shadow:0 2px 8px rgba(0,0,0,.3); }
.product-card .peye{ position:absolute; top:14px; right:14px; width:44px; height:44px; border-radius:50%; background:#fff; color:var(--navy); display:flex; align-items:center; justify-content:center; opacity:0; transform:translateY(-8px); transition:.4s; z-index:2; box-shadow:var(--sh-xs); }
.product-card:hover .peye{ opacity:1; transform:none; }
.product-card .peye:hover{ background:var(--cy); color:#fff; }
@media (max-width:700px){ .bx-prod-grid{ grid-template-columns:1fr; } .bx-prod-grid > *:nth-child(even){ margin-top:0; } }

/* Stats */
.bx-stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-radius:20px; overflow:hidden; box-shadow:var(--sh); background:#fff; }
.bx-stats .st{ padding:56px 22px; border-right:1px solid var(--line); }
.bx-stats .st:last-child{ border-right:none; }
.bx-stats .st .big{ font-family:var(--disp); font-weight:600; font-size:clamp(2.6rem,5vw,4.4rem); line-height:1; color:var(--heading); }
.bx-stats .st .big span{ background:var(--grad-cy); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.bx-stats .st .lbl{ color:var(--mut); margin-top:10px; letter-spacing:.04em; }
@media (max-width:700px){ .bx-stats{ grid-template-columns:repeat(2,1fr); } .bx-stats .st:nth-child(2){ border-right:none; } .bx-stats .st:nth-child(-n+2){ border-bottom:1px solid var(--line); } }

/* CTA */
.bx-cta-band{ position:relative; overflow:hidden; border-radius:28px; background:var(--grad); padding:clamp(50px,7vw,90px); text-align:center; }
.bx-cta-band::before{ content:""; position:absolute; top:-90px; right:-70px; width:320px; height:320px; border-radius:50%; background:rgba(255,255,255,.08); }
.bx-cta-band::after{ content:""; position:absolute; bottom:-90px; left:-60px; width:260px; height:260px; border-radius:50%; background:rgba(65,190,238,.25); }
.bx-cta-band > *{ position:relative; z-index:2; }
.bx-cta-band .kick{ color:#bfeeffe0; justify-content:center; }
.bx-cta-band .kick::before{ background:rgba(255,255,255,.6); }
.bx-cta-band h2{ font-family:var(--disp); font-weight:600; letter-spacing:-.03em; line-height:1.05; font-size:clamp(2.2rem,5.5vw,4.4rem); margin:14px auto 16px; max-width:16ch; color:#fff; }
.bx-cta-band p{ color:rgba(255,255,255,.85); max-width:52ch; margin:0 auto 36px; }
.bx-cta-band .bx-cta-link{ background:#fff; color:var(--navy) !important; }

/* Footer */
.bx-footer{ background:var(--navy-d); color:rgba(255,255,255,.68); padding:80px 0 34px; }
.bx-foot-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.1fr; gap:40px; }
.bx-footer img.flogo{ height:48px; margin-bottom:20px; }
.bx-footer p.fab{ color:rgba(255,255,255,.66); max-width:34ch; }
.bx-footer h5{ font-family:var(--disp); font-weight:600; font-size:1rem; margin:0 0 18px; color:#fff; }
.bx-footer .fcol a{ display:block; color:rgba(255,255,255,.68); padding:7px 0; transition:.3s; }
.bx-footer .fcol a:hover{ color:var(--cy); padding-left:5px; }
.bx-foot-bottom{ display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap; margin-top:56px; padding-top:26px; border-top:1px solid rgba(255,255,255,.1); color:rgba(255,255,255,.5); font-size:.9rem; }
.bx-foot-bottom a{ color:#fff; }
.bx-foot-bottom a:hover{ color:var(--cy); }
@media (max-width:900px){ .bx-foot-top{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .bx-foot-top{ grid-template-columns:1fr; } }

/* ===== Inner page components ===== */
.bx-pagehead{ position:relative; overflow:hidden; padding:180px 0 96px; background:radial-gradient(1000px 560px at 82% 6%, var(--bg2), transparent 60%), var(--bg); }
.bx-pagehead .bx-wrap{ position:relative; z-index:2; }
.bx-pagehead h1{ font-family:var(--disp); font-weight:700; letter-spacing:-.03em; font-size:clamp(2.6rem,6vw,5rem); color:var(--heading); margin:14px 0 0; }
.bx-crumb{ display:flex; align-items:center; gap:10px; margin-top:18px; font-family:var(--disp); font-weight:500; color:var(--mut); font-size:15px; }
.bx-crumb a{ color:var(--mut); } .bx-crumb a:hover{ color:var(--cy-d); }
.bx-crumb .sep{ color:var(--dim); }
.bx-crumb .cur{ color:var(--cy-d); }

.bx-2col{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,64px); align-items:center; }
@media(max-width:900px){ .bx-2col{ grid-template-columns:1fr; } }

/* Mission / Vision */
.bx-mv{ background:#fff; border:1px solid var(--line); border-radius:18px; padding:40px; box-shadow:var(--sh-xs); transition:.4s; height:100%; }
.bx-mv:hover{ box-shadow:var(--sh); transform:translateY(-6px); }
.bx-mv .mvic{ width:64px; height:64px; border-radius:16px; background:var(--cy-soft); color:var(--cy-d); display:flex; align-items:center; justify-content:center; font-size:26px; margin-bottom:22px; transition:.4s; }
.bx-mv:hover .mvic{ background:var(--grad-cy); color:#fff; }
.bx-mv h3{ font-family:var(--disp); font-weight:600; color:var(--heading); font-size:1.6rem; margin:0 0 12px; }
.bx-mv p{ color:var(--tx); margin:0; }

/* Team */
.bx-team{ background:#fff; border:1px solid var(--line); border-top:4px solid var(--cy); border-radius:18px; padding:34px 30px; box-shadow:var(--sh-xs); transition:.4s; height:100%; }
.bx-team:hover{ box-shadow:var(--sh); transform:translateY(-6px); }
.bx-team .av{ width:72px; height:72px; border-radius:18px; background:var(--grad); color:#fff; display:flex; align-items:center; justify-content:center; font-family:var(--disp); font-weight:700; font-size:1.5rem; margin-bottom:20px; }
.bx-team h4{ font-family:var(--disp); font-weight:600; color:var(--heading); margin:0 0 3px; font-size:1.3rem; }
.bx-team h4 span{ font-size:12px; color:var(--mut); font-weight:500; }
.bx-team .role{ color:var(--cy-d); font-weight:600; font-family:var(--disp); margin:0 0 12px; }
.bx-team p{ color:var(--tx); margin:0; font-size:.96rem; }

/* Contact */
.bx-cirow{ display:flex; gap:18px; align-items:flex-start; background:#fff; border:1px solid var(--line); border-radius:16px; padding:22px 24px; margin-bottom:14px; transition:.35s; }
.bx-cirow:hover{ box-shadow:var(--sh); transform:translateY(-3px); }
.bx-cirow .ci{ width:50px; height:50px; flex:0 0 50px; border-radius:14px; background:var(--cy-soft); color:var(--cy-d); display:flex; align-items:center; justify-content:center; font-size:20px; }
.bx-cirow strong{ display:block; color:var(--heading); font-family:var(--disp); margin-bottom:4px; }
.bx-cirow p, .bx-cirow a{ color:var(--tx); margin:0; display:block; }
.bx-cirow a:hover{ color:var(--cy-d); }
.bx-map{ border-radius:18px; overflow:hidden; box-shadow:var(--sh); border:1px solid var(--line); height:100%; }
.bx-map iframe{ width:100%; height:100%; min-height:440px; border:0; display:block; }

/* Form */
.bx-form{ background:#fff; border:1px solid var(--line); border-radius:20px; padding:clamp(28px,4vw,48px); box-shadow:var(--sh); }
.bx-form .frow{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.bx-field{ margin-bottom:18px; }
.bx-field label{ display:block; font-family:var(--disp); font-weight:500; color:var(--heading); font-size:.9rem; margin-bottom:8px; }
.bx-field input, .bx-field textarea{ width:100%; border:1px solid var(--line2); border-radius:12px; padding:14px 16px; font-family:var(--body); font-size:15px; color:var(--heading); background:var(--bg3); outline:none; transition:.3s; }
.bx-field input:focus, .bx-field textarea:focus{ border-color:var(--cy); box-shadow:0 0 0 3px rgba(65,190,238,.15); background:#fff; }
.bx-field textarea{ resize:vertical; min-height:120px; }
.bx-btn{ display:inline-flex; align-items:center; gap:10px; border:none; cursor:pointer; font-family:var(--disp); font-weight:600; font-size:15px; background:var(--grad-cy); color:#fff; padding:15px 34px; border-radius:100px; box-shadow:0 12px 26px rgba(65,190,238,.32); transition:.35s; }
.bx-btn:hover{ background:var(--navy); transform:translateY(-2px); }
@media(max-width:600px){ .bx-form .frow{ grid-template-columns:1fr; } }

/* Core values */
.bx-vals{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.bx-val{ background:#fff; border:1px solid var(--line); border-radius:16px; padding:32px 26px; box-shadow:var(--sh-xs); transition:.4s; }
.bx-val:hover{ transform:translateY(-8px); box-shadow:var(--sh); }
.bx-val .vi{ width:58px; height:58px; border-radius:15px; background:var(--cy-soft); color:var(--cy-d); display:flex; align-items:center; justify-content:center; font-size:24px; margin-bottom:18px; transition:.4s; }
.bx-val:hover .vi{ background:var(--grad-cy); color:#fff; }
.bx-val h4{ font-family:var(--disp); font-weight:600; font-size:1.15rem; color:var(--heading); margin:0 0 8px; }
.bx-val p{ color:var(--mut); margin:0; font-size:.95rem; }
@media(max-width:900px){ .bx-vals{ grid-template-columns:1fr 1fr; } }
@media(max-width:520px){ .bx-vals{ grid-template-columns:1fr; } }

/* ---- Interaction bits ---- */
.rotator{ display:inline-block; }
@keyframes wordSwap{ 0%{ opacity:0; transform:translateY(16px);} 100%{ opacity:1; transform:none;} }
.scroll-progress{ position:fixed; top:0; left:0; height:3px; width:0; z-index:100001; background:var(--grad-cy); box-shadow:0 0 12px rgba(65,190,238,.7); }
.reveal{ opacity:0; transform:translateY(46px); transition:opacity .9s cubic-bezier(.2,.7,.3,1), transform .9s cubic-bezier(.2,.7,.3,1); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1 !important; transform:none !important; } [data-parallax]{ transform:none !important; } *{ animation:none !important; } }
@media (hover:hover) and (pointer:fine){
    body, a, button, .bx-menu a, .product-card, .bx-caprow, .bx-arrow-link { cursor:none; }
    .cursor-dot,.cursor-ring{ position:fixed; top:0; left:0; border-radius:50%; pointer-events:none; z-index:100002; }
    .cursor-dot{ width:7px; height:7px; margin:-3.5px 0 0 -3.5px; background:var(--cy-d); }
    .cursor-ring{ width:40px; height:40px; margin:-20px 0 0 -20px; border:1.5px solid rgba(65,190,238,.6); transition:width .25s,height .25s,margin .25s,background .25s; }
    .cursor-ring.hover{ width:66px; height:66px; margin:-33px 0 0 -33px; background:rgba(65,190,238,.12); }
}
