/* ==========================================================================
   Theme Sections & Blocks
   ========================================================================== */

/* -- Header — Dark Topbar + Nav -- */
.hdr-top{background:var(--color-text);padding:.45rem 0}.hdr-top-inner{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 1.5rem}.hdr-top-left{display:flex;align-items:center;gap:.75rem;color:rgba(255,255,255,.7);font-size:.78rem}.hdr-top-sep{opacity:.3}.hdr-top-right{display:flex;align-items:center;gap:.75rem}.hdr-main{position:sticky;top:0;z-index:100;background:var(--color-bg);border-bottom:1px solid var(--color-border);padding:.7rem 0;box-shadow:0 1px 4px rgba(0,0,0,.04)}.hdr-main-inner{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:0 1.5rem}.hdr-main-logo{font-family:var(--font-secondary);font-weight:800;font-size:1.3rem;color:var(--color-text);text-decoration:none}.hdr-main-nav{display:flex;gap:1.75rem;align-items:center}.hdr-main-link{color:var(--color-text-muted);text-decoration:none;font-size:.9rem;font-weight:600;transition:color .2s}.hdr-main-link:hover{color:var(--color-primary)}.hdr-main-actions{display:flex;align-items:center;gap:1rem}.hdr-main-cta{background:var(--color-primary);color:#fff;padding:.6rem 1.5rem;border-radius:var(--radius);text-decoration:none;font-size:.88rem;font-weight:700;transition:.2s}.hdr-main-cta:hover{background:var(--color-primary-dark)}.burger-toggle{display:none;background:none;border:none;cursor:pointer;padding:4px;position:relative;z-index:1000}.burger-toggle span{display:block;width:22px;height:2px;background:var(--color-text);margin:5px 0;transition:.3s}@media(max-width:768px){.hdr-top{display:none}.hdr-main-nav{position:fixed;top:0;right:-100%;width:80vw;height:100vh;background:var(--color-surface);flex-direction:column;padding:6rem 2rem;gap:1.25rem;transition:right .3s;box-shadow:-4px 0 24px rgba(0,0,0,.15);z-index:999}body.nav-open .hdr-main-nav{right:0}.hdr-main-link{font-size:1.1rem;color:var(--color-text)}.burger-toggle{display:block}.hdr-main-cta{display:none}}

/* -- Hero — Grid Info Blocks -- */
.hig-sec{padding:calc(var(--section-py)*1.5) 0 var(--section-py);background:var(--color-surface)}.hig-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem}.hig-top{max-width:700px;margin-bottom:4rem}.hig-label{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--color-primary);margin-bottom:1rem}.hig-title{font-family:var(--font-secondary);font-size:clamp(2.2rem,5vw,3.8rem);font-weight:800;color:var(--color-text);line-height:1.1;letter-spacing:-.02em;margin-bottom:1.25rem}.hig-desc{color:var(--color-text-muted);font-size:1.1rem;line-height:1.65;margin-bottom:2.5rem;max-width:560px}.hig-btn{display:inline-block;background:var(--color-primary);color:#fff;padding:.9rem 2.2rem;border-radius:var(--radius);font-weight:700;font-size:.95rem;text-decoration:none;transition:.2s}.hig-btn:hover{background:var(--color-primary-dark)}.hig-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}.hig-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:calc(var(--radius)*1.5);padding:2rem 1.75rem}.hig-card-num{display:block;font-family:var(--font-secondary);font-size:1.8rem;font-weight:900;color:var(--color-border);margin-bottom:1rem;line-height:1}.hig-card h3{font-family:var(--font-secondary);font-size:1rem;font-weight:700;color:var(--color-text);margin-bottom:.5rem}.hig-card p{color:var(--color-text-muted);font-size:.85rem;line-height:1.55;margin:0}@media(max-width:900px){.hig-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.hig-grid{grid-template-columns:1fr}.hig-top{text-align:center;margin-left:auto;margin-right:auto}.hig-top .hig-desc{margin-left:auto;margin-right:auto}}

/* -- Features — Outlined Three Column -- */
.fol-sec{padding:var(--section-py) 0;background:var(--color-surface)}.fol-inner{max-width:1100px;margin:0 auto;padding:0 1.5rem}.fol-head{text-align:center;max-width:620px;margin:0 auto 3.5rem}.fol-head h2{font-family:var(--font-secondary);font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;color:var(--color-text);line-height:1.2;margin-bottom:.75rem}.fol-head p{color:var(--color-text-muted);font-size:1.05rem;line-height:1.6}.fol-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.fol-card{background:transparent;border:2px dashed var(--color-border);border-radius:calc(var(--radius)*1.5);padding:2.5rem 2rem;transition:border-color .3s,background .3s}.fol-card:hover{border-color:var(--color-primary);border-style:solid;background:var(--color-bg)}.fol-card-label{display:block;font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--color-primary);margin-bottom:1rem}.fol-card h3{font-family:var(--font-secondary);font-size:1.15rem;font-weight:700;color:var(--color-text);margin-bottom:.6rem;line-height:1.3}.fol-card p{color:var(--color-text-muted);font-size:.9rem;line-height:1.6;margin:0}@media(max-width:900px){.fol-grid{grid-template-columns:1fr 1fr}}@media(max-width:600px){.fol-grid{grid-template-columns:1fr}}

