/* Services overhaul */
.services{background:var(--bg-alt)}
.services h2{text-align:center;margin-bottom:22px}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.svc-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:12px;transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease}
.svc-card:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(2,6,23,.07);border-color:#d9dde5}
.svc-head{display:flex;align-items:center;gap:10px}
.svc-head h3{margin:0;font-size:18px}
.svc-icon{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:10px;background:linear-gradient(180deg,#eaf6f3,#d8ece7);color:#0b3b3b;border:1px solid #dfe8e5}
.svc-list{list-style:none;margin:0;padding-left:0;display:grid;gap:6px;color:var(--muted)}
.svc-list li{position:relative;padding-left:16px}
.svc-list li::before{content:"";position:absolute;left:0;top:.55em;width:8px;height:8px;border-radius:50%;background:#bfe6e0}
.svc-cta{align-self:flex-start;margin-top:6px;border:1px solid var(--border);padding:10px 12px;border-radius:10px;color:var(--text);background:#fff;transition:all .18s ease}
.svc-cta:hover{border-color:#2a2f3a;transform:translateY(-1px)}
.svc-card:nth-child(2) .svc-icon{background:linear-gradient(180deg,#ffe5e2,#ffd6d2);color:#7a2d29;border-color:#ffd4cf}
.svc-card:nth-child(3) .svc-icon{background:linear-gradient(180deg,#e9eef7,#d9e3f5);color:#1b3a73;border-color:#dae2f2}
.svc-card:nth-child(4) .svc-icon{background:linear-gradient(180deg,#fff0da,#ffe4bd);color:#7a4b12;border-color:#ffe0b0}
.svc-card:nth-child(5) .svc-icon{background:linear-gradient(180deg,#f2f7ff,#e3efff);color:#1f3f7a;border-color:#dde9ff}
.svc-card:nth-child(6) .svc-icon{background:linear-gradient(180deg,#f3f3f3,#e9e9e9);color:#333;border-color:#e5e5e5}
@media (max-width: 960px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 640px){.svc-grid{grid-template-columns:1fr}}

/* Atouts (services like in reference) */
.atouts{background:#fff}
.atouts-head{text-align:center;margin-bottom:10px}
.atouts-head h2{letter-spacing:.08em;color:var(--text)}
.atouts-sub{color:var(--accent);margin:0}
.atouts-grid{display:grid;grid-template-columns:1fr minmax(260px,420px) 1fr;gap:20px;align-items:center}
.atouts-col{display:grid;gap:26px}
.atouts-col-right .atout-item{justify-content:flex-end}
.atout-item{display:flex;align-items:flex-start;gap:12px}
.atouts-col-right .atout-item{gap:12px}
.atout-copy h3{margin:0 0 4px;color:var(--text);font-size:16px}
.atout-copy p{margin:0;color:var(--muted)}
.atout-icon{width:40px;height:40px;display:inline-grid;place-items:center;border-radius:10px;color:var(--text);border:1.5px solid var(--border);background:var(--bg-alt)}
.atouts-media{display:flex;justify-content:center}
.atouts-media img{max-width:420px;width:100%;border-radius:14px;box-shadow:0 12px 28px rgba(2,6,23,.12)}
@media (max-width: 960px){
  .atouts-grid{grid-template-columns:1fr;gap:18px}
  .atouts-col-right .atout-item{justify-content:flex-start}
  .atouts-media img{max-width:520px}
}
/* Réalisations slider */
.realisations{background:#e6f3f1}
.reel-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.reel-header h2{margin:0 auto;text-align:center;flex:1}
.reel{display:flex;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:6px;-ms-overflow-style:none;scrollbar-width:none}
.reel::-webkit-scrollbar{display:none}
.reel-item{flex:0 0 auto;scroll-snap-align:start;display:block;border-radius:12px;border:1px solid var(--border);background:#fff;overflow:hidden}
.reel-item{width:calc((100% - 36px) / 4)}
.reel-item img{display:block;width:100%;height:280px;object-fit:cover;transition:transform .25s ease}
.reel-item:hover img{transform:scale(1.03)}
.reel-controls{display:flex;align-items:center;gap:8px}
.reel-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:9999px;border:1px solid var(--border);background:#0b3b3b;color:#fff;cursor:pointer}
.reel-btn:hover{filter:brightness(.95)}
/* full-bleed wrapper for slider outside the container */
.reel-bleed{width:100vw;margin-left:calc(50% - 50vw);padding:0 16px}
@media (min-width: 1200px){.reel-bleed{padding:0 24px}}
@media (max-width: 1200px){
  .reel-item{width:calc((100% - 24px) / 3)}
  .reel-item img{height:240px}
}
@media (max-width: 768px){
  .reel-item{width:calc((100% - 12px) / 2)}
  .reel-item img{height:200px}
}
/* Testimonials - Modern Design */
.testimonials{background:linear-gradient(135deg, #f8fafc 0%, #e6f3f1 100%);position:relative;overflow:hidden}
.testimonials::before{content:"";position:absolute;top:-80px;left:-80px;width:300px;height:300px;background:radial-gradient(circle, rgba(11,59,59,0.08) 0%, transparent 70%);border-radius:50%;pointer-events:none}
.testimonials::after{content:"";position:absolute;bottom:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle, rgba(251,119,111,0.06) 0%, transparent 70%);border-radius:50%;pointer-events:none}
.testi-head{text-align:center;margin-bottom:48px;position:relative;z-index:1}
.testi-badge{display:inline-block;background:#0b3b3b;color:#fff;padding:6px 16px;border-radius:9999px;font-size:12px;font-weight:600;letter-spacing:0.05em;text-transform:uppercase;margin-bottom:12px}
.testi-head h2{margin:12px 0 8px;font-size:clamp(28px, 4vw, 38px);color:var(--text)}
.testi-subtitle{color:var(--muted);font-size:16px;margin:0;max-width:600px;margin-left:auto;margin-right:auto}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative;z-index:1}
.testi-card{background:#fff;border:1px solid #e5e7eb;border-radius:20px;padding:28px;display:flex;flex-direction:column;gap:16px;position:relative;transition:all .3s ease;box-shadow:0 4px 12px rgba(0,0,0,0.03)}
.testi-card:hover{transform:translateY(-6px);box-shadow:0 20px 40px rgba(0,0,0,0.08);border-color:#d1d5db}
.testi-card.featured{background:linear-gradient(135deg, #0b3b3b 0%, #0f766e 100%);border-color:#0b3b3b;color:#fff}
.testi-card.featured .testi-text{color:#fff}
.testi-card.featured .testi-name{color:#fff}
.testi-card.featured .testi-meta{color:rgba(255,255,255,0.7)}
.testi-card.featured .quote-icon{color:rgba(255,255,255,0.15)}
.testi-card.featured .stars{color:#fbbf24}
.quote-icon{position:absolute;top:20px;right:20px;width:48px;height:48px;color:rgba(11,59,59,0.08);opacity:0.6}
.quote-icon svg{width:100%;height:100%}
.stars{display:flex;gap:3px;color:#fbbf24;margin-bottom:4px}
.stars svg{width:18px;height:18px;fill:currentColor}
.testi-text{margin:0;color:#334155;font-size:15px;line-height:1.7;flex:1;font-style:italic}
.testi-footer{margin-top:auto;padding-top:16px;border-top:1px solid #f1f5f9}
.testi-card.featured .testi-footer{border-top-color:rgba(255,255,255,0.15)}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-avatar{width:44px;height:44px;display:inline-grid;place-items:center;border-radius:50%;background:linear-gradient(135deg, #0b3b3b 0%, #0f766e 100%);color:#fff;font-weight:700;font-size:14px;flex-shrink:0}
.testi-card:nth-child(2) .testi-avatar{background:linear-gradient(135deg, #fb776f 0%, #f97316 100%)}
.testi-card:nth-child(3) .testi-avatar{background:linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%)}
.testi-card.featured .testi-avatar{background:#fff;color:#0b3b3b}
.testi-info{display:flex;flex-direction:column;gap:2px}
.testi-name{font-weight:600;font-size:15px;color:var(--text)}
.testi-meta{font-size:13px;color:var(--muted)}
@media (max-width: 960px){
  .testi-grid{grid-template-columns:repeat(2,1fr);gap:20px}
  .testi-head{margin-bottom:36px}
}
@media (max-width: 640px){
  .testi-grid{grid-template-columns:1fr;gap:18px}
  .testi-card{padding:24px}
  .testi-head{margin-bottom:32px}
}
.expertise-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.expertise-card{background:#eff3f5;border:1px solid var(--border);border-radius:12px;padding:10px;display:flex;flex-direction:column;gap:8px}
.expertise-title{margin:0;text-align:center;color:#0b3b3b}
.expertise-media{position:relative;border-radius:12px;overflow:hidden}
.expertise-media img{width:100%;height:150px;object-fit:cover;display:block;border-radius:10px}
.expertise-media .ex-deco{position:absolute;left:10px;bottom:10px;width:36px;height:36px;background:#fb776f;border-radius:50%;opacity:.35}
@media (max-width: 960px){
  .expertise-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 640px){
  .expertise-grid{grid-template-columns:1fr}
}
/* compact spacing for expertises section only */
.expertises.section{padding:48px 0}
.expertises .expertise-title{font-size:18px}
.exp-banner{background:#e6f3f1;padding:24px 0}
.exp-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:28px 0}
.exp-left{display:flex;align-items:center;gap:16px}
.exp-icon{width:64px;height:64px;display:grid;place-items:center;background:transparent;border-radius:12px}
.exp-title{margin:0;font-size:22px;line-height:1.2}
.exp-sub{margin:4px 0 0;color:var(--muted)}
.exp-right .exp-cta{background:#0b3b3b;color:#fff;border-radius:9999px;padding:12px 18px;border:0}
.exp-right .exp-cta:hover{filter:brightness(.95)}
@media (max-width: 768px){
  .exp-inner{flex-direction:column;align-items:flex-start}
}
:root{--bg:#ffffff;--bg-alt:#f8fafc;--text:#0f172a;--muted:#475569;--brand:#eab308;--accent:#2563eb;--card:#ffffff;--border:#e5e7eb}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter', -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:1120px;margin:0 auto;padding:0 16px}
.section{padding:72px 0}
.section-alt{background:var(--bg-alt)}
 h1,h2,h3{margin:0 0 16px}
 p{margin:0 0 16px;color:var(--muted)}
 ul{margin:0;padding-left:18px}

.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.75);backdrop-filter:saturate(160%) blur(6px);border-bottom:1px solid var(--border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:110px}
.logo{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.2px}
.logo-img{height:80px;width:auto;display:block}
.logo-text{white-space:nowrap}
.nav-toggle{display:none;align-items:center;justify-content:center;flex-direction:column;gap:5px;width:44px;height:44px;border:1px solid var(--border);background:transparent;border-radius:10px;color:var(--text);position:relative;z-index:60}
.nav-toggle .bar{display:block;width:20px;height:2px;background:var(--text);margin:0;border-radius:2px;transition:transform .18s ease, opacity .18s ease, background-color .18s ease}
/* animate to X when open */
.nav-toggle[aria-expanded="true"] .bar:nth-child(1){transform:translateY(6px) rotate(45deg);background:var(--accent)}
.nav-toggle[aria-expanded="true"] .bar:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] .bar:nth-child(3){transform:translateY(-6px) rotate(-45deg);background:var(--accent)}
.nav{display:block;z-index:55}
.nav-list{list-style:none;display:flex;gap:18px;margin:0;padding:0}
.nav-list a{display:block;padding:10px 12px;border-radius:9999px;color:var(--text);transition:background-color .2s ease,color .2s ease}
.nav-list a:hover{background:var(--bg-alt);color:var(--text)}
.nav-list a.active{background:rgba(2,6,23,.06);border:1px solid var(--border)}

.hero{position:relative;overflow:hidden;padding:96px 0;background:transparent;border-bottom:0;min-height:calc(80vh - 110px);display:grid;align-items:center}
/* hero background image removed to match attached design (text only) */
 
.hero-compact{min-height:auto;padding:64px 0}
@media (max-width: 768px){
  .hero-compact{padding:56px 0}
}

.hero h1{font-size:40px;line-height:1.2}
.hero p{font-size:18px;color:var(--muted)}
.hero-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:center}

.hero-content{padding:0}
.hero-content .eyebrow{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--text);margin:0 0 12px}
.hero-content .lead{font-size:18px;color:var(--muted);max-width:60ch}
.badges{list-style:none;margin:16px 0 0;padding:0;display:flex;gap:8px;flex-wrap:wrap}
.badge{background:var(--bg-alt);border:1px solid var(--border);color:var(--text);border-radius:9999px;padding:6px 10px;font-size:12px}
.hero-media{align-self:center;display:flex;justify-content:center;align-items:center;overflow:visible;margin:0}
.hero-media img{width:100%;height:100%;object-fit:cover;border-radius:0;border:none;box-shadow:none;margin:0;padding:0}
.hero-media .hero-photo{width:clamp(180px,28vw,340px);height:clamp(180px,28vw,340px);border-radius:50%;object-fit:cover;box-shadow:0 8px 24px rgba(2,6,23,.08)}
.hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}
.hero-content,.hero-media{position:relative;z-index:1}
.highlight{background:var(--bg);border:1px solid var(--border);border-radius:9999px;padding:2px 8px}
/* styles to match attached hero design */
.hero-title{font-size:clamp(36px,6.2vw,64px);line-height:1.05;font-weight:800;letter-spacing:-.02em}
.hero-title .accent{color:#fb776f}
.btn-cta{background:#0f766e;color:#fff;border:1px solid transparent;border-radius:9999px;padding:14px 20px;display:inline-flex;align-items:center;gap:10px;font-weight:600}
.btn-cta:hover{filter:brightness(.95)}
.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:9999px;background:rgba(255,255,255,.15);color:#fff}
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:stretch;grid-template-areas:"media content"}
.about-grid{min-height:520px}
.about-content p{max-width:60ch}
.about-content{display:flex;flex-direction:column;min-height:0;grid-area:content}
.about-text{flex:1;overflow:auto;max-height:520px;padding-right:8px}
.about-media{align-self:stretch;overflow:hidden;border-radius:12px;border:1px solid var(--border);grid-area:media}
.about-media img{width:100%;height:100%;object-fit:cover;display:block}
@media (min-width: 961px){
  .about-media{grid-column:1}
  .about-content{grid-column:2}
}
.cta{margin-top:24px;display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 18px;border-radius:10px;border:1px solid var(--border);transition:all .2s ease;cursor:pointer}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{filter:brightness(.95)}
.btn-secondary{background:transparent;color:var(--text)}
.btn-secondary:hover{border-color:#2a2f3a}

.grid{display:grid;gap:16px}
.services-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.gallery-grid{grid-template-columns:repeat(3,1fr)}
.card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px}
.card h3{margin-bottom:8px}
/* unify cards with subtle hover */
.card{transition:transform .18s ease, box-shadow .18s ease}
.card:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(2,6,23,.06)}

/* Services: enhanced card layout with icon */
.service-card{display:flex;gap:12px;align-items:flex-start}
.service-icon{flex:0 0 auto;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:var(--bg-alt);border:1px solid var(--border);color:#0b3b3b}
.service-card h3{margin:0 0 6px}
.service-card p{margin:0}

/* gallery items consistent rounding/ratio */
.gallery-item{display:block;overflow:hidden;border-radius:12px;border:1px solid var(--border);background:#fff}
.gallery-item img{display:block;width:100%;height:200px;object-fit:cover;transition:transform .25s ease}
.gallery-item:hover img{transform:scale(1.03)}
@media (max-width: 960px){
  .gallery-item img{height:180px}
}
@media (max-width: 640px){
  .gallery-item img{height:160px}
}

.cols{display:grid;grid-template-columns:1.2fr .8fr;gap:24px}
.list{color:var(--text)}
.list li{margin:8px 0}

.contact-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.contact-card{display:flex;flex-direction:column;gap:2px;border:1px solid var(--border);background:var(--card);border-radius:12px;padding:14px}
.contact-title{font-size:12px;color:var(--muted)}
.contact-value{font-size:16px}
.contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.contact-form input,.contact-form textarea{width:100%;padding:12px 14px;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--text)}
.contact-form textarea{resize:vertical}
.contact-form button{margin-top:4px}

/* Contact overhaul */
.contact{background:#e6f3f1;border-top:1px solid var(--border)}
.contact h2{text-align:center;margin-bottom:20px}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:18px}
.contact-form-only{max-width:820px;margin:0 auto}
.info-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:10px}
.info-card h3{margin:0 0 6px}
.info-line{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:#fff;color:var(--text)}
.info-line + .info-line{margin-top:8px}
.info-label{font-size:12px;color:var(--muted)}
.info-value{font-weight:600}
.info-note{font-size:12px;color:var(--muted)}
.contact .socials{margin-top:8px}
.contact-form.card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:22px}
.contact-form .form-actions{display:flex;align-items:center;gap:10px;margin-top:4px;flex-wrap:wrap}
.form-note{font-size:12px;color:var(--muted)}
/* Contact form: flat style override (no green/colored background) */
.contact{background:transparent}
.contact .card{background:transparent;border:0;box-shadow:none}
/* Contact form full width */
.contact .contact-form-only{max-width:none;width:100%}
.contact .contact-form{width:100%}
/* Contact form container (nice card) */
.contact .contact-form{background:#fff;border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:0 8px 24px rgba(0,0,0,.06)}
/* Contact form design */
.contact .form-grid{display:grid;gap:20px}
.contact .field .label{display:block;font-weight:600;margin:0 0 10px;color:var(--text)}
.contact .input{display:flex;align-items:center;gap:10px;border:1px solid var(--border);border-radius:12px;background:#fff;padding:12px 14px;transition:border-color .2s ease, box-shadow .2s ease}
.contact .input.with-icon svg{width:18px;height:18px;color:var(--muted);flex:0 0 auto}
.contact .input input,.contact .input select,.contact .input textarea{border:0;outline:0;background:transparent;width:100%;font:inherit;color:var(--text)}
.contact .input textarea{resize:vertical}
.contact ::placeholder{color:var(--muted)}
.contact .input:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(11,59,59,.08)}
.contact .input:focus-within svg{color:var(--accent)}
.contact .check{display:flex;align-items:center;gap:8px;margin-top:10px}
.contact .check input{width:16px;height:16px}
.contact .form-actions{margin-top:16px;gap:12px}
/* inline feedback spacing */
.contact .form-feedback{margin-top:12px}
@media (max-width: 960px){
  .contact-grid{grid-template-columns:1fr}
  .contact-form .form-row{grid-template-columns:1fr}
}

/* Mobile-friendly contact form spacing */
@media (max-width: 640px){
  .contact .contact-form{padding:16px}
  .contact .form-grid{gap:16px}
  .contact-form .form-row{gap:14px;margin-bottom:14px}
}

/* Full-bleed sections (edge-to-edge beyond container) */
.full-bleed{width:100vw;margin-left:50%;transform:translateX(-50%)}
.map-section{padding:0}
.map-section .map-embed{border:0}
.map-section .map-embed iframe{display:block;width:100%;height:560px;border:0}
@media (max-width: 640px){
  .map-section .map-embed iframe{height:360px}
}

/* Rhythm and hierarchy tweaks */
/* Headings: clearer hierarchy */
h1, h2, h3 { margin: 0 0 20px; }
@media (min-width: 961px) {
  h1 { margin-bottom: 28px; }
  h2 { margin-bottom: 24px; }
}

/* Section rhythm: generous on desktop, slightly tighter default */
.section { padding: 64px 0; }

/* Footer refinements: smaller, linky, sophisticated */
.site-footer { font-size: 14px; }
.site-footer .footer-top { padding: 28px 0; }
.site-footer .footer-menu h4 { font-size: 12px; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); margin: 0 0 10px; }
.site-footer .footer-menu ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 6px; }
.site-footer .footer-menu a { color: var(--muted); text-decoration: none; border-bottom: 1px dotted transparent; transition: color .2s ease, border-color .2s ease, opacity .2s ease; opacity: 0.9; }
.site-footer .footer-menu a:hover { color: var(--accent); border-bottom-color: var(--accent); opacity: 1; }
.site-footer .footer-contact h4 { font-size: 12px; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); margin: 0 0 10px; }
.site-footer .footer-contact p { margin: 4px 0; color: var(--muted); }
.site-footer .footer-contact a { color: inherit; text-decoration: none; border-bottom: 1px dotted transparent; }
.site-footer .footer-contact a:hover { color: var(--accent); border-bottom-color: var(--accent); }
.site-footer .footer-bottom { font-size: 12px; opacity: 0.9; }
@media (min-width: 961px) {
  .section { padding: 88px 0; }
}

/* Hero spacing on small screens */
@media (max-width: 768px) {
  .hero { padding: 84px 0; }
}

/* Exp banner: avoid cramped feel */
.exp-banner { padding: 36px 0; }
@media (min-width: 961px) {
  .exp-banner { padding: 44px 0; }
}

/* Section headers -> content spacing */
.atouts-head { margin-bottom: 20px; }
@media (min-width: 961px) {
  .atouts-head { margin-bottom: 28px; }
}

/* Reel header spacing so the gallery breathes */
.reel-header { margin-bottom: 16px; }
@media (min-width: 961px) {
  .reel-header { margin-bottom: 22px; }
}

/* Testimonials heading spacing */
.testimonials h2 { margin-bottom: 26px; }

/* Paragraph rhythm */
p { margin: 0 0 18px; }
@media (min-width: 961px) {
  p { margin: 0 0 20px; }
}

/* Contact form modern redesign */
.contact-form-modern{padding:22px}
.contact-form-modern .form-head h3{margin:0}
.contact-form-modern .form-head .muted{margin:4px 0 8px;color:var(--muted)}
.contact-form-modern .form-grid{display:grid;gap:12px;margin-bottom:10px}
.contact-form-modern .two-cols{grid-template-columns:1fr 1fr}
.contact-form-modern .field{display:flex;flex-direction:column;gap:6px}
.contact-form-modern .label{font-size:12px;color:var(--muted)}
.contact-form-modern .input{display:flex;align-items:center;border:1px solid var(--border);background:#fff;border-radius:10px;padding:10px 12px}
.contact-form-modern .input.select{padding:0}
.contact-form-modern .input.with-icon svg{width:16px;height:16px;margin-right:8px;color:var(--muted);flex:0 0 auto}
.contact-form-modern input[type="text"],
.contact-form-modern input[type="email"],
.contact-form-modern input[type="tel"],
.contact-form-modern select,
.contact-form-modern textarea{border:0;outline:0;width:100%;background:transparent;color:var(--text);font:inherit}
.contact-form-modern input[type="checkbox"]{width:16px;height:16px;accent-color:var(--accent);flex:0 0 auto}
.contact-form-modern select{padding:10px 12px}
.contact-form-modern .check{display:flex;align-items:center;gap:8px;margin:4px 0 8px}
.contact-form-modern .form-actions{justify-content:flex-start}
@media (max-width: 960px){
  .contact-form-modern .two-cols{grid-template-columns:1fr}
}
.contact-legal{margin-top:12px;color:var(--muted);font-size:13px;text-align:center}

/* Footer */
.site-footer{margin-top:32px;box-shadow:inset 0 1px 0 var(--border)}
.footer-top{background:#e6f3f1}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:28px;padding:32px 0}
.footer-grid-4{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:28px;padding:32px 0}
.footer-brand{display:flex;flex-direction:column;gap:12px}
.footer-logo{height:56px;width:auto;display:block}
.footer-desc{margin:0;color:var(--muted);max-width:46ch}
.footer-cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.footer-meta{list-style:none;margin:12px 0 0;padding:0;display:grid;gap:6px;color:var(--muted);font-size:14px}
.footer-meta strong{color:var(--text);font-weight:600}
.footer-menu h4,.footer-contact h4{margin:0 0 10px;font-size:16px}
.footer-menu ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.footer-menu a{color:var(--text)}
.footer-menu a:hover{color:var(--accent)}
.footer-contact p{margin:4px 0}
.footer-hours h5{margin:10px 0 6px;font-size:14px}
.footer-hours ul{list-style:none;margin:0;padding:0;display:grid;gap:4px;color:var(--muted);font-size:14px}
.footer-zones{margin:8px 0 0}
.socials{display:flex;gap:10px;margin-top:8px;padding:0;list-style:none}
.social{display:inline-grid;place-items:center;width:32px;height:32px;border-radius:9999px;background:#0b3b3b;color:#fff}
.social:hover{filter:brightness(.95)}
.footer-bottom{background:#0b3b3b;color:#fff}
.footer-bottom .container{display:flex;align-items:center;justify-content:center;min-height:56px}
.footer-bottom p{margin:0;font-size:14px}

/* Back to top button */
.back-to-top{position:fixed;right:18px;bottom:18px;width:40px;height:40px;border-radius:9999px;background:#0b3b3b;color:#fff;display:grid;place-items:center;border:1px solid rgba(255,255,255,.2);box-shadow:0 6px 18px rgba(2,6,23,.15);opacity:0;pointer-events:none;transform:translateY(8px);transition:opacity .2s ease, transform .2s ease}
.back-to-top.show{opacity:1;pointer-events:auto;transform:none}
@media (max-width: 960px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:20px}
  .footer-grid-4{grid-template-columns:1fr 1fr}
}
@media (max-width: 640px){
  .footer-grid{grid-template-columns:1fr;gap:18px}
  .footer-grid-4{grid-template-columns:1fr}
  .footer-brand,.footer-menu,.footer-contact{ text-align:center }
  .footer-cta{ justify-content:center }
}

@media (max-width: 960px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .cols{grid-template-columns:1fr}
  .hero-grid{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr;grid-template-areas:"media" "content"}
  .about-text{max-height:none;overflow:visible;padding-right:0}
  .about-media{align-self:auto}
  .about-media img{height:auto}
}
@media (max-width: 768px){
  .hero{padding:76px 0}
  .hero h1{font-size:32px}
  .nav-toggle{display:inline-flex}
  .nav{position:absolute;top:110px;right:16px;left:16px;background:var(--bg-alt);border:1px solid var(--border);border-radius:12px;display:none}
  .nav.open{display:block}
  .nav-list{flex-direction:column;padding:8px}
  .contact-cards{grid-template-columns:1fr}
  .contact-form .form-row{grid-template-columns:1fr}
}

/* Safer mobile nav overlay and tap targets */
@media (max-width: 768px){
  .nav{left:12px;right:12px}
  .nav-list a{padding:12px 14px}
  .nav.open{animation: navDrop .18s ease}
}
@keyframes navDrop{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* Compact header on very small phones */
@media (max-width: 480px){
  .header-inner{height:84px}
  .logo-img{height:56px}
  .nav{top:84px}
}

/* Footer mobile breathing room and link tap targets */
@media (max-width: 640px){
  .footer-cta{margin-top:12px}
  .site-footer .footer-menu ul{gap:8px}
  .site-footer .footer-contact p{margin:6px 0}
}
.site-footer .footer-menu a{padding:2px 0}

/* Floating mobile/tablet CTA bar */
.mobile-cta{position:fixed;left:0;right:0;bottom:0;display:none;gap:10px;padding:10px 12px;background:transparent;backdrop-filter:none;border-top:0;box-shadow:none;z-index:70}
.mobile-cta .cta-link{flex:1;display:inline-flex;align-items:center;justify-content:center;border-radius:9999px;padding:12px 14px;font-weight:600;border:1px solid var(--border)}
.mobile-cta .cta-link.contact{background:#0f766e;color:#fff;border-color:transparent}
.mobile-cta .cta-link.call{background:#fff;color:var(--text)}
.mobile-cta .cta-link svg{margin-right:8px}
.mobile-cta-safe{height:env(safe-area-inset-bottom, 0px)}
@media (max-width: 960px){ .mobile-cta{display:flex} }
@media (max-width: 960px){ body{ padding-bottom: 72px } }

/* Subtle animated background for ambient sections */
.section-ambient{position:relative;overflow:hidden}
.section-ambient .container{position:relative;z-index:1}
.section-ambient::before,
.section-ambient::after{content:"";position:absolute;border-radius:50%;filter:blur(28px);opacity:.28;pointer-events:none}
.section-ambient::before{top:-120px;left:-120px;width:520px;height:520px;background:
  radial-gradient(closest-side, rgba(191,230,224,.55), rgba(251,119,111,.32), rgba(11,59,59,.18), transparent 70%);
  animation: ambientFloat 22s ease-in-out infinite}
.section-ambient::after{bottom:-140px;right:-140px;width:560px;height:560px;background:
  radial-gradient(closest-side, rgba(11,59,59,.18), rgba(191,230,224,.45), rgba(251,119,111,.28), transparent 70%);
  animation: ambientFloat 26s ease-in-out infinite reverse}

@keyframes ambientFloat{
  0%{transform:translate3d(0,0,0) rotate(0)}
  50%{transform:translate3d(24px,-18px,0) rotate(22deg)}
  100%{transform:translate3d(0,0,0) rotate(0)}
}

@media (prefers-reduced-motion: reduce){
  .section-ambient::before,
  .section-ambient::after{animation:none}
}
