/* ===== Design System ===== */
:root{
  --bg:#f6f1ec;
  --surface:rgba(255,255,255,.82);
  --surface-strong:#ffffff;
  --text:#1f1a17;
  --muted:#695f59;
  --line:rgba(31,26,23,.08);
  --line-strong:rgba(31,26,23,.14);
  --primary:#8f3d3d;
  --primary-2:#c17a52;
  --accent:#d8b98a;
  --success:#588157;
  --shadow:0 18px 60px rgba(44,27,15,.12);
  --shadow-soft:0 10px 30px rgba(44,27,15,.08);
  --radius:24px;
  --container:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--text);
  background:
    radial-gradient(1000px 500px at 80% 0%, rgba(193,122,82,.12), transparent 55%),
    radial-gradient(800px 450px at 0% 20%, rgba(143,61,61,.12), transparent 55%),
    linear-gradient(180deg, #fbf8f5 0%, var(--bg) 100%);
}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline}
img{display:block;max-width:100%}
button{font:inherit}
.container{width:min(var(--container), calc(100% - 32px));margin-inline:auto}
.section{padding:96px 0}
.section-soft{background:linear-gradient(180deg, rgba(255,255,255,.45), rgba(255,255,255,.18))}
.center{text-align:center}
.skip-link:not(:focus), .sr-only{position:absolute;left:-9999px}
.skip-link:focus{position:fixed;top:12px;left:12px;background:#fff;padding:8px 12px;border-radius:12px;z-index:1000;box-shadow:var(--shadow-soft)}

/* ===== Header ===== */
.site-header{position:sticky;top:0;z-index:50;backdrop-filter:blur(18px);background:rgba(251,248,245,.72);border-bottom:1px solid var(--line)}
.nav-wrap{display:flex;align-items:center;gap:18px;min-height:78px}
.brand{display:flex;align-items:center;gap:14px;min-width:0}
.brand-logo-wrap{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(145deg, var(--primary), var(--primary-2));color:#fff;font-weight:800;font-size:1.25rem;box-shadow:0 12px 28px rgba(143,61,61,.24);overflow:hidden;animation:floatLogo 4s ease-in-out infinite}
.brand-logo-wrap.fallback{display:grid;place-items:center}
.brand-logo{width:100%;height:100%;object-fit:contain;background:#fff;padding:6px}
.brand-eyebrow{display:block;font-size:.8rem;color:var(--muted);font-weight:650;letter-spacing:.08em;text-transform:uppercase}
.brand-title{display:block;font-size:1rem;font-weight:800;letter-spacing:.01em}
.site-nav{margin-left:auto;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.site-nav a{padding:10px 14px;border-radius:999px;color:var(--muted);font-weight:650}
.site-nav a:hover{text-decoration:none;background:rgba(143,61,61,.08);color:var(--text)}
.menu-toggle{display:none;margin-left:auto;border:1px solid var(--line);background:rgba(255,255,255,.8);border-radius:16px;padding:10px;width:48px;height:48px;box-shadow:var(--shadow-soft);cursor:pointer}
.menu-toggle span{display:block;height:2px;background:var(--text);margin:5px 0;border-radius:999px}

/* ===== Buttons ===== */
.button{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:52px;padding:0 20px;border-radius:999px;border:1px solid transparent;cursor:pointer;transition:transform .18s ease, box-shadow .18s ease, background .18s ease;font-weight:750;letter-spacing:.01em}
.button:hover{text-decoration:none;transform:translateY(-1px)}
.button-primary{color:#fff;background:linear-gradient(135deg, var(--primary), var(--primary-2));box-shadow:0 16px 36px rgba(143,61,61,.22)}
.button-secondary{background:rgba(255,255,255,.82);border-color:var(--line-strong);color:var(--text)}
.button-small{min-height:44px;padding:0 16px}

/* ===== Hero ===== */
.hero{padding:72px 0 52px}
.hero-grid{display:grid;grid-template-columns:1.16fr .84fr;gap:30px;align-items:center}
.eyebrow,.mini-label{margin:0 0 12px;color:var(--primary);font-weight:800;letter-spacing:.12em;text-transform:uppercase;font-size:.78rem}
.hero h1{font-size:clamp(2.6rem, 6vw, 5rem);line-height:.96;letter-spacing:-.04em;margin:0 0 20px;max-width:12ch}
.hero h1 span{background:linear-gradient(135deg, var(--primary), var(--primary-2) 60%, #b99661);-webkit-background-clip:text;background-clip:text;color:transparent}
.lead{font-size:1.08rem;line-height:1.8;color:#403833;max-width:62ch;margin:0 0 28px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:20px}
.hero-pill-list{display:flex;flex-wrap:wrap;gap:10px;list-style:none;padding:0;margin:0}
.hero-pill-list li{padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.68);border:1px solid var(--line);color:var(--muted);font-weight:650}
.glass-card{background:linear-gradient(180deg, rgba(255,255,255,.88), rgba(255,255,255,.72));border:1px solid rgba(255,255,255,.65);box-shadow:var(--shadow);border-radius:calc(var(--radius) + 4px)}
.hero-card{padding:22px}
.hero-image-box,.portrait-image-box{margin-bottom:22px}
.hero-image,.portrait-image{width:100%;height:auto;border-radius:22px;box-shadow:var(--shadow-soft)}
.hero-image-placeholder,.portrait-placeholder,.service-placeholder{display:grid;place-items:center;min-height:240px;border-radius:20px;background:linear-gradient(135deg, rgba(143,61,61,.08), rgba(193,122,82,.14));border:1px dashed rgba(143,61,61,.25);color:var(--muted);font-weight:700;text-align:center;padding:18px}
.info-list{display:grid;gap:12px}
.info-row{display:flex;flex-direction:column;gap:4px;padding:14px 16px;background:rgba(255,255,255,.72);border:1px solid var(--line);border-radius:18px}
.info-row span{font-size:.86rem;color:var(--muted)}
.info-row strong{font-size:.98rem;line-height:1.5}

/* ===== Cards/sections ===== */
.highlight-strip{padding-top:12px}
.highlight-grid,.cards-grid{display:grid;gap:18px}
.highlight-grid{grid-template-columns:repeat(3,1fr)}
.highlight-card,.service-card,.testimonial-card,.feature-card,.timeline-item,.contact-card{background:rgba(255,255,255,.72);border:1px solid var(--line);box-shadow:var(--shadow-soft);border-radius:var(--radius);padding:24px}
.highlight-card h2,.service-card h3,.feature-card h3,.timeline-item h3{margin:0 0 10px;font-size:1.16rem}
.highlight-card p,.service-card p,.feature-card p,.timeline-item p,.testimonial-card p,.section-copy,.contact-card,.portrait-card p{color:var(--muted);line-height:1.75}
.highlight-icon{display:inline-grid;place-items:center;width:40px;height:40px;border-radius:14px;background:rgba(143,61,61,.1);color:var(--primary);font-weight:800;margin-bottom:14px}
.section-head{margin-bottom:34px}
.section-head h2,.portrait-card h2,.cta-panel h2,.faq-wrap h2{font-size:clamp(2rem, 4vw, 3rem);line-height:1.05;margin:0 0 14px;letter-spacing:-.03em}
.service-grid{grid-template-columns:repeat(3,1fr)}
.service-image-wrap{margin-bottom:18px}
.service-image{width:100%;height:180px;object-fit:contain;border-radius:18px}
.service-number{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--primary);font-weight:800;margin-bottom:16px}
.featured-service{background:linear-gradient(160deg, rgba(143,61,61,.92), rgba(193,122,82,.94));color:#fff;border-color:transparent}
.featured-service p,.featured-service h3{color:#fff}
.featured-badge{display:inline-flex;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.16);font-weight:800;letter-spacing:.08em;text-transform:uppercase;font-size:.75rem;margin-bottom:18px}
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:start}
.portrait-card{padding:32px}
.check-list{list-style:none;padding:0;margin:24px 0 0;display:grid;gap:12px}
.check-list li{position:relative;padding-left:32px;font-weight:650}
.check-list li::before{content:"✓";position:absolute;left:0;top:0;width:22px;height:22px;border-radius:999px;background:rgba(88,129,87,.12);color:var(--success);display:grid;place-items:center;font-size:.92rem}
.feature-stack{display:grid;gap:18px}
.timeline{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.timeline-step{display:inline-grid;place-items:center;width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg, rgba(143,61,61,.12), rgba(193,122,82,.22));color:var(--primary);font-weight:800;margin-bottom:18px}
.testimonial-grid{grid-template-columns:repeat(3,1fr)}
.testimonial-card{margin:0}
.testimonial-card p{font-size:1.04rem;color:var(--text)}
.testimonial-card footer{margin-top:18px;color:var(--muted);font-weight:650}
.faq-wrap{align-items:start}
.faq-list{display:grid;gap:14px}
.faq-list details{background:rgba(255,255,255,.78);border:1px solid var(--line);border-radius:20px;padding:18px 20px;box-shadow:var(--shadow-soft)}
.faq-list summary{cursor:pointer;font-weight:750;list-style:none;position:relative;padding-right:24px}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"+";position:absolute;right:0;top:0;color:var(--primary);font-size:1.2rem;font-weight:700}
.faq-list details[open] summary::after{content:"–"}
.faq-list p{margin:14px 0 0;color:var(--muted);line-height:1.7}

/* ===== Contact/Footer ===== */
.cta-section{padding-top:28px}
.cta-panel{background:linear-gradient(135deg, rgba(143,61,61,.96), rgba(193,122,82,.94));color:#fff;border-radius:32px;padding:34px;display:grid;grid-template-columns:1fr .95fr;gap:24px;box-shadow:var(--shadow)}
.cta-panel .eyebrow{color:rgba(255,255,255,.76)}
.cta-panel p{color:rgba(255,255,255,.86)}
.contact-card{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.18);box-shadow:none;color:#fff}
.contact-row{display:flex;flex-direction:column;gap:4px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.18)}
.contact-row:last-of-type{border-bottom:0}
.contact-row span{color:rgba(255,255,255,.72);font-size:.86rem}
.contact-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.cta-panel .button-secondary{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.25);color:#fff}
.site-footer{padding:28px 0 40px}
.footer-grid{display:grid;grid-template-columns:1.1fr 1fr auto;gap:18px;align-items:end;color:var(--muted)}
.footer-title{margin-bottom:6px;color:var(--text)}
.footer-links{display:flex;gap:14px;flex-wrap:wrap;justify-content:flex-end}
.footer-links a{font-weight:700}

/* ===== Modal ===== */
.booking-modal{position:fixed;inset:0;display:none;z-index:100}
.booking-modal[aria-hidden="false"]{display:block}
.modal-backdrop{position:absolute;inset:0;background:rgba(20,17,15,.56);backdrop-filter:blur(6px)}
.modal-card{position:relative;width:min(760px, calc(100% - 24px));margin:6vh auto;background:#fff;border-radius:28px;box-shadow:0 36px 90px rgba(0,0,0,.24);overflow:hidden;border:1px solid rgba(255,255,255,.4)}
.modal-head{display:flex;justify-content:space-between;gap:18px;padding:24px 24px 0}
.modal-head h2{margin:0 0 8px;font-size:1.6rem}
.modal-close{background:#f6f1ec;border:1px solid var(--line);width:44px;height:44px;border-radius:14px;cursor:pointer;font-size:1.55rem;line-height:1}
.modal-body{padding:24px}
.consent-card{background:linear-gradient(180deg, #fcfaf7, #f5eee8);border:1px solid var(--line);border-radius:24px;padding:24px}
.consent-card h3{margin:0 0 10px}
.modal-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.booking-embed{min-height:260px;border:1px solid var(--line);border-radius:24px;padding:20px;background:#fff}
.booking-placeholder{display:grid;gap:14px}
.placeholder-box{padding:18px;border-radius:18px;background:#f8f4ef;border:1px solid var(--line)}

/* ===== Cookie Banner ===== */
.cookie-banner{position:fixed;left:20px;right:20px;bottom:20px;z-index:120}
.cookie-box{max-width:860px;margin-inline:auto;background:rgba(255,255,255,.96);border:1px solid var(--line);box-shadow:0 20px 60px rgba(0,0,0,.18);border-radius:24px;padding:18px 20px;display:flex;gap:18px;align-items:center;justify-content:space-between}
.cookie-box h3{margin:0 0 6px}
.cookie-box p{margin:0;color:var(--muted);line-height:1.6}
.cookie-buttons{display:flex;flex-wrap:wrap;gap:10px;align-items:center}

/* ===== Animations ===== */
@keyframes floatLogo{0%{transform:translateY(0)}50%{transform:translateY(-4px)}100%{transform:translateY(0)}}

/* ===== Responsive ===== */
@media (max-width: 980px){
  .hero-grid,.split-grid,.cta-panel,.footer-grid{grid-template-columns:1fr}
  .service-grid,.testimonial-grid,.timeline,.highlight-grid{grid-template-columns:repeat(2,1fr)}
  .footer-links{justify-content:flex-start}
  .cookie-box{flex-direction:column;align-items:flex-start}
}
@media (max-width: 760px){
  .section{padding:72px 0}
  .site-nav{position:absolute;top:84px;left:16px;right:16px;display:none;flex-direction:column;align-items:stretch;padding:12px;background:rgba(255,255,255,.96);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow)}
  .site-nav.open{display:flex}
  .site-nav a{padding:14px 16px;border-radius:16px}
  .menu-toggle{display:inline-block}
  .nav-wrap > .button-small{display:none}
  .service-grid,.testimonial-grid,.timeline,.highlight-grid{grid-template-columns:1fr}
  .hero{padding-top:46px}
  .hero h1{max-width:unset}
  .modal-card{margin:3vh auto}
  .cookie-banner{left:12px;right:12px;bottom:12px}
}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *{transition:none !important;animation:none !important}
}
.service-card {
  border: none;
  border-radius: 16px;
}

.service-card.red-border {
  border: 4px solid red;
}

.service-card.black-border {
  border: 4px solid black;
}