/* -- Pricing — Single Featured Plan -- */
.psf-sec{padding:var(--section-py) 0;background:var(--color-surface)}.psf-inner{max-width:1000px;margin:0 auto;padding:0 1.5rem}.psf-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;background:var(--color-bg);border:1px solid var(--color-border);border-radius:calc(var(--radius)*2);padding:4rem}.psf-tag{display:block;font-size:.72rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--color-primary);margin-bottom:1rem}.psf-text h2{font-family:var(--font-secondary);font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;color:var(--color-text);line-height:1.2;margin-bottom:1rem}.psf-text p{color:var(--color-text-muted);font-size:.95rem;line-height:1.6;margin-bottom:2rem}.psf-price-block{display:flex;align-items:baseline;gap:.75rem;margin-bottom:2rem}.psf-amount{font-family:var(--font-secondary);font-size:3.5rem;font-weight:900;color:var(--color-text);line-height:1;letter-spacing:-.03em}.psf-price-meta{display:flex;flex-direction:column}.psf-period{font-size:.9rem;font-weight:600;color:var(--color-text)}.psf-note{font-size:.78rem;color:var(--color-text-muted)}.psf-btn{display:inline-block;background:var(--color-primary);color:#fff;padding:1rem 2.5rem;border-radius:var(--radius);font-weight:700;font-size:1rem;text-decoration:none;transition:.2s}.psf-btn:hover{background:var(--color-primary-dark);transform:translateY(-2px)}.psf-features-box{background:var(--color-surface);border:1px solid var(--color-border);border-radius:calc(var(--radius)*1.5);padding:2.5rem}.psf-features-box h4{font-family:var(--font-secondary);font-size:1rem;font-weight:700;color:var(--color-text);margin-bottom:1.5rem}.psf-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.85rem}.psf-features li{position:relative;padding-left:1.5rem;font-size:.9rem;color:var(--color-text-muted);line-height:1.45}.psf-features li::before{content:'';position:absolute;left:0;top:.35rem;width:6px;height:10px;border:solid var(--color-primary);border-width:0 2px 2px 0;transform:rotate(45deg)}@media(max-width:768px){.psf-content{grid-template-columns:1fr;padding:2.5rem 2rem;gap:2.5rem}}

/* -- Portfolio — Overlay Hover -- */
.pf-ovr{padding:var(--section-py) 0;background:var(--color-bg)}.pf-ovr-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem}.pf-ovr-title{font-family:var(--font-secondary);font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;color:var(--color-text);text-align:center;margin-bottom:3.5rem}.pf-ovr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.pf-ovr-card{position:relative;border-radius:calc(var(--radius)*1.5);overflow:hidden;aspect-ratio:4/3}.pf-ovr-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s}.pf-ovr-card:hover img{transform:scale(1.06)}.pf-ovr-layer{position:absolute;inset:0;background:linear-gradient(transparent 40%,rgba(0,0,0,.8));display:flex;flex-direction:column;justify-content:flex-end;padding:1.5rem;opacity:0;transition:opacity .35s}.pf-ovr-card:hover .pf-ovr-layer{opacity:1}.pf-ovr-layer span{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-primary);margin-bottom:.25rem}.pf-ovr-layer h3{font-family:var(--font-secondary);font-size:1.1rem;font-weight:700;color:var(--color-bg)}@media(max-width:768px){.pf-ovr-grid{grid-template-columns:1fr 1fr}.pf-ovr-layer{opacity:1}}@media(max-width:480px){.pf-ovr-grid{grid-template-columns:1fr}}

