:root {
--c:       #0C0F14;
--c2:      #141820;
--c3:      #1D2330;
--or:      #D4A843;
--or2:     #E8C26A;
--or-bg:   rgba(212,168,67,.08);
--or-brd:  rgba(212,168,67,.22);
--w:       #FFFFFF;
--snow:    #F7F8FA;
--snow2:   #EEF0F5;
--txt:     #2E3545;
--txt2:    #5C6478;
--brd:     #E0E4EE;
--brd2:    #CBD1E0;
--d-brd:   rgba(255,255,255,.07);
--d-txt:   rgba(255,255,255,.55);
--d-txt2:  rgba(255,255,255,.78);
--grn:     #10B981;
--red:     #EF4444;
--r:  8px;
--r2: 16px;
--r3: 24px;
--sh: 0 8px 40px rgba(12,15,20,.10);
--sh2:0 24px 80px rgba(12,15,20,.18);
--e:  cubic-bezier(.22,1,.36,1);
--e2: cubic-bezier(.4,0,.2,1);
--d:  .38s;
--df: .18s;
--sec: 96px;
}
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
font-family:'DM Sans',sans-serif;
font-size:16px; font-weight:400;
color:var(--txt); background:#fff;
line-height:1.72; overflow-x:hidden;
-webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4 {
font-family:'Cormorant Garamond',serif;
line-height:1.1; color:var(--c);
}
h1 { font-size:clamp(2.2rem,5.5vw,3.8rem); font-weight:700; letter-spacing:-.02em; }
h2 { font-size:clamp(1.6rem,3.5vw,2.4rem); font-weight:700; letter-spacing:-.02em; }
h3 { font-size:1.1rem; font-weight:600; font-family:'DM Sans',sans-serif; }
p  { color:var(--txt2); line-height:1.8; }
a  { color:var(--or); text-decoration:none; transition:color var(--df) var(--e2); }
a:hover { color:var(--or2); }
img { max-width:100%; height:auto; display:block; }
ul { list-style:none; }
strong { color:var(--c); font-weight:600; }
.wrap  { max-width:1200px; margin:0 auto; padding:0 32px; }
.sec   { padding:var(--sec) 0; }
.sec-lt { background:var(--snow); }
.eyebrow {
display:inline-flex; align-items:center; gap:8px;
font-family:'DM Sans',sans-serif; font-size:.68rem;
font-weight:700; letter-spacing:.14em; text-transform:uppercase;
color:var(--or); background:var(--or-bg); border:1px solid var(--or-brd);
padding:5px 14px; border-radius:20px; margin-bottom:16px;
}
.eyebrow-dark { color:rgba(255,255,255,.5); background:rgba(255,255,255,.05); border-color:rgba(255,255,255,.1); }
.topbar {
background:var(--c); color:rgba(255,255,255,.72);
font-size:.76rem; padding:9px 0; text-align:center;
font-family:'DM Sans',sans-serif; position:relative; z-index:200;
}
.topbar strong { color:var(--w); }
.topbar a { color:var(--or); font-weight:600; }
.topbar a:hover { color:var(--or2); }
.hdr {
background:rgba(255,255,255,.97);
backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
border-bottom:1px solid var(--brd);
position:sticky; top:0; z-index:180;
transition:box-shadow .3s var(--e2), border-color .3s;
}
.hdr.up { box-shadow:0 4px 28px rgba(12,15,20,.09); border-color:transparent; }
.nav-row {
display:flex; align-items:center; justify-content:space-between;
height:70px; gap:12px;
}
.logo {
font-family:'Cormorant Garamond',serif;
font-size:1.22rem; font-weight:700; color:var(--c);
letter-spacing:-.01em; flex-shrink:0; text-decoration:none;
white-space:nowrap;
}
.logo em { font-style:normal; color:var(--or); }
.nav-items { display:flex; align-items:center; gap:2px; }
.nav-items a {
padding:7px 12px; border-radius:var(--r);
font-size:.84rem; font-weight:500; color:var(--txt);
transition:background var(--df), color var(--df);
text-decoration:none; white-space:nowrap;
}
.nav-items a:hover { background:var(--snow2); color:var(--c); }
.nav-items a.cur { color:var(--or); background:var(--or-bg); }
.nav-btn {
background:var(--c) !important; color:#fff !important;
padding:10px 22px !important; border-radius:var(--r) !important;
font-weight:700 !important; font-size:.84rem !important;
box-shadow:0 4px 18px rgba(12,15,20,.25) !important;
transition:background .22s, transform .22s, box-shadow .22s !important;
}
.nav-btn:hover {
background:var(--c3) !important; color:#fff !important;
transform:translateY(-1px) !important;
box-shadow:0 8px 28px rgba(12,15,20,.35) !important;
}
.brg { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:5px; border:none; background:none; }
.brg span { display:block; width:22px; height:2px; background:var(--c); border-radius:2px; transition:.3s; }
.hero { min-height:100vh; position:relative; display:flex; align-items:center; overflow:hidden; background:var(--c); }
.slides { position:absolute; inset:0; z-index:0; }
.slide  { position:absolute; inset:0; opacity:0; transition:opacity 1.6s ease; }
.slide.on { opacity:1; }
.slide img { width:100%; height:100%; object-fit:cover; animation:kbz 10s var(--e) forwards; will-change:transform; }
@keyframes kbz { from{transform:scale(1.08) translateX(6px)} to{transform:scale(1)} }
.hero-ov {
position:absolute; inset:0; z-index:1;
background:
linear-gradient(105deg,rgba(12,15,20,.92) 0%,rgba(12,15,20,.68) 50%,rgba(12,15,20,.2) 100%),
linear-gradient(to top,rgba(12,15,20,.82) 0%,transparent 45%);
}
.hero-grain {
position:absolute; inset:0; z-index:2; pointer-events:none; opacity:.025;
background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.78' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='400' height='400' filter='url(%23g)'/%3E%3C/svg%3E") center/400px;
}
.hero-or-line {
position:absolute; top:0; left:0; bottom:0; width:5px; z-index:3;
background:linear-gradient(to bottom,transparent,var(--or) 25%,var(--or) 75%,transparent);
opacity:.8;
}
.hero-body { position:relative; z-index:4; padding:120px 0 100px; max-width:720px; }
.hero-tag {
display:inline-flex; align-items:center; gap:9px;
margin-bottom:28px; animation:slR .7s .05s both;will-change:transform,opacity;
}
.hero-tag-line { width:28px; height:2px; background:var(--or); border-radius:2px; flex-shrink:0; }
.hero-tag span { font-size:.7rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--or); }
.live { width:7px; height:7px; border-radius:50%; background:var(--grn); animation:pulse 2s infinite; }
@keyframes pulse { 0%{box-shadow:0 0 0 0 rgba(16,185,129,.4)} 70%{box-shadow:0 0 0 8px rgba(16,185,129,0)} 100%{box-shadow:0 0 0 0 rgba(16,185,129,0)} }
.hero h1 { color:#fff; margin-bottom:22px; animation:slR .7s .12s both;will-change:transform,opacity; text-shadow:0 2px 24px rgba(0,0,0,.3); }
.hero h1 .ghost { display:block; -webkit-text-stroke:1.5px rgba(255,255,255,.3); color:transparent; font-style:italic; }
.hero h1 .solid { display:block; }
.hero h1 .gold  { color:var(--or); }
.hero-lead { color:rgba(255,255,255,.65); font-size:1.06rem; line-height:1.82; max-width:550px; margin-bottom:40px; animation:slR .7s .22s both; }
.hero-lead strong { color:rgba(255,255,255,.88); font-weight:600; }
.hero-ctas { display:flex; gap:14px; flex-wrap:wrap; animation:slR .7s .32s both; }
.hero-trust { display:flex; gap:24px; flex-wrap:wrap; margin-top:44px; padding-top:28px; border-top:1px solid rgba(255,255,255,.08); animation:slR .7s .42s both; }
.tbadge { display:flex; align-items:center; gap:8px; color:rgba(255,255,255,.5); font-size:.79rem; font-weight:500; }
.tbadge-ico { width:30px; height:30px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:.95rem; flex-shrink:0; }
.hero-dots { position:absolute; bottom:38px; left:50%; transform:translateX(-50%); z-index:5; display:flex; gap:8px; align-items:center; }
.hdot { height:3px; border-radius:2px; background:rgba(255,255,255,.22); cursor:pointer; transition:.4s var(--e); width:18px; }
.hdot.on { width:36px; background:var(--or); }
.scrollhint { position:absolute; right:44px; bottom:36px; z-index:5; display:flex; flex-direction:column; align-items:center; gap:7px; color:rgba(255,255,255,.28); font-size:.64rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; animation:fadein 1s 2s both; }
.sh-track { width:1px; height:48px; background:rgba(255,255,255,.12); overflow:hidden; position:relative; }
.sh-fill  { position:absolute; top:-60%; width:100%; height:60%; background:var(--or); animation:sfill 2.4s ease-in-out infinite; }
@keyframes sfill { from{top:-60%} to{top:110%} }
@keyframes slR { from{opacity:0;transform:translateX(-26px)} to{opacity:1;transform:none} }
@keyframes fadein { from{opacity:0} to{opacity:1} }
.btn {
display:inline-flex; align-items:center; gap:9px;
padding:15px 30px; border-radius:var(--r);
font-family:'DM Sans',sans-serif; font-weight:700; font-size:.91rem;
cursor:pointer; border:2px solid transparent;
transition:all .24s var(--e); text-decoration:none; white-space:nowrap;
}
.btn .a { transition:transform .2s var(--e); }
.btn:hover .a { transform:translateX(4px); }
.btn-or {
background:var(--or); color:var(--c); border-color:var(--or);
box-shadow:0 6px 24px rgba(212,168,67,.3);
position:relative; overflow:hidden;
animation:btnPulse 2.8s ease-in-out infinite;
}
.btn-or::after {
content:''; position:absolute; top:0; left:-100%;
width:55%; height:100%;
background:linear-gradient(120deg,transparent,rgba(255,255,255,.4),transparent);
animation:btnShine 2.8s ease-in-out infinite;
}
.btn-or:hover { background:var(--or2); border-color:var(--or2); color:var(--c); transform:translateY(-2px); box-shadow:0 12px 40px rgba(212,168,67,.55); animation:none; }
.btn-or:hover::after { animation:none; }
@keyframes btnPulse { 0%,100%{box-shadow:0 6px 24px rgba(212,168,67,.3)} 50%{box-shadow:0 6px 32px rgba(212,168,67,.7),0 0 0 5px rgba(212,168,67,.15)} }
@keyframes btnShine { 0%{left:-100%} 50%,100%{left:150%} }
.btn-or:hover { background:var(--or2); border-color:var(--or2); color:var(--c); transform:translateY(-2px); box-shadow:0 12px 40px rgba(212,168,67,.42); }
.btn-ghost-w { background:transparent; color:rgba(255,255,255,.78); border-color:rgba(255,255,255,.2); }
.btn-ghost-w:hover { border-color:rgba(255,255,255,.6); color:#fff; background:rgba(255,255,255,.07); }
.btn-dark { background:var(--c); color:#fff; border-color:var(--c); box-shadow:0 4px 18px rgba(12,15,20,.2); }
.btn-dark:hover { background:var(--c3); color:#fff; transform:translateY(-1px); box-shadow:0 8px 28px rgba(12,15,20,.3); }
.btn-outline { background:transparent; color:#fff; border-color:rgba(255,255,255,.5); }
.btn-outline:hover { border-color:var(--or); color:var(--or); background:rgba(212,168,67,.1); }
.kpis { background:var(--c2); border-bottom:1px solid var(--d-brd); }
.kpis-row { display:grid; grid-template-columns:repeat(4,1fr); border-left:1px solid var(--d-brd); }
.kpi { padding:32px 24px; border-right:1px solid var(--d-brd); position:relative; transition:background .3s; cursor:default; }
.kpi:hover { background:rgba(255,255,255,.03); }
.kpi::after { content:''; position:absolute; bottom:0; left:0; right:0; height:2px; background:var(--or); transform:scaleX(0); transition:transform .4s var(--e); }
.kpi:hover::after { transform:scaleX(1); }
.kpi-n { font-family:'Cormorant Garamond',serif; font-size:2.6rem; font-weight:700; color:#fff; letter-spacing:-.03em; line-height:1; margin-bottom:5px; }
.kpi-n sup { font-size:1.1rem; color:var(--or); vertical-align:super; font-family:'DM Sans',sans-serif; font-weight:700; }
.kpi-l { font-size:.77rem; color:rgba(255,255,255,.72); font-weight:500; }
.sec-hd { display:grid; grid-template-columns:1fr auto; align-items:end; gap:24px; margin-bottom:52px; }
.sec-hd-txt h2 { margin-top:8px; }
.sec-hd-txt p { margin-top:12px; font-size:.95rem; max-width:560px; }
.sec-hd-center { text-align:center; max-width:580px; margin:0 auto 56px; }
.sec-hd-center h2 { margin-top:8px; }
.sec-hd-center p { margin-top:14px; }
.svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.svc { border:1.5px solid var(--brd); border-radius:var(--r3); overflow:hidden; text-decoration:none; color:inherit; background:#fff; display:flex; flex-direction:column; transition:all .35s var(--e); }
.svc:hover { border-color:var(--or); box-shadow:0 20px 60px rgba(212,168,67,.12); transform:translateY(-5px); }
.svc-pic { height:210px; overflow:hidden; position:relative; }
.svc-pic img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--e); }
.svc:hover .svc-pic img { transform:scale(1.05); }
.svc-ov { position:absolute; inset:0; background:linear-gradient(to top,rgba(12,15,20,.6) 0%,transparent 55%); }
.svc-chip { position:absolute; top:14px; left:14px; background:rgba(255,255,255,.92); backdrop-filter:blur(8px); color:var(--c); font-size:.65rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; padding:4px 10px; border-radius:20px; }
.svc-body { padding:28px; flex:1; display:flex; flex-direction:column; }
.svc-body h3 { font-size:1.05rem; color:var(--c); margin-bottom:10px; font-family:'Cormorant Garamond',serif; font-size:1.2rem; font-weight:700; }
.svc-body p { font-size:.87rem; line-height:1.72; flex:1; }
.svc-ft { display:flex; align-items:center; justify-content:space-between; padding-top:18px; margin-top:18px; border-top:1px solid var(--brd); }
.svc-lnk { font-size:.81rem; font-weight:700; color:var(--or); display:flex; align-items:center; gap:5px; transition:gap .22s; }
.svc:hover .svc-lnk { gap:9px; }
.svc-badge { font-size:.68rem; font-weight:700; color:var(--txt2); background:var(--snow2); padding:3px 9px; border-radius:4px; }
.about { background:var(--c); padding:var(--sec) 0; position:relative; overflow:hidden; }
.about::before { content:''; position:absolute; inset:0; pointer-events:none; background:radial-gradient(ellipse 80% 60% at 10% 50%,rgba(212,168,67,.06) 0%,transparent 55%),radial-gradient(ellipse 60% 80% at 90% 20%,rgba(212,168,67,.04) 0%,transparent 50%); }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; position:relative; z-index:1; }
.about-imgs { position:relative; height:520px; }
.ai-main { position:absolute; top:0; left:0; width:80%; height:420px; object-fit:cover; border-radius:var(--r3); box-shadow:0 32px 80px rgba(0,0,0,.5); }
.ai-sec  { position:absolute; bottom:0; right:0; width:54%; height:240px; object-fit:cover; border-radius:var(--r2); box-shadow:0 20px 60px rgba(0,0,0,.5); border:4px solid var(--c); }
.ai-card { position:absolute; bottom:72px; left:62%; background:var(--or); border-radius:var(--r2); padding:18px 22px; text-align:center; box-shadow:0 12px 48px rgba(212,168,67,.5); z-index:2; }
.ai-card .big { font-family:'Cormorant Garamond',serif; font-size:2.6rem; font-weight:700; color:var(--c); line-height:1; }
.ai-card .sm  { font-size:.7rem; color:rgba(12,15,20,.7); font-weight:700; text-transform:uppercase; letter-spacing:.07em; margin-top:4px; }
.about-txt h2 { color:#fff; margin:8px 0 20px; }
.about-txt > p { color:var(--d-txt); font-size:.96rem; margin-bottom:14px; line-height:1.84; }
.feats { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin:28px 0 36px; }
.feat { display:flex; align-items:flex-start; gap:12px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.07); border-radius:var(--r2); padding:16px 14px; transition:background .3s; }
.feat:hover { background:rgba(255,255,255,.07); }
.feat-ic { width:34px; height:34px; border-radius:8px; background:var(--or-bg); border:1px solid var(--or-brd); display:flex; align-items:center; justify-content:center; font-size:1rem; flex-shrink:0; }
.feat h4 { font-family:'DM Sans',sans-serif; font-size:.85rem; font-weight:700; color:var(--d-txt2); margin-bottom:3px; }
.feat p  { font-size:.76rem; color:var(--d-txt); line-height:1.6; }
.trust-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:52px; }
.trust-item { background:#fff; border:1.5px solid var(--brd); border-radius:var(--r2); padding:28px 22px; text-align:center; transition:all .3s var(--e); }
.trust-item:hover { border-color:var(--or); box-shadow:0 12px 40px rgba(212,168,67,.1); transform:translateY(-3px); }
.trust-ico { font-size:2rem; margin-bottom:12px; }
.trust-item h3 { font-size:.95rem; margin-bottom:8px; color:var(--c); font-family:'DM Sans',sans-serif; font-weight:700; }
.trust-item p { font-size:.83rem; }
.proc-grid { display:grid; grid-template-columns:repeat(4,1fr); margin-top:56px; position:relative; }
.proc-grid::before { content:''; position:absolute; top:26px; left:12.5%; right:12.5%; height:1.5px; background:linear-gradient(to right,var(--or),rgba(212,168,67,.3),var(--brd)); }
.proc-step { display:flex; flex-direction:column; align-items:center; text-align:center; padding:0 14px; }
.pn { width:52px; height:52px; border-radius:50%; background:#fff; border:2px solid var(--brd); display:flex; align-items:center; justify-content:center; font-family:'Cormorant Garamond',serif; font-size:1.2rem; font-weight:700; color:var(--or); position:relative; z-index:1; margin-bottom:20px; transition:all .3s var(--e); }
.proc-step:hover .pn { background:var(--or); border-color:var(--or); color:var(--c); box-shadow:0 6px 24px rgba(212,168,67,.35); }
.proc-step h3 { font-size:.94rem; margin-bottom:8px; color:var(--c); }
.proc-step p  { font-size:.83rem; }
.avis-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:52px; }
.avis { background:#fff; border:1.5px solid var(--brd); border-radius:var(--r2); padding:32px; position:relative; transition:all .3s var(--e); overflow:hidden; }
.avis::before { content:'"'; position:absolute; top:10px; right:22px; font-family:'Cormorant Garamond',serif; font-size:6rem; font-weight:700; color:var(--or); opacity:.08; line-height:.7; pointer-events:none; }
.avis:hover { border-color:var(--or); box-shadow:0 16px 52px rgba(212,168,67,.1); transform:translateY(-2px); }
.avis-stars { color:var(--or); letter-spacing:2px; font-size:.95rem; margin-bottom:16px; }
.avis-txt { font-size:.9rem; font-style:italic; color:var(--txt); line-height:1.82; margin-bottom:20px; }
.avis-bar  { width:24px; height:2.5px; background:var(--or); border-radius:2px; margin-bottom:14px; }
.avis-nom  { font-weight:700; font-size:.88rem; color:var(--c); }
.avis-role { font-size:.76rem; color:var(--txt2); margin-top:2px; }
.google-tag { display:flex; align-items:center; gap:6px; margin-top:12px; font-size:.7rem; font-weight:600; color:var(--txt2); }
.villes-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:10px; margin-top:44px; }
.ville { background:#fff; border:1.5px solid var(--brd); border-radius:var(--r2); padding:20px 16px; text-decoration:none; transition:all .3s var(--e); position:relative; overflow:hidden; display:flex; flex-direction:column; gap:3px; }
.ville::after { content:''; position:absolute; bottom:0; left:0; right:0; height:3px; background:var(--or); transform:scaleX(0); transition:transform .35s var(--e); }
.ville:hover { border-color:var(--or); transform:translateY(-4px); box-shadow:0 14px 44px rgba(212,168,67,.12); }
.ville:hover::after { transform:scaleX(1); }
.ville strong { font-size:.93rem; font-weight:700; color:var(--c); font-family:'DM Sans',sans-serif; }
.ville .cp { font-size:.75rem; color:var(--txt2); }
.ville .vl { font-size:.75rem; font-weight:700; color:var(--or); margin-top:9px; opacity:0; transform:translateY(4px); transition:.25s; }
.ville:hover .vl { opacity:1; transform:none; }
.cta-sec { background:var(--c); padding:var(--sec) 0; position:relative; overflow:hidden; }
.cta-sec::before { content:''; position:absolute; inset:0; pointer-events:none; background:radial-gradient(ellipse 80% 60% at 0 60%,rgba(212,168,67,.07) 0%,transparent 55%),radial-gradient(ellipse 50% 70% at 100% 10%,rgba(212,168,67,.04) 0%,transparent 50%); }
.cta-sec::after { content:'BORDEAUX'; position:absolute; bottom:-80px; right:-60px; font-family:'Cormorant Garamond',serif; font-size:18rem; font-weight:700; color:rgba(255,255,255,.014); line-height:1; pointer-events:none; white-space:nowrap; }
.cta-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; position:relative; z-index:1; }
.cta-left h2 { color:#fff; margin:8px 0 18px; }
.cta-left > p { color:var(--d-txt); font-size:.96rem; line-height:1.84; margin-bottom:32px; }
.chk-list { display:flex; flex-direction:column; gap:11px; margin-bottom:36px; }
.chk-list li { display:flex; align-items:center; gap:12px; font-size:.87rem; color:var(--d-txt2); }
.chk-list li::before { content:'✓'; width:22px; height:22px; border-radius:50%; background:rgba(16,185,129,.12); border:1px solid rgba(16,185,129,.3); display:flex; align-items:center; justify-content:center; font-size:.68rem; color:var(--grn); flex-shrink:0; }
.cta-tel { display:inline-flex; align-items:center; gap:12px; background:rgba(212,168,67,.1); border:1px solid rgba(212,168,67,.2); color:var(--or); padding:16px 24px; border-radius:var(--r2); font-weight:700; font-size:1.05rem; transition:.3s; width:fit-content; text-decoration:none; }
.cta-tel:hover { background:rgba(212,168,67,.18); color:var(--or2); border-color:rgba(212,168,67,.4); }
.fbox { background:#fff; border-radius:var(--r2); padding:40px; box-shadow:0 40px 100px rgba(0,0,0,.32); }
.fbox h3 { font-family:'DM Sans',sans-serif; font-size:1.12rem; font-weight:700; margin-bottom:5px; }
.fbox-sub { font-size:.8rem; color:var(--txt2); margin-bottom:24px; padding-bottom:22px; border-bottom:1.5px solid var(--brd); }
.fg { margin-bottom:13px; }
.fg label { display:block; font-size:.76rem; font-weight:700; color:var(--c); margin-bottom:5px; letter-spacing:.015em; }
.fg input,.fg select,.fg textarea {
width:100%; padding:11px 14px;
border:1.5px solid var(--brd); border-radius:var(--r);
font-family:'DM Sans',sans-serif; font-size:.87rem; color:var(--c);
background:#fff; outline:none; -webkit-appearance:none;
transition:border-color .2s,box-shadow .2s;
}
.fg input:focus,.fg select:focus,.fg textarea:focus { border-color:var(--or); box-shadow:0 0 0 3px rgba(212,168,67,.12); }
.fg textarea { resize:vertical; min-height:84px; }
.fg-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.fsub {
width:100%; padding:15px; background:var(--c); color:#fff;
border:none; border-radius:var(--r); font-family:'DM Sans',sans-serif;
font-size:.95rem; font-weight:700; cursor:pointer;
transition:all .25s var(--e); margin-top:6px; box-shadow:0 6px 24px rgba(12,15,20,.28);
}
.fsub:hover { background:var(--c3); transform:translateY(-2px); box-shadow:0 12px 36px rgba(12,15,20,.38); }
.ffoot { font-size:.71rem; color:var(--txt2); text-align:center; margin-top:9px; }
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:48px; }
.bcard { border:1.5px solid var(--brd); border-radius:var(--r2); overflow:hidden; background:#fff; text-decoration:none; color:inherit; transition:all .32s var(--e); display:flex; flex-direction:column; }
.bcard:hover { border-color:var(--or); box-shadow:0 18px 56px rgba(212,168,67,.1); transform:translateY(-5px); }
.bpic { height:188px; overflow:hidden; }
.bpic img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--e); }
.bcard:hover .bpic img { transform:scale(1.07); }
.bbody { padding:24px; flex:1; display:flex; flex-direction:column; }
.btag { font-size:.66rem; font-weight:800; text-transform:uppercase; letter-spacing:.1em; color:var(--or); background:var(--or-bg); padding:3px 9px; border-radius:4px; display:inline-block; margin-bottom:11px; }
.bbody h3 { font-family:'DM Sans',sans-serif; font-size:.97rem; font-weight:700; color:var(--c); margin-bottom:8px; line-height:1.42; }
.bbody p { font-size:.83rem; flex:1; }
.bdate { font-size:.73rem; color:var(--txt2); margin-top:13px; }
.phero { background:var(--c); padding:64px 0; position:relative; overflow:hidden; }
.phero::before { content:''; position:absolute; inset:0; pointer-events:none; background:radial-gradient(ellipse 70% 120% at 100% 50%,rgba(212,168,67,.06) 0%,transparent 55%); }
.phero .wrap { position:relative; z-index:2; }
.bc { display:flex; align-items:center; gap:6px; flex-wrap:wrap; font-size:.76rem; color:rgba(255,255,255,.3); margin-bottom:22px; }
.bc a { color:rgba(255,255,255,.72); transition:color .2s; text-decoration:none; }
.bc a:hover { color:var(--or); }
.bc span { color:rgba(255,255,255,.18); }
.phero h1 { color:#fff; margin-bottom:14px; }
.phero .lead { color:rgba(255,255,255,.85); max-width:640px; font-size:1.02rem; margin-bottom:28px; line-height:1.8; }
.phero .lead strong { color:#fff; font-weight:700; }
.phero strong { color:#fff; }
.sec strong { color:inherit; }
.badges { display:flex; flex-wrap:wrap; gap:9px; }
.bdg { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); color:rgba(255,255,255,.65); padding:5px 13px; border-radius:20px; font-size:.76rem; font-weight:500; }
.page-wrap { display:grid; grid-template-columns:1fr 340px; gap:62px; align-items:start; }
.cmain h2 { margin:44px 0 14px; font-size:1.6rem; }
.cmain h2:first-child { margin-top:0; }
.cmain h3 { margin:26px 0 10px; color:var(--or); font-family:'DM Sans',sans-serif; font-size:.97rem; font-weight:700; }
.cmain p { margin-bottom:15px; }
.cmain ul { margin:14px 0 20px; display:flex; flex-direction:column; gap:10px; }
.cmain ul li { padding-left:22px; position:relative; font-size:.92rem; color:var(--txt); }
.cmain ul li::before { content:'→'; position:absolute; left:0; color:var(--or); font-weight:700; font-size:.82rem; }
.spanel { position:sticky; top:82px; display:flex; flex-direction:column; gap:18px; }
.sc { background:#fff; border:1.5px solid var(--brd); border-radius:var(--r2); padding:26px; }
.sc.dark { background:var(--c); border-color:var(--c2); }
.sc.dark h3 { color:#fff; }
.sc.dark p { color:rgba(255,255,255,.72); }
.sc h3 { font-family:'DM Sans',sans-serif; font-size:.97rem; margin-bottom:10px; }
.sc p { font-size:.83rem; margin-bottom:14px; }
.sc-tel { display:flex; align-items:center; justify-content:center; gap:8px; background:var(--c); color:#fff; padding:13px; border-radius:var(--r); font-weight:700; font-size:.93rem; width:100%; text-decoration:none; transition:.25s; box-shadow:0 4px 16px rgba(12,15,20,.2); }
.sc-tel:hover { background:var(--c3); color:#fff; transform:translateY(-1px); }
.sc-lnks { display:flex; flex-direction:column; gap:7px; margin-top:8px; }
.sc-lnks a { display:flex; align-items:center; gap:9px; padding:9px 12px; background:var(--snow); border-radius:var(--r); font-size:.84rem; font-weight:500; color:var(--txt); transition:.2s; text-decoration:none; }
.sc-lnks a:hover { background:var(--snow2); color:var(--or); }
.faq-list { display:flex; flex-direction:column; gap:10px; margin-top:30px; }
.faq-item { border:1.5px solid var(--brd); border-radius:var(--r2); overflow:hidden; transition:border-color .2s; }
.faq-item.open { border-color:var(--or); }
.faq-q { padding:17px 22px; font-weight:600; font-size:.89rem; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:12px; transition:background .2s; }
.faq-q:hover { background:var(--snow); }
.faq-tog { width:24px; height:24px; border-radius:50%; background:var(--snow2); display:flex; align-items:center; justify-content:center; font-size:.9rem; color:var(--or); flex-shrink:0; transition:all .3s; }
.faq-item.open .faq-tog { background:var(--or); color:var(--c); transform:rotate(45deg); }
.faq-a { display:none; padding:0 22px 17px; font-size:.86rem; color:var(--txt2); line-height:1.76; border-top:1px solid var(--brd); }
.faq-item.open .faq-a { display:block; padding-top:14px; }
.vtabs { display:flex; flex-wrap:wrap; gap:8px; margin:22px 0 10px; }
.vtab { padding:7px 15px; border-radius:20px; font-size:.81rem; font-weight:600; border:1.5px solid var(--brd); color:var(--txt); background:#fff; cursor:pointer; transition:.2s; text-decoration:none; }
.vtab:hover,.vtab.on { background:var(--or); border-color:var(--or); color:var(--c); }
.flt { position:fixed; bottom:24px; right:24px; z-index:300; display:flex; flex-direction:column; align-items:flex-end; gap:10px; }
.fbtn { display:flex; align-items:center; gap:10px; padding:12px 20px; border-radius:50px; font-family:'DM Sans',sans-serif; font-weight:700; font-size:.83rem; box-shadow:0 8px 28px rgba(0,0,0,.18); transition:all .3s var(--e); text-decoration:none; white-space:nowrap; }
.fbtn:hover { transform:translateY(-3px); box-shadow:0 14px 38px rgba(0,0,0,.25); }
.ftel  { background:var(--c2); color:#fff; border:1px solid rgba(255,255,255,.1); }
.ftel:hover { color:#fff; background:var(--c3); }
.fdevis { background:var(--or); color:var(--c); }
.fdevis:hover { color:var(--c); background:var(--or2); }
footer { background:var(--c2); border-top:1px solid var(--d-brd); padding:72px 0 0; }
.ft-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; padding-bottom:52px; contain:layout; }
.ft-logo { font-family:'Cormorant Garamond',serif; font-size:1.22rem; font-weight:700; color:#fff; display:block; margin-bottom:13px; text-decoration:none; }
.ft-logo em { font-style:normal; color:var(--or); }
.ft-desc { font-size:.82rem; color:rgba(255,255,255,.65); max-width:260px; line-height:1.75; }
.ft-tel { display:inline-flex; align-items:center; gap:8px; background:rgba(212,168,67,.1); border:1px solid rgba(212,168,67,.22); color:var(--or); padding:10px 18px; border-radius:var(--r); font-weight:700; font-size:.84rem; margin-top:16px; transition:.3s; text-decoration:none; }
.ft-tel:hover { background:rgba(212,168,67,.2); color:var(--or2); }
.ft-col h4, .ft-col-title { font-family:'DM Sans',sans-serif; font-size:.7rem; font-weight:800; text-transform:uppercase; letter-spacing:.12em; color:rgba(255,255,255,.7); margin-bottom:16px; }
.ft-col ul { display:flex; flex-direction:column; gap:9px; }
.ft-col ul a { font-size:.82rem; color:rgba(255,255,255,.72); transition:color .2s; text-decoration:none; }
.ft-col ul a:hover { color:rgba(255,255,255,.82); }
.ft-btm { border-top:1px solid var(--d-brd); padding:20px 0; display:flex; justify-content:space-between; align-items:center; font-size:.74rem; color:rgba(255,255,255,.55); flex-wrap:wrap; gap:8px; }
.ft-btm a { color:rgba(255,255,255,.6); text-decoration:none; }
.ft-btm a:hover { color:rgba(255,255,255,.7); }
.rv { opacity:0; transform:translateY(26px); transition:opacity .7s var(--e),transform .7s var(--e); }
.rv.in { opacity:1; transform:none; }
.d1{transition-delay:.08s}.d2{transition-delay:.18s}.d3{transition-delay:.28s}.d4{transition-delay:.38s}
@media(max-width:1100px){
.svc-grid{grid-template-columns:repeat(2,1fr)}
.ft-grid{grid-template-columns:1fr 1fr}
.page-wrap{grid-template-columns:1fr}
.spanel{position:static}
.villes-grid{grid-template-columns:repeat(3,1fr)}
.about-grid{grid-template-columns:1fr}
.about-imgs{height:300px;margin-bottom:40px}
.ai-main{width:100%;height:300px;position:relative}
.ai-sec,.ai-card{display:none}
.proc-grid{grid-template-columns:repeat(2,1fr);gap:32px}
.proc-grid::before{display:none}
.trust-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
:root{--sec:60px}
.nav-items{display:none}
.brg{display:flex}
.mob-open .nav-items{display:flex;flex-direction:column;position:fixed;top:70px;left:0;right:0;background:#fff;padding:16px;gap:4px;z-index:177;border-bottom:1px solid var(--brd);box-shadow:0 12px 40px rgba(0,0,0,.12)}
.mob-open .nav-items a{padding:13px 16px;border-radius:var(--r);font-size:.94rem}
.kpis-row{grid-template-columns:repeat(2,1fr)}
.svc-grid{grid-template-columns:1fr}
.avis-grid{grid-template-columns:1fr}
.cta-grid{grid-template-columns:1fr;gap:44px}
.villes-grid{grid-template-columns:repeat(2,1fr)}
.blog-grid{grid-template-columns:1fr}
.ft-grid{grid-template-columns:1fr}
.fg-row{grid-template-columns:1fr}
.hero-body{padding:96px 0 78px}
.sec-hd{grid-template-columns:1fr;gap:18px}
.scrollhint{display:none}
.flt{bottom:16px;right:16px}
.fbtn .flbl{display:none}
.fbtn{padding:14px;border-radius:50%;width:52px;height:52px;justify-content:center;gap:0}
.proc-grid{grid-template-columns:1fr}
.trust-grid{grid-template-columns:1fr 1fr}
}
html {
-webkit-text-size-adjust: 100%;
text-size-adjust: 100%;
}
* {
-webkit-tap-highlight-color: transparent;
}
.btn, .nav-btn, .fbtn, .sc-tel, .cta-tel, .spc-tel {
min-height: 44px;
}
a.nav-items, .nav-items a {
min-height: 44px;
display: inline-flex;
align-items: center;
}
a:focus-visible, button:focus-visible,
input:focus-visible, select:focus-visible, textarea:focus-visible {
outline: 2px solid var(--or);
outline-offset: 2px;
border-radius: var(--r);
}
.skip-link {
position: absolute;
top: -40px;
left: 0;
background: var(--or);
color: var(--c);
padding: 8px 16px;
z-index: 9999;
font-weight: 700;
border-radius: 0 0 var(--r) 0;
text-decoration: none;
transition: top .2s;
}
.skip-link:focus { top: 0; }
img {
transition: opacity .3s ease;
}
img[loading="lazy"] {
opacity: 0;
}
img[loading="lazy"].loaded {
opacity: 1;
}
@media (max-width: 768px) {
.fg input, .fg select, .fg textarea {
font-size: 16px;
}
.faq-q {
padding: 18px 16px;
min-height: 56px;
}
.blog-grid {
grid-template-columns: 1fr;
}
.hero h1 {
font-size: clamp(1.8rem, 7vw, 2.8rem);
}
.hero-ctas {
flex-direction: column;
}
.hero-ctas .btn {
width: 100%;
justify-content: center;
}
.fbox {
padding: 24px 20px;
}
.nav-items a.cur {
border-left: 3px solid var(--or);
padding-left: 13px;
}
}
@media (max-width: 480px) {
.hero-trust {
flex-direction: column;
gap: 12px;
}
.kpis-row {
grid-template-columns: 1fr 1fr;
}
.villes-grid {
grid-template-columns: 1fr;
}
.proof-cell {
flex: 0 0 100%;
}
.ft-grid {
grid-template-columns: 1fr;
}
}
@media print {
.hdr, .flt, footer, #floating-cta { display: none !important; }
.hero { min-height: auto; padding: 40px 0; }
body { font-size: 12pt; }
a[href]:after { content: " (" attr(href) ")"; font-size: 10pt; color: #666; }
}
@media (prefers-contrast: high) {
.btn-or { border: 2px solid var(--c); }
.svc, .avis, .trust-item { border-width: 2px; }
}
@media (prefers-reduced-motion: reduce) {
*, *::before, *::after {
animation-duration: .01ms !important;
animation-iteration-count: 1 !important;
transition-duration: .01ms !important;
scroll-behavior: auto !important;
}
.rv { opacity: 1 !important; transform: none !important; }
}