*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'DM Sans',sans-serif;background:#f9f4ef;color:#0f1923;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button{font-family:'DM Sans',sans-serif;cursor:pointer}
input,textarea,select{font-family:'DM Sans',sans-serif}
section{scroll-margin-top:68px}
:root{--navy:#0f172a;--blue:#4A6984;--slate:#d0dfe6;--taupe:#f9f4ef;--stone:#e5d8c6;--gray:#4b5563;--dark:#0f1923;--white:#fff;--gold:#c6ac82;--text:#111827;--serif:'Cormorant Garamond',serif;--sans:'DM Sans',sans-serif}
.wrap{max-width:1160px;margin:0 auto;padding:0 40px}
.sp{padding:96px 0}
.lbl{display:block;font-size:10px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:var(--blue);margin-bottom:14px}
.h1{font-family:var(--serif);font-size:clamp(2.4rem,5vw,4.2rem);font-weight:300;line-height:1.1;color:var(--navy)}
.h2{font-family:var(--serif);font-size:clamp(1.9rem,3.5vw,3rem);font-weight:300;line-height:1.15;color:var(--navy)}
.h2 em,.h1 em{font-style:italic;color:var(--blue)}
.h2.lt,.h1.lt{color:var(--white)}
.h2.lt em{color:var(--slate)}
.h3{font-family:var(--serif);font-size:clamp(1.4rem,2.5vw,2rem);font-weight:300;line-height:1.2;color:var(--navy)}
.body{font-size:15px;line-height:1.9;color:var(--text)}
.body strong{font-weight:600}
.body.lt{color:rgba(255,255,255,.82)}
.body.lt strong{color:var(--white)}
.ilink{color:var(--gold);font-weight:500;cursor:pointer;transition:all .3s;padding:2px 6px;margin:0 -2px;border-radius:4px}
.ilink:hover{background:rgba(198,172,130,.15);color:var(--navy)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;height:50px;padding:0 28px;font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;border:1.5px solid var(--navy);color:var(--navy);background:transparent;transition:background .2s,color .2s;white-space:nowrap;flex-shrink:0;-webkit-tap-highlight-color:transparent}
.btn:hover{background:var(--navy);color:var(--white)}
.btn.bb{border-color:var(--blue);color:var(--blue)}.btn.bb:hover{background:var(--blue);color:var(--white)}
.btn.bw{border-color:var(--white);color:var(--white)}.btn.bw:hover{background:var(--white);color:var(--navy)}
.btn.bf{background:var(--blue);border-color:var(--blue);color:var(--white)}.btn.bf:hover{background:var(--navy);border-color:var(--navy)}
.btn-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.div{width:40px;height:2px;background:var(--gold);display:block;margin-bottom:24px}
.img-box{overflow:hidden;width:100%;position:relative;background:var(--stone)}
.img-box img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .6s cubic-bezier(.4,0,.2,1)}
.img-box:hover img{transform:scale(1.04)}
.r43{aspect-ratio:4/3}.r34{aspect-ratio:3/4}.r169{aspect-ratio:16/9}
.rv{opacity:0;transform:translateY(20px);transition:opacity .7s cubic-bezier(.4,0,.2,1),transform .7s cubic-bezier(.4,0,.2,1)}
.rv.in{opacity:1;transform:translateY(0)}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:72px}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.g5{display:grid;grid-template-columns:repeat(5,1fr);gap:2px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--gray);font-weight:500}
.field input,.field textarea,.field select{height:50px;padding:0 16px;font-size:14px;color:var(--dark);background:var(--white);border:1.5px solid var(--stone);outline:none;transition:border-color .2s;width:100%}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--blue)}
.field textarea{height:auto;min-height:110px;padding:14px 16px;resize:none}
.tab-btn{height:50px;padding:0 24px;font-size:12px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;background:transparent;border:none;cursor:pointer;flex-shrink:0;margin-bottom:-1px;border-bottom:3px solid transparent;color:var(--gray)}
.tab-btn.active{color:var(--navy);border-bottom-color:var(--blue)}
#header{position:fixed;top:0;left:0;right:0;z-index:300;height:68px;display:flex;align-items:center;justify-content:space-between;padding:0 40px;background:rgba(249,244,239,.92);backdrop-filter:blur(16px);border-bottom:1px solid rgba(74,105,132,.07);transition:all .3s}
#header.sc{background:rgba(249,244,239,.97);border-bottom-color:rgba(74,105,132,.16);box-shadow:0 1px 24px rgba(28,46,61,.07)}
.logo-btn{background:none;border:none;padding:0;cursor:pointer;flex-shrink:0}
.nav-links{display:flex;align-items:center;gap:20px}
.nav-link{background:none;border:none;font-size:11px;font-weight:500;letter-spacing:.13em;text-transform:uppercase;color:var(--gray);cursor:pointer;padding:5px 0;transition:all .2s}
.nav-link:hover{color:var(--navy);}
.nav-tools{display:flex;align-items:center;gap:10px;margin-left:16px;flex-shrink:0}
.lang-box{display:flex;border:1px solid var(--stone);overflow:hidden;border-radius:4px;background:rgba(255,255,255,.45)}
.lang-btn{height:38px;min-width:38px;padding:0 12px;font-size:10px;font-weight:500;letter-spacing:.14em;border:none;background:transparent;color:var(--gray);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}
.lang-btn.active{background:var(--navy);color:var(--white)}
.ham-btn{display:none;background:none;border:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer}
.ham-line{display:block;height:1.5px;background:var(--navy)}
.menu-ov{position:fixed;inset:0;z-index:600;pointer-events:none;opacity:0;transition:opacity .35s}
.menu-ov.open{pointer-events:all;opacity:1}
.menu-bd{position:absolute;inset:0;background:rgba(15,25,35,.65);backdrop-filter:blur(6px)}
.menu-pn{position:absolute;top:0;right:0;width:min(360px,88vw);height:100%;background:var(--dark);transform:translateX(110%);transition:transform .42s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;border-left:1px solid rgba(74,105,132,.12)}
.menu-ov.open .menu-pn{transform:translateX(0)}
.menu-ln{display:block;width:100%;padding:16px 32px;font-family:var(--serif);font-size:1.55rem;font-weight:300;color:rgba(255,255,255,.72);background:none;border:none;border-left:3px solid transparent;text-align:left;cursor:pointer;transition:color .2s,border-color .2s,padding-left .2s}
.menu-ln:hover{color:var(--white);border-left-color:var(--blue);padding-left:40px}
.menu-lang{display:flex;border:1px solid rgba(255,255,255,.15);overflow:hidden;width:fit-content}
.menu-lang-btn{height:38px;padding:0 18px;font-size:10px;font-weight:500;border:none;background:transparent;color:rgba(255,255,255,.55);cursor:pointer;transition:all .2s}
.menu-lang-btn.active{background:var(--white);color:var(--navy)}
.wa-btn{position:fixed;bottom:28px;left:28px;z-index:200;width:50px;height:50px;border-radius:50%;background:var(--navy);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(28,46,61,.4);transition:transform .2s,opacity .28s ease,visibility .28s;text-decoration:none;flex-shrink:0}
.wa-btn:hover:not(.float-hidden){transform:scale(1.08)}
.wa-btn.float-hidden{opacity:0!important;visibility:hidden;pointer-events:none;transform:translateY(14px) scale(.94)!important}
.wa-btn svg{width:24px;height:24px;fill:var(--white);flex-shrink:0}
.cta-fl{position:fixed;bottom:28px;right:28px;z-index:200;display:none}
.cta-fl.vis{display:block}
#hero-grid{display:grid;grid-template-columns:1fr 1fr;min-height:calc(100vh - 68px)}
#hero-txt{display:flex;flex-direction:column;justify-content:center;padding:80px 64px 80px 40px;background:var(--taupe);position:relative;overflow:hidden}
#hero-wm{position:absolute;right:-20px;top:50%;transform:translateY(-50%) rotate(90deg);font-family:var(--serif);font-size:140px;font-weight:600;color:rgba(74,105,132,.04);pointer-events:none;white-space:nowrap}
#hero-img{position:relative;overflow:hidden;min-height:500px;background:var(--dark)}
#hero-img-inner{position:absolute;inset:0}
#hero-img-inner img{width:100%;height:115%;object-fit:cover;display:block}
#hero-img-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(15,25,35,.1),rgba(15,25,35,.35))}
#hero-stats{position:absolute;bottom:0;left:0;right:0;background:rgba(249,244,239,.96);backdrop-filter:blur(12px);padding:18px 28px;display:flex;justify-content:space-around;border-top:3px solid var(--gold)}
.stat-num{font-family:var(--serif);font-size:clamp(1.4rem,2.5vw,1.8rem);font-weight:600;color:var(--gold)}
.stat-lbl{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--gray);margin-top:3px}
.hero-line{width:52px;height:2px;background:var(--gold);margin-bottom:28px;animation:aline .8s cubic-bezier(.4,0,.2,1) .2s both;transform-origin:left}
.scroll-cue{position:absolute;bottom:32px;left:40px;display:flex;align-items:center;gap:12px;cursor:pointer;animation:afade 1s ease 1.2s both}
.svc{cursor:pointer;background:var(--taupe);padding:44px 32px;position:relative;overflow:hidden;height:100%;transition:background .35s}
.svc-bar{position:absolute;bottom:0;left:0;width:100%;height:3px;background:var(--blue);transform:scaleX(0);transform-origin:left;transition:transform .35s}
.svc:hover .svc-bar,.svc.open .svc-bar{transform:scaleX(1)}
.svc:hover,.svc.open{background:var(--navy)}
.svc:hover .svc-t,.svc.open .svc-t{color:var(--white)}
.svc:hover .svc-d,.svc.open .svc-d{color:rgba(255,255,255,.62)}
.svc:hover .svc-n,.svc.open .svc-n{color:rgba(208,223,230,.45)}
.svc:hover .svc-l,.svc.open .svc-l{color:var(--slate)}
.svc-x{max-height:0;overflow:hidden;transition:max-height .45s cubic-bezier(.4,0,.2,1)}
.svc-x.open{max-height:300px}
.step-c{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);padding:28px 22px 36px;cursor:pointer;position:relative;transition:background .35s,border-color .35s}
.step-c:hover,.step-c.open{background:rgba(74,105,132,.2);border-color:rgba(74,105,132,.35)}
.step-x{max-height:0;overflow:hidden;transition:max-height .45s cubic-bezier(.4,0,.2,1)}
.step-x.open{max-height:200px}
.step-bar{position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--gold);opacity:.2;transition:opacity .3s}
.step-c.open .step-bar{opacity:1}
.step-plus{position:absolute;bottom:10px;right:14px;font-size:16px;color:var(--blue);transition:transform .2s}
.step-c.open .step-plus{transform:rotate(45deg)}
.tl-c{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);padding:26px 18px 30px;cursor:pointer;position:relative;transition:background .35s}
.tl-c:hover,.tl-c.open{background:rgba(74,105,132,.18)}
.tl-x{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1)}
.tl-x.open{max-height:140px}
.tl-plus{position:absolute;bottom:10px;right:14px;font-size:16px;color:var(--blue);transition:transform .2s}
.tl-c.open .tl-plus{transform:rotate(45deg)}
.gal-item{position:relative;overflow:hidden;cursor:pointer}
.gal-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.gal-item:hover img{transform:scale(1.06)}
.gal-ov{position:absolute;inset:0;background:rgba(28,46,61,.72);display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;transition:opacity .35s}
.gal-item:hover .gal-ov{opacity:1}
.gal-ov-lbl{color:var(--white);font-size:11px;letter-spacing:.15em;text-transform:uppercase}
.gal-ov-icon{color:var(--blue);font-size:22px;margin-top:8px}
.cas-card{background:var(--white);overflow:hidden;transition:box-shadow .3s}
.cas-card:hover{box-shadow:0 4px 24px rgba(28,46,61,.1)}
#lightbox{position:fixed;inset:0;z-index:800;background:rgba(0,0,0,.93);display:none;align-items:center;justify-content:center}
#lightbox.vis{display:flex}
#lightbox img{max-width:92vw;max-height:88vh;object-fit:contain}
#lb-close{position:absolute;top:20px;right:24px;background:none;border:none;color:var(--white);font-size:32px;cursor:pointer;line-height:1;z-index:1}
#lb-caption{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.85);font-size:12px;letter-spacing:.12em;text-transform:uppercase;text-align:center;max-width:90vw;padding:0 16px}
.logo-lm{display:block}
.logo-dm{display:none}
[data-theme="dark"] .logo-lm{display:none}
[data-theme="dark"] .logo-dm{display:block}
.cv-drop:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
.pt-wrap{overflow:hidden;mask-image:linear-gradient(to right,transparent,black 8%,black 92%,transparent);-webkit-mask-image:linear-gradient(to right,transparent,black 8%,black 92%,transparent)}
.pt-trk{display:flex;gap:48px;align-items:center;animation:scrolll 28s linear infinite;width:max-content}
.pt-trk:hover{animation-play-state:paused}
.pt-item{flex-shrink:0;padding:10px 24px;border:1px solid var(--stone);color:var(--text);font-size:12px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;transition:all .2s}
.pt-item:hover{border-color:var(--blue);color:var(--navy)}
.dist{background:var(--taupe);padding:32px 22px;border-top:3px solid var(--stone);cursor:pointer;transition:all .35s;height:100%}
.dist:hover,.dist.open{background:var(--navy);border-top-color:var(--blue)}
.dist:hover .dist-t,.dist.open .dist-t{color:var(--white)}
.dist:hover .dist-ico,.dist.open .dist-ico{border-color:rgba(198,172,130,.42);color:var(--gold);background:rgba(198,172,130,.1)}
.dist .acc-num{margin-bottom:8px}
.dist-ico{width:38px;height:38px;border-radius:50%;border:1px solid rgba(74,105,132,.22);background:rgba(74,105,132,.06);color:var(--blue);flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:4px;transition:border-color .35s,color .35s,background .35s}
.dist-x{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1)}
.dist-x.open{max-height:120px}
.success-box{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:320px;gap:16px;text-align:center}
.footer-link{background:none;border:none;cursor:pointer;font-size:13px;color:rgba(255,255,255,.52);padding:0;text-align:left;font-family:var(--sans);display:block;margin-bottom:11px;transition:color .2s}
.footer-link:hover{color:var(--white)}
.footer-link-inline{display:inline;margin-bottom:0;margin-right:0;font-size:11px;letter-spacing:.04em}
.footer-bar-links .footer-link-inline{margin-right:18px}
.footer-bar-links .footer-link-inline:last-child{margin-right:0}
a.footer-link{text-decoration:none}
.social-row{display:flex;gap:10px;margin-bottom:20px}
.footer-social{margin-bottom:0}
.social-btn{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.55);text-decoration:none;transition:border-color .2s,color .2s,background .2s;flex-shrink:0;border-radius:4px}
.social-btn svg{width:18px;height:18px;display:block;fill:currentColor}
.social-btn:hover{border-color:var(--gold);color:var(--white);background:rgba(255,255,255,.04)}
.site-footer{background:var(--dark);padding:52px 0 28px;margin-top:0}
.footer-main{display:grid;grid-template-columns:minmax(220px,1.35fr) 1fr 1fr;gap:40px 44px;margin-bottom:36px;align-items:start}
.footer-logo{height:56px;width:auto;display:block;margin-bottom:18px}
.footer-tagline{margin-bottom:22px;max-width:400px;line-height:1.85}
.footer-col .footer-section-title{margin-bottom:16px;color:rgba(198,172,130,.65)}
.footer-contact-line{display:block;font-size:13px;color:rgba(255,255,255,.78);margin-bottom:12px;text-decoration:none;transition:color .2s;line-height:1.55}
.footer-contact-line:hover{color:var(--white)}
.footer-contact-label{display:block;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.38);margin-bottom:5px;font-weight:500}
.footer-contact-map .footer-contact-label{margin-bottom:6px}
.footer-bar{border-top:1px solid rgba(255,255,255,.09);padding-top:22px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.footer-copy-line{font-size:12px;color:rgba(255,255,255,.48);margin:0;line-height:1.5}
@keyframes aup{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes afade{from{opacity:0}to{opacity:1}}
@keyframes aline{from{transform:scaleX(0)}to{transform:scaleX(1)}}
@keyframes scrolll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.a1{animation:aup .8s cubic-bezier(.4,0,.2,1) .2s both}
.a2{animation:aup .8s cubic-bezier(.4,0,.2,1) .4s both}
.a3{animation:aup .8s cubic-bezier(.4,0,.2,1) .55s both}
.a4{animation:aup .8s cubic-bezier(.4,0,.2,1) .7s both}
@media(max-width:1024px){.nav-links{display:none!important}.ham-btn{display:flex!important}.g5{grid-template-columns:1fr 1fr 1fr}}
@media(max-width:640px){.wrap{padding:0 20px}.sp{padding:64px 0}#hero-grid{grid-template-columns:1fr}#hero-img{min-height:260px;order:-1}#hero-img-inner img{height:100%}#hero-txt{padding:44px 20px 48px}#hero-wm,.scroll-cue{display:none}.h1{font-size:2.1rem!important}.h2{font-size:1.75rem!important}.btn{height:50px;padding:0 20px}.btn-row .btn{width:100%;justify-content:center}.g2{grid-template-columns:1fr!important;gap:36px!important}.g3{grid-template-columns:1fr!important}.g5{grid-template-columns:1fr 1fr!important}.cas-card>div:first-child{grid-template-columns:1fr!important}.cg{grid-template-columns:1fr!important;gap:44px!important}.footer-main{grid-template-columns:1fr!important;gap:32px!important}.footer-bar{flex-direction:column;align-items:flex-start}.wa-btn{bottom:20px;left:16px;width:48px;height:48px}.cta-fl{bottom:20px;right:16px}#hero-stats{padding:14px 16px}#contact-form-grid{grid-template-columns:1fr!important}}
@media(min-width:641px) and (max-width:900px){.wrap{padding:0 28px}.sp{padding:80px 0}#hero-grid{grid-template-columns:1fr 1fr}#hero-img{min-height:400px}.g3{grid-template-columns:1fr 1fr}.g5{grid-template-columns:1fr 1fr 1fr}.cg{grid-template-columns:1fr!important;gap:44px!important}.footer-main{grid-template-columns:1fr 1fr;gap:28px 36px}.footer-brand{grid-column:1/-1}}
@media(max-width:380px){.g5{grid-template-columns:1fr!important}}


/* ═══ DARK / LIGHT MODE ═══ */
.theme-btn{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--stone);border-radius:4px;background:rgba(255,255,255,.45);cursor:pointer;transition:all .25s;flex-shrink:0;position:relative;overflow:hidden}
.nav-links .nav-cta{height:38px!important;min-height:38px;padding:0 22px!important;font-size:10px!important;font-weight:500!important;letter-spacing:.14em!important;border-radius:4px!important;border-width:1px!important;line-height:1!important}
.theme-btn:hover{border-color:var(--blue);background:rgba(74,105,132,.08)}
.theme-icon{font-size:15px;line-height:1;transition:transform .3s,opacity .3s;display:block;color:var(--gray)}
.theme-icon-moon{position:absolute;opacity:0;transform:translateY(14px)}
[data-theme="dark"] .theme-icon-sun{opacity:0;transform:translateY(-14px)}
[data-theme="dark"] .theme-icon-moon{opacity:1;transform:translateY(0)}
[data-theme="dark"] .theme-btn{border-color:rgba(198,172,130,.35);background:rgba(198,172,130,.06)}
[data-theme="dark"] .theme-btn:hover{border-color:var(--gold);background:rgba(198,172,130,.12)}
[data-theme="dark"] .theme-icon{color:var(--gold)}

/* Dark vars */
[data-theme="dark"]{
  --taupe:#0e1820;
  --white:#132030;
  --stone:#1e3044;
  --dark:#07101a;
  --text:#f1f5f9;
  --gray:#cbd5e1;
}
[data-theme="dark"] body{background:#0e1820;color:#b0c8dc}

/* Header */
[data-theme="dark"] #header{background:rgba(7,16,26,.94);border-bottom-color:rgba(74,105,132,.14)}
[data-theme="dark"] #header.sc{background:rgba(7,16,26,.98);box-shadow:0 1px 24px rgba(0,0,0,.4)}
[data-theme="dark"] .ham-line{background:var(--slate)}
[data-theme="dark"] .theme-btn{border-color:#1e3044}
[data-theme="dark"] .theme-btn:hover{border-color:var(--blue)}

/* Typography */
[data-theme="dark"] .h1,[data-theme="dark"] .h2,[data-theme="dark"] .h3{color:#c5dcea}
[data-theme="dark"] .h2 em,[data-theme="dark"] .h1 em{color:#f1f5f9}
[data-theme="dark"] .h2.lt,[data-theme="dark"] .h1.lt{color:#e8f4fa}
[data-theme="dark"] .h2.lt em{color:var(--slate)}
[data-theme="dark"] .body{color:var(--text)}
[data-theme="dark"] .lbl{color:#4A6984}
[data-theme="dark"] .nav-link{color:rgba(176,200,220,.55)}
[data-theme="dark"] .nav-link:hover{color:var(--slate);}

/* Buttons */
[data-theme="dark"] .btn{border-color:rgba(176,200,220,.35);color:rgba(176,200,220,.8)}
[data-theme="dark"] .btn:hover{background:rgba(176,200,220,.12);color:var(--slate);border-color:var(--slate)}
[data-theme="dark"] .btn.bb{border-color:var(--blue);color:var(--blue)}
[data-theme="dark"] .btn.bb:hover{background:var(--blue);color:#07101a}
[data-theme="dark"] .btn.bw{border-color:rgba(255,255,255,.25);color:rgba(255,255,255,.8)}
[data-theme="dark"] .btn.bw:hover{background:rgba(255,255,255,.1);color:white}
[data-theme="dark"] .btn.bf{background:var(--blue);border-color:var(--blue);color:white}
[data-theme="dark"] .btn.bf:hover{background:#2a7aaa;border-color:#2a7aaa}
[data-theme="dark"] .lang-btn{color:rgba(176,200,220,.5)}
[data-theme="dark"] .lang-btn.active{background:var(--blue);color:white}
[data-theme="dark"] .lang-box{border-color:#1e3044;background:rgba(19,32,48,.45)}
[data-theme="dark"] .nav-tools .theme-btn{border-color:#1e3044;background:rgba(19,32,48,.45)}
[data-theme="dark"] .nav-tools .theme-btn:hover{border-color:var(--blue);background:rgba(74,105,132,.14)}

/* Sections */
[data-theme="dark"] .ilink{color:var(--gold)}
[data-theme="dark"] .ilink:hover{background:rgba(198,172,130,.2);color:#fff}

/* Hero */
[data-theme="dark"] #hero-txt{background:#0a161f}
[data-theme="dark"] #hero-stats{background:rgba(7,16,26,.94)}

/* Atelier items */
[data-theme="dark"] .img-box{background:#1e3044}

/* Savoir-faire cards */
[data-theme="dark"] .svc{background:#0e1820}
[data-theme="dark"] .svc:hover,[data-theme="dark"] .svc.open{background:#07101a}
[data-theme="dark"] .svc-t{color:#c5dcea!important}
[data-theme="dark"] .svc-d{color:var(--text)!important}

/* Gallery */
[data-theme="dark"] .gal-item{background:#1e3044}
[data-theme="dark"] .cas-card{background:#132030!important;border:1px solid #1e3044}
[data-theme="dark"] .cas-card>div:last-child{border-top-color:#1e3044}

/* Ce qui nous distingue */
[data-theme="dark"] .dist{background:#0e1820;border-top-color:#1e3044}
[data-theme="dark"] .dist:hover,[data-theme="dark"] .dist.open{background:#07101a;border-top-color:var(--blue)}
[data-theme="dark"] .dist-t{color:#c5dcea!important}
[data-theme="dark"] .dist-ico{border-color:rgba(74,105,132,.4);background:rgba(74,105,132,.12);color:#9ebccf}

/* Partenaires */
[data-theme="dark"] .pt-item{border-color:#1e3044;color:var(--text)}
[data-theme="dark"] .pt-item:hover{border-color:var(--blue);color:var(--slate)}

/* Contact section */
[data-theme="dark"] .tab-btn{color:rgba(176,200,220,.45)}
[data-theme="dark"] .tab-btn.active{color:#c5dcea;}
[data-theme="dark"] .field input,[data-theme="dark"] .field textarea,[data-theme="dark"] .field select{
  background:#1e3044;border-color:#2a4458;color:#c5dcea
}
[data-theme="dark"] .field input::placeholder,[data-theme="dark"] .field textarea::placeholder{color:#4a6a80}
[data-theme="dark"] .field input:focus,[data-theme="dark"] .field textarea:focus,[data-theme="dark"] .field select:focus{border-color:var(--blue)}
[data-theme="dark"] .field label{color:#6a8aa0}

/* CV upload zone */
[data-theme="dark"] .cv-drop{background:#1e3044!important;border-color:#2a4458!important}

/* Horaires */
[data-theme="dark"] [style*="background:var(--stone)"]{background:#1e3044!important}

/* Footer links */
[data-theme="dark"] .footer-link{color:rgba(176,200,220,.48)}
[data-theme="dark"] .footer-link:hover{color:#e8f4fa}
[data-theme="dark"] .footer-copy-line{color:rgba(176,200,220,.42)}

/* Scroll cue */
[data-theme="dark"] .scroll-cue span{color:rgba(176,200,220,.4)}

/* Menu slide-in — same dark, tweak slightly */
[data-theme="dark"] .menu-pn{background:#07101a}

/* Success box */
[data-theme="dark"] .success-box .h3{color:#c5dcea}
[data-theme="dark"] .success-box .body{color:var(--text)}

/* ═══ EXTRACTED COMPONENT CLASSES ═══ */

/* Feature icon box (Atelier, Contact) */
.icon-box{width:46px;height:46px;background:var(--navy);color:white;flex-shrink:0;display:flex;align-items:center;justify-content:center}

/* Feature row (icon + text) */
.feature-row{display:flex;gap:18px;align-items:flex-start}

/* Feature title */
.feature-title{font-family:var(--serif);font-size:1.1rem;font-weight:500;color:var(--navy);margin-bottom:6px}

/* Feature description */
.feature-desc{font-size:13px;color:var(--text);line-height:1.78}

/* Section with dark bg */
.section-dark{background:var(--dark);position:relative;overflow:hidden}

/* Section header (label + h2) centered */
.section-header-center{max-width:560px;margin:0 auto 52px;text-align:center}

/* Timeline / Accordion number */
.acc-num{font-family:var(--serif);font-size:2.4rem;color:rgba(198,172,130,.25);margin-bottom:14px;transition:color .3s}

/* Step number (large) */
.step-num{font-family:var(--serif);font-size:2.6rem;font-weight:600;color:rgba(198,172,130,.45);line-height:1;transition:color .3s}

/* SVG icon circle (timeline) */
.svg-icon-circle{width:40px;height:40px;border-radius:50%;margin-bottom:14px;border:1px solid rgba(74,105,132,.3);background:rgba(74,105,132,.05);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--gold)}

/* Contact info block */
.contact-info-row{display:flex;gap:16px;align-items:flex-start;margin-bottom:20px;text-decoration:none}

/* Contact info label */
.contact-label{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--gray);margin-bottom:3px}

/* Gallery image label badge */
.badge-avant{position:absolute;top:14px;left:14px;background:rgba(28,46,61,.82);padding:5px 12px}
.badge-apres{position:absolute;top:14px;left:14px;background:rgba(198,172,130,.9);padding:5px 12px}
.badge-text{font-size:9px;font-weight:600;letter-spacing:.18em;text-transform:uppercase}
.badge-text-light{color:rgba(255,255,255,.7)}
.badge-text-dark{color:var(--navy)}

/* Cas clinique image box */
.cas-img{height:100%;min-height:280px;background:var(--stone);overflow:hidden;cursor:pointer}
.cas-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}

/* Candidature job item */
.job-item{display:flex;gap:14px;align-items:flex-start;padding:12px 14px;background:var(--stone);margin-bottom:8px;transition:background .2s}
.job-item:hover{background:var(--navy)}
.job-title{font-size:13px;font-weight:500;color:var(--navy)}
.job-sub{font-size:12px;color:var(--gray);margin-top:2px}

/* Footer section title */
.footer-section-title{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:#4A6984;margin-bottom:14px}

/* Decorative circle */
.deco-circle{position:absolute;width:380px;height:380px;border:1px solid rgba(74,105,132,.08);border-radius:50%;pointer-events:none}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .pt-trk{animation:none!important}
  .rv{opacity:1;transform:none}
  .a1,.a2,.a3,.a4{animation:none!important}
  .hero-line,.scroll-cue{animation:none!important}
}


/* Accessible clickable elements */
[role="button"]{cursor:pointer;-webkit-tap-highlight-color:transparent}
[role="button"]:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