/* -- Blog — Hover Effect Cards -- */
.blg-crd-hv{padding:var(--section-py) 0;background:var(--color-surface)}.blg-crd-hv-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem}.blg-crd-hv-head{text-align:center;max-width:600px;margin:0 auto 3rem}.blg-crd-hv-head h2{font-family:var(--font-secondary);font-size:clamp(1.8rem,4vw,2.5rem);font-weight:800;color:var(--color-text);margin-bottom:.75rem}.blg-crd-hv-head p{color:var(--color-text-muted);font-size:1.05rem}.blg-crd-hv-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.blg-crd-hv-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;transition:transform .2s,box-shadow .2s}.blg-crd-hv-card:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(0,0,0,.1)}.blg-crd-hv-img{display:block;overflow:hidden}.blg-crd-hv-img img{width:100%;height:200px;object-fit:cover;transition:transform .3s}.blg-crd-hv-card:hover .blg-crd-hv-img img{transform:scale(1.03)}.blg-crd-hv-body{padding:1.5rem}.blg-crd-hv-meta{font-size:.8rem;color:var(--color-text-muted);margin-bottom:.75rem}.blg-crd-hv-body h3{margin-bottom:.75rem}.blg-crd-hv-body h3 a{color:var(--color-text);text-decoration:none;font-size:1.1rem;font-weight:700;line-height:1.4}.blg-crd-hv-body h3 a:hover{color:var(--color-primary)}.blg-crd-hv-body p{color:var(--color-text-muted);font-size:.9rem;line-height:1.6;margin-bottom:1rem}.blg-crd-hv-more{color:var(--color-primary);text-decoration:none;font-size:.85rem;font-weight:600}@media(max-width:768px){.blg-crd-hv-grid{grid-template-columns:1fr}}

/* -- Testimonials — Bordered Cards -- */
.tstm-crd-b{padding:var(--section-py) 0;background:var(--color-bg)}.tstm-crd-b-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem}.tstm-crd-b-head{text-align:center;max-width:600px;margin:0 auto 3rem}.tstm-crd-b-head h2{font-family:var(--font-secondary);font-size:clamp(1.8rem,4vw,2.5rem);font-weight:800;color:var(--color-text);margin-bottom:.75rem}.tstm-crd-b-head p{color:var(--color-text-muted);font-size:1.05rem;line-height:1.6}.tstm-crd-b-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}.tstm-crd-b-card{background:var(--color-surface);padding:2rem;border-radius:var(--radius);border:1px solid var(--color-border);transition:transform .2s,box-shadow .2s}.tstm-crd-b-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(0,0,0,.08)}.tstm-crd-b-stars{color:#f59e0b;font-size:.9rem;margin-bottom:1rem;letter-spacing:2px}.tstm-crd-b-quote{color:var(--color-text);font-size:.95rem;line-height:1.7;margin-bottom:1.5rem;font-style:italic}.tstm-crd-b-author strong{display:block;font-size:.9rem;color:var(--color-text);font-weight:600}.tstm-crd-b-author span{font-size:.8rem;color:var(--color-text-muted)}@media(max-width:768px){.tstm-crd-b-grid{grid-template-columns:1fr;gap:1.5rem}}

/* -- CTA — Trust Guarantee -- */
.cta-tru{padding:var(--section-py) 0;background:var(--color-surface)}.cta-tru-inner{max-width:700px;margin:0 auto;padding:0 1.5rem;text-align:center}.cta-tru-icon{width:64px;height:64px;margin:0 auto 1.5rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.cta-tru-icon svg{width:32px;height:32px}.cta-tru-title{font-family:var(--font-secondary);font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;color:var(--color-text);margin-bottom:1rem}.cta-tru-desc{color:var(--color-text-muted);font-size:1.05rem;line-height:1.6;margin-bottom:2.5rem}.cta-tru-action{display:flex;flex-direction:column;align-items:center;gap:1rem}.cta-tru-btn{background:var(--color-primary);color:#fff;padding:1rem 2.5rem;border-radius:var(--radius);font-weight:700;font-size:1rem;text-decoration:none;transition:background .2s,box-shadow .2s;box-shadow:0 8px 20px rgba(37,99,235,.15)}.cta-tru-btn:hover{background:var(--color-primary-dark);box-shadow:0 4px 10px rgba(37,99,235,.1)}.cta-tru-note{font-size:.85rem;color:var(--color-text-muted);display:flex;align-items:center;gap:.4rem}.cta-tru-note::before{content:'';display:inline-block;width:12px;height:12px;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%232563eb" stroke-width="3" stroke-linecap="round" stroke-linejoin="round"><polyline points="20 6 9 17 4 12"></polyline></svg>') no-repeat center;background-size:contain}

/* -- Footer — SaaS Mega Menu -- */
.ft-mega{background:var(--color-bg);padding:5rem 0 2rem;border-top:1px solid var(--color-border)}.ft-mega-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem}.ft-mega-main{display:flex;gap:5rem;margin-bottom:4rem;flex-wrap:wrap}.ft-mega-brand{flex:1;min-width:260px;max-width:320px}.ft-mega-logo{font-family:var(--font-secondary);font-size:1.5rem;font-weight:800;color:var(--color-text);text-decoration:none;display:inline-block;margin-bottom:1rem}.ft-mega-brand p{color:var(--color-text-muted);font-size:.95rem;line-height:1.6}.ft-mega-nav{flex:3;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:2rem}.ft-mega-col h4{font-size:.9rem;font-weight:700;color:var(--color-text);margin-bottom:1.25rem}.ft-mega-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.ft-mega-col a{color:var(--color-text-muted);text-decoration:none;font-size:.95rem;transition:color .2s}.ft-mega-col a:hover{color:var(--color-primary)}.ft-mega-bot{border-top:1px solid var(--color-border);padding-top:2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem}.ft-mega-copy p{color:var(--color-text-muted);font-size:.85rem;margin:0}.ft-mega-legal{display:flex;gap:1.5rem}.ft-mega-legal a{color:var(--color-text-muted);font-size:.85rem;text-decoration:none;transition:color .2s}.ft-mega-legal a:hover{color:var(--color-text)}@media(max-width:900px){.ft-mega-main{gap:3rem;flex-direction:column}.ft-mega-brand{max-width:100%}}@media(max-width:600px){.ft-mega-nav{grid-template-columns:1fr 1fr}.ft-mega-bot{flex-direction:column-reverse;align-items:flex-start}}

/* -- About — Story + Team -- */
.about-sec{padding:var(--section-py) 0}.about-sec .container{max-width:1000px;margin:0 auto;padding:0 1.5rem}.about-story{max-width:700px;margin-bottom:4rem}.about-story h1{font-family:var(--font-secondary);font-size:clamp(1.8rem,4vw,2.5rem);color:var(--color-text);margin-bottom:1rem}.about-lead{font-size:1.1rem;color:var(--color-text);line-height:1.6;margin-bottom:1rem;font-weight:500}.about-story p{color:var(--color-text-muted);line-height:1.7}.about-team h2{font-family:var(--font-secondary);font-size:1.8rem;margin-bottom:2rem;color:var(--color-text)}.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}.team-card{text-align:center;text-decoration:none;color:inherit;transition:transform .2s;display:block}.team-card:hover{transform:translateY(-4px)}.team-card img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--radius);margin-bottom:.75rem}.team-card h3{font-size:1.1rem;color:var(--color-text);margin-bottom:.25rem}.team-card span{color:var(--color-text-muted);font-size:.85rem}@media(max-width:768px){.team-grid{grid-template-columns:1fr 1fr}}@media(max-width:480px){.team-grid{grid-template-columns:1fr}}

/* -- About — Story + Team (Inner Pages) -- */
.team-profile{padding-bottom:5rem}.team-profile-header{background:var(--color-surface);padding:6rem 0;border-bottom:1px solid var(--color-border)}.tp-grid{max-width:1000px;margin:0 auto;padding:0 1.5rem;display:grid;grid-template-columns:350px 1fr;gap:4rem;align-items:center}.tp-image img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow);border:8px solid var(--color-bg)}.tp-name{font-family:var(--font-secondary);font-size:clamp(2.5rem, 5vw, 3.5rem);color:var(--color-text);line-height:1.1;margin-bottom:.5rem}.tp-role{font-size:1.25rem;font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1.5rem}.tp-divider{width:60px;height:4px;background:var(--color-border);margin-bottom:1.5rem}.tp-intro{font-size:1.1rem;color:var(--color-text-muted);line-height:1.6;margin-bottom:2rem}.tp-contacts{display:flex;gap:1rem;flex-wrap:wrap}.tp-contact-link{display:inline-flex;align-items:center;padding:.6rem 1.2rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:100px;color:var(--color-text);font-size:.9rem;font-weight:600;text-decoration:none;transition:.2s}.tp-contact-link:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.tp-body{max-width:800px;margin:0 auto;padding:4rem 1.5rem 0}.tp-bio h2{font-family:var(--font-secondary);font-size:2rem;color:var(--color-text);margin-bottom:1.5rem}.tp-content{font-size:1.1rem;line-height:1.8;color:var(--color-text-muted)}.tp-content p{margin-bottom:1.5rem}.tp-content h3{color:var(--color-text);font-family:var(--font-secondary);margin:2rem 0 1rem;font-size:1.4rem}@media(max-width:768px){.tp-grid{grid-template-columns:1fr;text-align:center}.tp-image{max-width:300px;margin:0 auto}.tp-divider{margin-left:auto;margin-right:auto}.tp-contacts{justify-content:center}}

/* -- Stats — Side-by-Side with Image -- */
.st-side{padding:var(--section-py) 0;background:var(--color-surface)}.st-side-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}.st-side-img img{width:100%;aspect-ratio:5/4;object-fit:cover;border-radius:calc(var(--radius)*1.5)}.st-side-tag{display:block;font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--color-primary);margin-bottom:.75rem}.st-side-content h2{font-family:var(--font-secondary);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800;color:var(--color-text);line-height:1.2;margin-bottom:.75rem}.st-side-sub{color:var(--color-text-muted);line-height:1.65;font-size:.95rem;margin-bottom:2rem}.st-side-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.st-side-stat{padding:1.25rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius)}.st-side-val{display:block;font-family:var(--font-secondary);font-size:1.8rem;font-weight:900;color:var(--color-text);letter-spacing:-.03em;line-height:1;margin-bottom:.25rem}.st-side-lbl{font-size:.78rem;font-weight:500;color:var(--color-text-muted)}@media(max-width:768px){.st-side-inner{grid-template-columns:1fr}.st-side-img{order:-1}}@media(max-width:400px){.st-side-grid{grid-template-columns:1fr}}

/* -- Services — Bento Box Grid -- */
.svc-bnt{padding:var(--section-py) 0;background:var(--color-bg)}.svc-bnt-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem}.svc-bnt-head{margin-bottom:3rem}.svc-bnt-tag{display:block;font-size:.75rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--color-primary);margin-bottom:1rem}.svc-bnt-head h2{font-family:var(--font-secondary);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;color:var(--color-text);line-height:1.15;margin:0}.svc-bnt-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}.svc-bnt-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:calc(var(--radius)*1.5);overflow:hidden;text-decoration:none;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s;position:relative}.svc-bnt-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(0,0,0,.08)}.svc-bnt-card:nth-child(1),.svc-bnt-card:nth-child(4){grid-column:span 2}.svc-bnt-content{padding:2rem;position:relative;z-index:2}.svc-bnt-card h3{font-family:var(--font-secondary);font-size:1.4rem;font-weight:800;color:var(--color-text);margin-bottom:.75rem}.svc-bnt-card p{color:var(--color-text-muted);font-size:.95rem;line-height:1.6;margin:0;max-width:400px}.svc-bnt-img{position:absolute;right:0;bottom:0;width:50%;height:100%;z-index:1;mask-image:linear-gradient(to right,transparent,black 40%);-webkit-mask-image:linear-gradient(to right,transparent,black 40%)}.svc-bnt-card:nth-child(2) .svc-bnt-img,.svc-bnt-card:nth-child(3) .svc-bnt-img{position:static;width:100%;height:180px;mask-image:none;-webkit-mask-image:none}.svc-bnt-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.svc-bnt-card:hover .svc-bnt-img img{transform:scale(1.05)}@media(max-width:900px){.svc-bnt-grid{grid-template-columns:repeat(2,1fr)}.svc-bnt-card:nth-child(1),.svc-bnt-card:nth-child(4){grid-column:span 2}.svc-bnt-card:nth-child(2) .svc-bnt-img,.svc-bnt-card:nth-child(3) .svc-bnt-img{height:220px}}@media(max-width:600px){.svc-bnt-grid{grid-template-columns:1fr}.svc-bnt-card:nth-child(1),.svc-bnt-card:nth-child(4){grid-column:span 1}.svc-bnt-img{position:static;width:100%;height:200px;mask-image:none;-webkit-mask-image:none}}

/* -- Services — Bento Box Grid (Inner Pages) -- */
.svc-in-bnt{padding-bottom:var(--section-py);background:var(--color-bg)}.svc-in-bnt-head{padding:6rem 0 4rem;background:var(--color-surface);border-bottom:1px solid var(--color-border);margin-bottom:4rem}.svc-in-bnt-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem}.svc-in-bnt-inner h1{font-family:var(--font-secondary);font-size:clamp(2.5rem,5vw,4rem);font-weight:900;color:var(--color-text);line-height:1.1;letter-spacing:-.03em;margin-bottom:1rem}.svc-in-bnt-inner p{font-size:1.25rem;color:var(--color-text-muted);line-height:1.6;max-width:700px}.svc-in-bnt-split{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}.svc-in-bnt-visual{position:sticky;top:6rem}.svc-in-bnt-visual img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:calc(var(--radius)*1.5);box-shadow:0 12px 32px rgba(0,0,0,.08)}.svc-in-bnt-content{font-size:1.1rem;line-height:1.8;color:var(--color-text-muted)}.svc-in-bnt-content h2,.svc-in-bnt-content h3{font-family:var(--font-secondary);color:var(--color-text);margin:0 0 1.25rem;line-height:1.3;font-weight:800}.svc-in-bnt-content p{margin-bottom:1.5rem}.svc-in-bnt-links{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--color-border);display:flex;gap:1rem;flex-wrap:wrap}.svc-bnt-primary{background:var(--color-primary);color:#fff;padding:.8rem 1.8rem;border-radius:var(--radius);font-weight:700;text-decoration:none;transition:.2s}.svc-bnt-primary:hover{background:var(--color-primary-dark)}.svc-bnt-ghost{border:2px solid var(--color-border);color:var(--color-text);padding:.8rem 1.8rem;border-radius:var(--radius);font-weight:700;text-decoration:none;transition:.2s}.svc-bnt-ghost:hover{border-color:var(--color-primary);color:var(--color-primary)}@media(max-width:900px){.svc-in-bnt-split{grid-template-columns:1fr}.svc-in-bnt-visual{position:static;margin-bottom:2rem}.svc-in-bnt-visual img{aspect-ratio:16/9}}

/* -- Contact Split — Minimal Form + Sidebar -- */
.cs-min{padding:var(--section-py) 0;background:var(--color-bg)}.cs-min-inner{max-width:1100px;margin:0 auto;padding:0 1.5rem;display:grid;grid-template-columns:1.5fr 1fr;gap:4rem;align-items:start}.cs-min-label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--color-primary);margin-bottom:.75rem}.cs-min-form h2{font-family:var(--font-secondary);font-size:clamp(1.6rem,3.5vw,2.2rem);font-weight:800;color:var(--color-text);margin-bottom:2rem}.cs-min-f{display:flex;flex-direction:column;gap:1rem}.cs-min-f input,.cs-min-f textarea{padding:.8rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);font-family:var(--font-primary);font-size:.9rem;transition:border-color .2s}.cs-min-f input:focus,.cs-min-f textarea:focus{outline:none;border-color:var(--color-primary)}.cs-min-f button{background:var(--color-text);color:var(--color-bg);border:none;padding:.85rem;border-radius:var(--radius);font-weight:700;cursor:pointer;transition:opacity .2s}.cs-min-f button:hover{opacity:.85}.cs-min-aside{display:flex;flex-direction:column;gap:1.5rem;position:sticky;top:6rem}.cs-min-box{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.75rem}.cs-min-box h3{font-family:var(--font-secondary);font-size:.95rem;font-weight:700;color:var(--color-text);margin-bottom:.75rem}.cs-min-box a,.cs-min-box span{display:block;color:var(--color-text-muted);font-size:.88rem;text-decoration:none;line-height:1.8;transition:color .2s}.cs-min-box a:hover{color:var(--color-primary)}@media(max-width:768px){.cs-min-inner{grid-template-columns:1fr;gap:2.5rem}}

/* -- FAQ — 2 Columns Accordion -- */
.faq-2col{padding:var(--section-py) 0;background:var(--color-bg)}.faq-2col-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem}.faq-2col-head{text-align:center;margin-bottom:4rem}.faq-2col-head h2{font-family:var(--font-secondary);font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;color:var(--color-text);margin:0}.faq-2col-grid{display:grid;grid-template-columns:1fr 1fr;column-gap:4rem;row-gap:0}.faq-item{border-bottom:1px solid var(--color-border)}.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;padding:1.5rem 0;background:transparent;border:none;color:var(--color-text);font-family:var(--font-primary);font-size:1.05rem;font-weight:700;text-align:left;cursor:pointer;transition:color .2s}.faq-question:hover{color:var(--color-primary)}.faq-icon{width:20px;height:20px;flex-shrink:0;transition:transform .3s ease;color:var(--color-text-muted)}.faq-item.active .faq-icon{transform:rotate(180deg);color:var(--color-primary)}.faq-answer{display:none}.faq-item.active .faq-answer{display:block}.faq-answer-inner{padding-bottom:1.5rem;color:var(--color-text-muted);font-size:.95rem;line-height:1.6}@media(max-width:900px){.faq-2col-grid{grid-template-columns:1fr}}

/* -- Privacy — Card Sections -- */
.prv-crd{padding:var(--section-py) 0;background:var(--color-surface)}.prv-crd-inner{max-width:900px;margin:0 auto;padding:0 1.5rem}.prv-crd-head{text-align:center;margin-bottom:4rem}.prv-crd-head h1{font-family:var(--font-secondary);font-size:clamp(2rem,4vw,3.5rem);font-weight:800;color:var(--color-text);margin-bottom:1.5rem}.prv-crd-badge{display:inline-block;background:var(--color-bg);border:1px solid var(--color-border);padding:.5rem 1.25rem;border-radius:100px;font-size:.9rem;font-weight:600;color:var(--color-text-muted)}.prv-crd-list{display:flex;flex-direction:column;gap:2rem}.prv-crd-box{background:var(--color-bg);border:1px solid var(--color-border);border-radius:calc(var(--radius)*1.5);padding:3rem;position:relative}.prv-crd-intro{border-top:4px solid var(--color-primary);font-size:1.1rem;color:var(--color-text-muted);line-height:1.7}.prv-crd-box-num{position:absolute;top:3rem;right:3rem;font-family:var(--font-secondary);font-size:4rem;font-weight:900;color:var(--color-surface);line-height:1;user-select:none;pointer-events:none}.prv-crd-box h2{font-family:var(--font-secondary);font-size:1.5rem;font-weight:800;color:var(--color-text);margin-bottom:1.5rem;position:relative;z-index:2}.prv-crd-box-txt{position:relative;z-index:2;color:var(--color-text-muted);font-size:1.05rem;line-height:1.7}.prv-crd-box-txt p{margin-bottom:1.25rem}.prv-crd-box-txt p:last-child{margin-bottom:0}.prv-crd-box-txt ul{margin-bottom:1.25rem;padding-left:1.5rem}@media(max-width:768px){.prv-crd-box{padding:2rem}.prv-crd-box-num{top:1.5rem;right:1.5rem;font-size:3rem}}

/* -- Terms of Service -- */
.legal-page{padding:var(--section-py) 0}.legal-content{max-width:780px;margin:0 auto;padding:0 1.5rem}.legal-content h1{font-family:var(--font-secondary);font-size:2rem;margin-bottom:.5rem}.legal-updated{color:var(--color-text-muted);font-size:.85rem;margin-bottom:2rem}.legal-content h2{font-size:1.2rem;margin-top:2rem;margin-bottom:.75rem}.legal-content p{color:var(--color-text-muted);line-height:1.7;font-size:.95rem}


/* ==========================================================================
   Dynamic Pages (single service, team profile)
   ========================================================================== */
.dynamic-hero{position:relative;min-height:40vh;display:flex;align-items:center;background-size:cover;background-position:center}
.dynamic-hero::before{content:'';position:absolute;inset:0;background:rgba(0,0,0,.55)}
.dynamic-hero .container{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:2rem 1.5rem}
.dynamic-hero h1{font-family:var(--font-secondary);font-size:clamp(1.8rem,4vw,2.8rem);color:#fff;margin-bottom:.5rem}
.dynamic-hero p{color:rgba(255,255,255,.85);font-size:1.05rem;max-width:600px}
.dynamic-content{padding:var(--section-py) 0}
.content-narrow{max-width:800px;margin:0 auto;padding:0 1.5rem}
.content-narrow h2{font-family:var(--font-secondary);font-size:1.4rem;color:var(--color-text);margin:2rem 0 .75rem}
.content-narrow p{color:var(--color-text-muted);line-height:var(--line-height);margin-bottom:1rem}
.content-narrow ul{margin:1rem 0 1rem 1.5rem;color:var(--color-text-muted);line-height:var(--line-height)}

/* -- Team Profile -- */
.team-profile-grid{display:grid;grid-template-columns:280px 1fr;gap:2rem;align-items:start;margin-bottom:2rem}
.team-profile-img img{width:100%;border-radius:var(--radius);aspect-ratio:1;object-fit:cover}
.team-profile-info h1{font-family:var(--font-secondary);font-size:1.8rem;margin-bottom:.25rem}
.team-role{color:var(--color-primary);font-weight:600;margin-bottom:.5rem}
.team-email a{color:var(--color-text-muted);text-decoration:none}
.spec-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}
.spec-tag{background:var(--color-surface);border:1px solid var(--color-border);padding:.25rem .75rem;border-radius:50px;font-size:.8rem;color:var(--color-text-muted)}

/* -- Cookie Banner Base -- */
.cookie-banner h4{font-family:var(--font-secondary);font-size:1.1rem;margin:0 0 .5rem;color:var(--color-text)}
.cookie-banner p{font-size:.85rem;color:var(--color-text-muted);margin-bottom:1rem;line-height:1.4}
.cookie-options{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;font-size:.9rem;color:var(--color-text)}
.cookie-options label{display:flex;align-items:center;gap:.5rem;cursor:pointer}
.cookie-buttons{display:flex;flex-wrap:wrap;gap:.5rem}
.cookie-buttons button{flex:1;min-width:120px;font-size:.85rem;padding:.5rem 1rem;white-space:nowrap}
.btn-alt{background:transparent;border:1px solid var(--color-border);color:var(--color-text);border-radius:var(--radius);cursor:pointer;transition:all .2s;text-align:center;display:inline-block;padding:0.75rem 1.5rem;}
.btn-alt:hover{background:var(--color-background)}

/* -- Utility -- */
header.scrolled{box-shadow:var(--shadow)}
.form-error{border-color:var(--color-primary)!important}

/* -- Header Switchers (Lang & Theme) -- */
.header-switchers{display:flex;align-items:center;gap:1rem;margin-left:1rem}
.lang-links{display:flex;gap:.5rem}
.lang-links a{color:var(--color-text-muted);text-decoration:none;font-size:.85rem;font-weight:600;transition:color .2s}
.lang-links a:hover, .lang-links a.active{color:var(--color-primary)}
#theme-toggle{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;transition:color .2s}
#theme-toggle:hover{color:var(--color-primary)}
html[data-theme="light"] .sun-icon { display: none; }
html[data-theme="dark"] .moon-icon { display: none; }
html[data-theme="dark"] .sun-icon { display: block; }

/* -- intl-tel-input fix -- */
.iti{width:100%}
.iti input[type=tel]{width:100%;padding-left:52px}

@media(max-width:768px){
  .team-profile-grid{grid-template-columns:1fr}
  .header-switchers{margin-left:0;margin-top:1rem}
}
@media(max-width:480px){
  :root { --section-py: 3rem; --gap: 1rem; }
}


/* v1.0.0 — initial layout (Oct 31, 2025) */
/* v1.2.0 — responsive fixes, dark mode (Dec 31, 2025) */
/* v2.1.4 — cookie banner, accessibility pass (Mar 2, 2026) */
