:root{
  interpolate-size: allow-keywords;
}
:root{
  --bg:#f6f5f2;
  --panel:#ffffff;
  --ink:#121212;
  --ink-2:#2b2b2b;
  --muted:#6b6b6b;
  --line:#e7e4de;
  --accent:#1a1a1a;
  --accent-2:#d7c9a7;
  --focus:#0b66ff;
  --max:1200px;
  --r:14px;
  --shadow:0 1px 2px rgba(0,0,0,.04), 0 10px 30px rgba(0,0,0,.06);
  --mono:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  --sans:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--ink);text-decoration:none;transition:color .25s ease}
a:hover{color:#000}
main p a, main li a, .lede a, .consent-row a, footer.site .cols p a{
  background-image:linear-gradient(currentColor,currentColor);
  background-repeat:no-repeat;
  background-position:0 100%;
  background-size:0% 1.5px;
  transition:background-size .35s ease, color .25s ease;
}
main p a:hover, main li a:hover, .lede a:hover, .consent-row a:hover, footer.site .cols p a:hover{
  background-size:100% 1.5px;color:#000;
}
:focus-visible{outline:3px solid var(--focus);outline-offset:2px;border-radius:6px}
.skip{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip:focus{position:fixed;left:16px;top:16px;width:auto;height:auto;padding:10px 14px;background:#000;color:#fff;z-index:9999;border-radius:8px}

.container{max-width:var(--max);margin:0 auto;padding:0 22px}

/* Header */
header.site{position:sticky;top:0;z-index:50;background:rgba(246,245,242,.92);backdrop-filter:saturate(1.2) blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:16px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--ink);font-weight:700;letter-spacing:.2px}
.brand > span:last-child{transition:transform .35s ease, color .3s ease}
.brand .logo{
  width:34px;height:34px;border-radius:8px;
  background:linear-gradient(135deg,#111 0 50%,#d7c9a7 50% 100%);
  background-size:200% 200%;
  background-position:0% 0%;
  box-shadow:var(--shadow);
  transition:transform .4s cubic-bezier(.2,.8,.2,1), box-shadow .35s ease, background-position .6s ease, border-radius .35s ease;
  position:relative;
}
.brand .logo::after{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(135deg, rgba(255,255,255,.35), rgba(255,255,255,0) 55%);
  opacity:0;transition:opacity .35s ease;
  pointer-events:none;
}
.brand:hover .logo{
  transform:rotate(-8deg) scale(1.08);
  background-position:100% 100%;
  box-shadow:0 2px 4px rgba(0,0,0,.06), 0 14px 28px rgba(0,0,0,.14);
  border-radius:10px;
}
.brand:hover .logo::after{opacity:1}
.brand:hover > span:last-child{transform:translateX(2px);color:#000}
.brand:focus-visible .logo{transform:rotate(-6deg) scale(1.06)}
.nav-menu{display:flex}
.nav-menu ul{display:flex;gap:6px;list-style:none;margin:0;padding:0;align-items:center}
.nav-menu a.menu{
  text-decoration:none;color:var(--ink-2);font-size:14px;
  padding:8px 12px;border-radius:999px;display:inline-block;
  transition:background .18s ease, color .18s ease;
}
.nav-menu a.menu:hover{color:#000;background:#ece8df}
.nav-menu a.menu.active{background:#111;color:#fff}
.nav-toggle{
  display:none;background:transparent;border:1px solid var(--line);
  width:44px;height:44px;border-radius:12px;cursor:pointer;position:relative;
}
.nav-toggle .bar{position:absolute;left:10px;right:10px;height:2px;background:#111;border-radius:2px;transition:transform .2s ease, opacity .2s ease, top .2s ease}
.nav-toggle .bar.b1{top:14px}
.nav-toggle .bar.b2{top:21px}
.nav-toggle .bar.b3{top:28px}
.nav-toggle[aria-expanded="true"] .bar.b1{top:21px;transform:rotate(45deg)}
.nav-toggle[aria-expanded="true"] .bar.b2{opacity:0}
.nav-toggle[aria-expanded="true"] .bar.b3{top:21px;transform:rotate(-45deg)}

/* Hero */
.hero{padding:64px 0 40px}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:0 0 14px}
.h1{font-size:clamp(32px,4.8vw,56px);line-height:1.05;margin:0 0 18px;letter-spacing:-.01em}
.lede{font-size:18px;color:var(--ink-2);max-width:60ch;margin:0 0 22px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;max-width:100%}
.btn{
  position:relative;
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 22px;border-radius:999px;
  text-decoration:none;font-size:14px;font-weight:500;
  border:1px solid transparent;cursor:pointer;
  line-height:1.2;text-align:center;
  max-width:100%;box-sizing:border-box;
  overflow:hidden;isolation:isolate;
  transition:transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s ease, color .3s ease, border-color .3s ease, background-color .3s ease;
}
.btn::before{
  content:"";position:absolute;inset:0;z-index:-1;
  border-radius:inherit;
  transform:scaleX(0);transform-origin:left center;
  transition:transform .45s cubic-bezier(.2,.8,.2,1);
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0);transition-duration:.12s}
.btn:hover::before{transform:scaleX(1)}

.btn-primary{background:#111;color:#fff}
.btn-primary::before{background:linear-gradient(90deg,#2a2a2a,#000)}
.btn-primary:hover{box-shadow:0 2px 4px rgba(0,0,0,.08), 0 14px 28px rgba(0,0,0,.22);color:#fff}

.btn-ghost{background:transparent;color:#111;border-color:var(--line)}
.btn-ghost::before{background:#111}
.btn-ghost:hover{color:#fff;border-color:#111;box-shadow:0 2px 4px rgba(0,0,0,.06), 0 12px 24px rgba(0,0,0,.14)}

.hero-media{position:relative}
.hero-image{
  aspect-ratio: 4/5;
  background:#eae4d6;
  border:1px solid var(--line);
  border-radius:var(--r);
  box-shadow:var(--shadow);
  overflow:hidden;
  width:100%;
}
.hero-image img{width:100%;height:100%;object-fit:cover}

/* Sections */
section{padding:64px 0;border-top:1px solid var(--line);scroll-margin-top:90px}
section h2{font-size:clamp(24px,3vw,36px);margin:0 0 10px;letter-spacing:-.01em}
section .sub{color:var(--muted);max-width:70ch;margin:0 0 28px}
.grid{display:grid;gap:20px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--r);
  padding:22px;
  box-shadow:var(--shadow);
  transition:transform .25s ease, box-shadow .25s ease;
}
.card:hover{transform:translateY(-2px);box-shadow:0 2px 4px rgba(0,0,0,.04), 0 18px 44px rgba(0,0,0,.08)}
.card h3{margin:0 0 8px;font-size:18px}
.card p{margin:0;color:var(--ink-2);font-size:15px}
.num{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px}

/* Text + image split blocks */
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center;margin-top:26px}
.split.reverse{grid-template-columns:.9fr 1.1fr}
.split.reverse .split-media{order:-1}
.split-text h3{margin:0 0 10px;font-size:22px;letter-spacing:-.01em}
.split-text p{color:var(--ink-2);margin:0 0 10px}
.split-media{
  aspect-ratio: 4/3;
  max-width:460px;
  width:100%;
  background:#ece6d6;
  border:1px solid var(--line);
  border-radius:var(--r);
  overflow:hidden;
  box-shadow:var(--shadow);
}
.split-media img{width:100%;height:100%;object-fit:cover}

/* Inline media row */
.media-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px}
.media-row .thumb{
  aspect-ratio:1/1;
  background:#ece6d6;
  border:1px solid var(--line);
  border-radius:12px;
  overflow:hidden;
}
.media-row .thumb img{width:100%;height:100%;object-fit:cover}

/* Pricing */
.pricing{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.price{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:24px;display:flex;flex-direction:column;gap:8px}
.price .tag{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase}
.price h3{margin:6px 0 4px;font-size:20px}
.price .range{font-size:26px;font-weight:700;letter-spacing:-.01em}
.price .meta{color:var(--muted);font-size:14px;margin-top:4px}
.note{font-size:13px;color:var(--muted);margin-top:16px}

/* Calc */
.calc{background:#111;color:#fff;border-radius:var(--r);padding:28px;display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:center;margin-top:28px}
.calc h3{margin:0 0 6px;font-size:22px}
.calc p{margin:0 0 14px;color:#d9d9d9;font-size:14px}
.calc label{display:block;font-size:13px;color:#c9c9c9;margin:10px 0 6px}
.calc input[type=range]{width:100%}
.calc select{width:100%;padding:10px 12px;background:#1e1e1e;color:#fff;border:1px solid #2a2a2a;border-radius:8px;font-family:inherit}
.calc .readout{background:#1a1a1a;border:1px solid #262626;border-radius:10px;padding:18px}
.calc .readout .big{font-size:26px;font-weight:700;letter-spacing:-.01em}
.calc .readout .lbl{font-family:var(--mono);font-size:12px;color:#a9a9a9;text-transform:uppercase;letter-spacing:.12em}
.calc .disclaimer{font-size:12px;color:#9a9a9a;margin-top:10px}

/* FAQ */
details.faq{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px 18px;margin-bottom:10px;transition:box-shadow .3s ease}
details.faq summary{cursor:pointer;font-weight:600;list-style:none;position:relative;padding-right:28px}
details.faq summary::-webkit-details-marker{display:none}
details.faq summary::after{
  content:"";position:absolute;right:4px;top:50%;width:10px;height:10px;
  border-right:2px solid #111;border-bottom:2px solid #111;
  transform:translateY(-70%) rotate(45deg);
  transition:transform .3s ease;
}
details.faq[open] summary::after{transform:translateY(-30%) rotate(-135deg)}
details.faq[open]{box-shadow:var(--shadow)}
details.faq p{margin:10px 0 4px;color:var(--ink-2)}
details.faq::details-content{
  block-size:0;
  overflow:clip;
  opacity:0;
  transition:block-size .35s ease, content-visibility .35s allow-discrete, opacity .3s ease;
}
details.faq[open]::details-content{
  block-size:auto;
  opacity:1;
}

/* Contact page */
.contact-hero{display:grid;grid-template-columns:1.1fr .9fr;gap:44px;align-items:center}
.contact-hero .media{
  aspect-ratio:5/4;border-radius:var(--r);overflow:hidden;
  border:1px solid var(--line);background:#ece6d6;box-shadow:var(--shadow);
}
.contact-hero .media img{width:100%;height:100%;object-fit:cover}

.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.info-card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r);
  padding:26px;box-shadow:var(--shadow);
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
  display:flex;flex-direction:column;gap:10px;
}
.info-card:hover{transform:translateY(-3px);border-color:#d9d3c4;box-shadow:0 2px 4px rgba(0,0,0,.05),0 22px 48px rgba(0,0,0,.09)}
.info-card .ic{
  width:44px;height:44px;border-radius:12px;
  display:grid;place-items:center;
  background:#f1ede4;border:1px solid var(--line);color:#111;
}
.info-card .ic svg{width:22px;height:22px;stroke:#111;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.info-card .lbl{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase}
.info-card .val{font-size:17px;font-weight:700;letter-spacing:-.005em;word-break:break-word}
.info-card .hint{color:var(--ink-2);font-size:14px;margin:0}

/* Form split layout */
.form-split{display:grid;grid-template-columns:1.35fr .85fr;gap:24px;align-items:start}
.form-block{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r);
  padding:32px;box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.form-block::before{
  content:"";position:absolute;left:0;right:0;top:0;height:3px;
  background:linear-gradient(90deg,#111 0%, #d7c9a7 60%, #111 100%);
}
.form-block h2{margin:0 0 6px;font-size:26px;letter-spacing:-.01em}
.form-block .sub{margin:0 0 22px}

form.contact{display:grid;grid-template-columns:1fr 1fr;gap:18px;position:relative}
form.contact .full{grid-column:1/-1}
form.contact .field{display:flex;flex-direction:column}
form.contact label{font-size:12px;color:var(--muted);display:block;margin-bottom:7px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase}
form.contact .req{color:#a51212;margin-left:2px}
form.contact input, form.contact textarea{
  width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:12px;
  font-family:inherit;font-size:15px;background:#fff;color:var(--ink);
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
form.contact input:hover, form.contact textarea:hover{border-color:#c9c3b3}
form.contact input:focus, form.contact textarea:focus{
  outline:none;border-color:#111;background:#fff;
  box-shadow:0 0 0 4px rgba(17,17,17,.08);
}
form.contact textarea{min-height:150px;resize:vertical}
form.contact .hp{position:absolute;left:-9999px;opacity:0}
.consent-row{
  display:flex;gap:12px;align-items:flex-start;
  padding:14px 16px;background:#f4f1e9;border:1px solid var(--line);border-radius:12px;
  font-size:14px;color:var(--ink-2);
}
.consent-row input[type=checkbox]{margin-top:3px;width:16px;height:16px;accent-color:#111;flex:none}
.form-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-top:4px}
.form-actions .btn-primary{padding:14px 26px;font-size:15px}
.form-msg{font-size:14px}
.form-msg.ok{color:#0a6b2b}
.form-msg.err{color:#a51212}

.aside-panel{
  background:#111;color:#fff;border-radius:var(--r);padding:28px;
  position:sticky;top:96px;box-shadow:var(--shadow);
}
.aside-panel h3{margin:0 0 6px;font-size:20px;letter-spacing:-.005em}
.aside-panel p{margin:0 0 18px;color:#cfcfcf;font-size:14px}
.steps{list-style:none;margin:0;padding:0;display:grid;gap:14px}
.steps li{display:grid;grid-template-columns:28px 1fr;gap:12px;align-items:flex-start}
.steps .n{
  width:28px;height:28px;border-radius:50%;
  background:#1e1e1e;border:1px solid #2a2a2a;color:#fff;
  display:grid;place-items:center;font-family:var(--mono);font-size:12px;
}
.steps strong{display:block;font-size:14px;margin-bottom:2px}
.steps span{font-size:13px;color:#bdbdbd;line-height:1.5}
.aside-divider{height:1px;background:#262626;margin:20px 0}
.aside-meta{display:grid;gap:8px;font-size:13px;color:#bdbdbd}
.aside-meta strong{color:#fff}

/* Footer */
footer.site{border-top:1px solid var(--line);padding:36px 0;color:var(--muted);font-size:14px;background:#efece6}
footer.site .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:24px}
footer.site a{
  color:var(--ink-2);
  display:inline-block;
  position:relative;
  transition:color .25s ease, transform .3s cubic-bezier(.2,.8,.2,1), padding-left .3s cubic-bezier(.2,.8,.2,1);
  background-image:none;padding-bottom:0;
}
footer.site a::before{
  content:"";position:absolute;left:0;top:50%;width:0;height:1.5px;
  background:currentColor;transform:translateY(-50%);
  transition:width .3s cubic-bezier(.2,.8,.2,1);
}
footer.site a:hover{color:#000;padding-left:16px;background-size:0 0}
footer.site a:hover::before{width:10px}
footer.site h4{color:var(--ink);font-size:14px;margin:0 0 10px}
footer.site ul{list-style:none;padding:0;margin:0;display:grid;gap:6px}
.legal{margin-top:22px;border-top:1px solid var(--line);padding-top:16px;display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}
.legal a:hover{padding-left:0}
.legal a::before{display:none}

/* Cookie banner — responsive, safe-area aware */
.cookie{
  position:fixed;
  left:max(16px,env(safe-area-inset-left));
  right:max(16px,env(safe-area-inset-right));
  bottom:max(16px,env(safe-area-inset-bottom));
  z-index:100;
  max-width:min(680px,calc(100% - 32px));
  margin-left:auto;margin-right:auto;
  background:linear-gradient(145deg,#161616,#0c0c0c);
  color:#fff;border-radius:16px;
  padding:clamp(16px,2.2vw,22px) clamp(18px,2.4vw,26px);
  box-shadow:0 24px 60px rgba(0,0,0,.42),0 2px 6px rgba(0,0,0,.25);
  border:1px solid #242424;
  display:none;
}
.cookie > *{position:relative}
.cookie.open{display:block;animation:cookie-in .55s cubic-bezier(.2,.8,.2,1) both}
.cookie::before{
  content:"";position:absolute;left:0;right:0;top:0;height:2px;border-radius:16px 16px 0 0;
  background:linear-gradient(90deg,#d7c9a7,#fff,#d7c9a7);
  background-size:200% 100%;animation:sp-shimmer 5s linear infinite;
}
.cookie h4{margin:0 0 6px;font-size:clamp(15px,1.4vw,17px);letter-spacing:-.005em}
.cookie p{margin:0 0 14px;color:#cfcfcf;font-size:clamp(12px,1.2vw,13.5px);line-height:1.55}
.cookie .row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.cookie button{
  background:#fff;color:#111;border:0;
  padding:10px 18px;border-radius:999px;
  font-weight:600;cursor:pointer;font-size:13px;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease,color .25s ease;
  white-space:nowrap;
}
.cookie button:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(255,255,255,.18)}
.cookie button.ghost{background:transparent;color:#fff;border:1px solid #3a3a3a}
.cookie button.ghost:hover{border-color:#fff;background:rgba(255,255,255,.06)}
@keyframes cookie-in{
  0%{opacity:0;transform:translateY(40px) scale(.96)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}
@media (max-width:640px){
  .cookie .row{width:100%}
  .cookie .row button{flex:1 1 auto;text-align:center;min-width:0}
}
@media (max-width:420px){
  .cookie{border-radius:14px;padding:14px 16px}
  .cookie .row{flex-direction:column}
  .cookie .row button{width:100%;padding:12px 16px}
}
.modal{position:fixed;inset:0;background:rgba(0,0,0,.45);display:none;align-items:center;justify-content:center;z-index:110;padding:16px}
.modal.open{display:flex}
.modal .box{background:#fff;border-radius:14px;max-width:520px;width:100%;padding:24px;box-shadow:var(--shadow)}
.modal h3{margin:0 0 8px}
.modal .opt{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-top:1px solid var(--line)}
.modal .opt:first-of-type{border-top:0}
.modal .opt small{display:block;color:var(--muted)}
.switch{position:relative;width:42px;height:24px;background:#d9d5cc;border-radius:999px;cursor:pointer}
.switch.on{background:#111}
.switch::after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:left .2s}
.switch.on::after{left:21px}
.switch.locked{opacity:.6;cursor:not-allowed}

/* Responsive */
@media (max-width:780px){
  .hero-cta{flex-direction:column;align-items:stretch;width:100%}
  .hero-cta .btn{width:100%;padding:14px 18px;font-size:15px}
}
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr 1fr}
  .grid-4{grid-template-columns:1fr 1fr}
  .pricing{grid-template-columns:1fr 1fr}
  .split,.split.reverse{grid-template-columns:1fr}
  .split.reverse .split-media{order:0}
  .split-media{max-width:100%}
  .media-row{grid-template-columns:1fr 1fr}
  form.contact{grid-template-columns:1fr}
  .contact-hero{grid-template-columns:1fr}
  .info-grid{grid-template-columns:1fr}
  .form-split{grid-template-columns:1fr}
  .aside-panel{position:static}
  .form-block{padding:24px}
  .calc{grid-template-columns:1fr}
  footer.site .cols{grid-template-columns:1fr 1fr}

  .nav-toggle{display:block}
  header.site .container.nav{padding-left:24px;padding-right:24px}
  .nav-menu{
    position:absolute;left:0;right:0;top:100%;
    background:#f6f5f2;
    display:grid;grid-template-rows:0fr;
    overflow:hidden;
    transition:grid-template-rows .35s ease, box-shadow .35s ease;
  }
  .nav-menu::after{
    content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
    background:var(--line);
    opacity:0;transition:opacity .35s ease;
    pointer-events:none;
  }
  .nav-menu > ul{
    min-height:0;overflow:hidden;
    padding:0 22px;
    transition:padding .35s ease;
  }
  .nav-menu.open{
    grid-template-rows:1fr;
    box-shadow:0 14px 24px rgba(0,0,0,.06);
  }
  .nav-menu.open::after{opacity:1}
  .nav-menu.open > ul{padding:14px 22px}
  .nav-menu ul{flex-direction:column;align-items:stretch;gap:4px;display:flex}
  .nav-menu a.menu{padding:12px 14px;border-radius:10px;font-size:15px}
}
@media (max-width:560px){
  .grid-3,.grid-4,.pricing{grid-template-columns:1fr}
  .media-row{grid-template-columns:1fr}
}
@media (prefers-reduced-motion: reduce){
  *{transition:none !important;animation:none !important;scroll-behavior:auto !important}
}

/* ============================================================
   Advanced effects & styles (additive, responsive)
   ============================================================ */

/* Scroll progress bar */
.scroll-progress{
  position:fixed;left:0;top:0;height:3px;width:0%;z-index:200;
  background:linear-gradient(90deg,#111,#d7c9a7,#111);
  background-size:200% 100%;
  animation:sp-shimmer 4s linear infinite;
  box-shadow:0 0 12px rgba(215,201,167,.55);
  pointer-events:none;
  transition:width .1s linear;
}
@keyframes sp-shimmer{
  0%{background-position:0% 0}
  100%{background-position:200% 0}
}

/* Scroll reveal */
.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .45s cubic-bezier(.2,.8,.2,1), transform .5s cubic-bezier(.2,.8,.2,1);
  will-change:opacity,transform;
}
.reveal.in{opacity:1;transform:none}
.reveal.delay-1{transition-delay:.05s}
.reveal.delay-2{transition-delay:.1s}
.reveal.delay-3{transition-delay:.15s}

/* Animated gradient text for headings */
.h1, section h2{
  background:linear-gradient(92deg,#111 0%,#111 40%,#6b5a2f 55%,#111 70%,#111 100%);
  background-size:220% 100%;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  animation:grad-sweep 9s ease-in-out infinite;
}
@keyframes grad-sweep{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}

/* Hero aura / floating orbs */
.hero{position:relative;overflow:hidden}
.hero::before,.hero::after{
  content:"";position:absolute;border-radius:50%;pointer-events:none;z-index:0;
  filter:blur(70px);opacity:.55;
}
.hero::before{
  width:520px;height:520px;left:-180px;top:-160px;
  background:radial-gradient(circle at 30% 30%,#d7c9a7,transparent 65%);
  animation:float-a 14s ease-in-out infinite;
}
.hero::after{
  width:420px;height:420px;right:-140px;bottom:-120px;
  background:radial-gradient(circle at 60% 60%,#cfd9ff,transparent 65%);
  animation:float-b 18s ease-in-out infinite;
}
.hero > *{position:relative;z-index:1}
@keyframes float-a{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(40px,30px) scale(1.08)}
}
@keyframes float-b{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(-30px,-20px) scale(1.1)}
}

/* Hero image: shine sweep + subtle float */
.hero-image{position:relative;isolation:isolate;animation:hero-float 7s ease-in-out infinite}
.hero-image::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(115deg,transparent 35%,rgba(255,255,255,.45) 50%,transparent 65%);
  transform:translateX(-120%);
  animation:shine 5.5s ease-in-out 1.2s infinite;
  mix-blend-mode:overlay;
}
@keyframes hero-float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}
@keyframes shine{
  0%{transform:translateX(-120%)}
  55%,100%{transform:translateX(120%)}
}

/* Button shine sweep */
.btn{position:relative}
.btn::after{
  content:"";position:absolute;top:0;left:-80%;width:60%;height:100%;
  background:linear-gradient(110deg,transparent 0,rgba(255,255,255,.35) 50%,transparent 100%);
  transform:skewX(-20deg);transition:left .75s cubic-bezier(.2,.8,.2,1);
  pointer-events:none;
}
.btn:hover::after{left:140%}

/* Cards: gradient border glow on hover + subtle tilt */
.card,.info-card,.price{
  position:relative;
  transform-style:preserve-3d;
}
.card::before,.info-card::before,.price::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(135deg,rgba(215,201,167,.0),rgba(215,201,167,.9),rgba(17,17,17,.0));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .4s ease;
  pointer-events:none;
}
.card:hover::before,.info-card:hover::before,.price:hover::before{opacity:1}
.card:hover,.info-card:hover,.price:hover{
  transform:translateY(-4px);
  box-shadow:0 2px 4px rgba(0,0,0,.05),0 26px 54px rgba(17,17,17,.12);
}
.price{transition:transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s ease}

/* Numbered badge pulse */
.num,.price .tag{position:relative;display:inline-block}
.num::before{
  content:"";display:inline-block;width:6px;height:6px;border-radius:50%;
  background:#d7c9a7;margin-right:8px;vertical-align:middle;
  box-shadow:0 0 0 0 rgba(215,201,167,.7);
  animation:pulse 2.4s ease-out infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(215,201,167,.7)}
  70%{box-shadow:0 0 0 10px rgba(215,201,167,0)}
  100%{box-shadow:0 0 0 0 rgba(215,201,167,0)}
}

/* Media thumbs — zoom + tint */
.media-row .thumb,.split-media,.hero-image,.contact-hero .media{position:relative;overflow:hidden}
.media-row .thumb img,.split-media img,.contact-hero .media img{
  transition:transform .9s cubic-bezier(.2,.8,.2,1), filter .6s ease;
}
.media-row .thumb:hover img,.split-media:hover img,.contact-hero .media:hover img{
  transform:scale(1.08);filter:saturate(1.08) contrast(1.03);
}
.media-row .thumb::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.35));
  opacity:0;transition:opacity .4s ease;
}
.media-row .thumb:hover::after{opacity:1}

/* Calculator: animated gradient frame */
.calc{position:relative;isolation:isolate;overflow:hidden}
.calc::before{
  content:"";position:absolute;inset:-2px;z-index:-1;border-radius:inherit;
  background:conic-gradient(from 0deg,#d7c9a7,#111,#d7c9a7,#111,#d7c9a7);
  animation:spin 12s linear infinite;opacity:.55;
}
.calc::after{
  content:"";position:absolute;inset:1.5px;border-radius:calc(var(--r) - 2px);
  background:#111;z-index:-1;
}
@keyframes spin{to{transform:rotate(360deg)}}
.calc input[type=range]{
  -webkit-appearance:none;appearance:none;height:4px;border-radius:999px;
  background:linear-gradient(90deg,#d7c9a7,#5a4f33);outline:none;
}
.calc input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;
  background:#fff;border:2px solid #d7c9a7;cursor:pointer;
  box-shadow:0 0 0 0 rgba(215,201,167,.6);
  transition:box-shadow .3s ease,transform .2s ease;
}
.calc input[type=range]::-webkit-slider-thumb:hover{
  transform:scale(1.15);box-shadow:0 0 0 8px rgba(215,201,167,.25);
}
.calc input[type=range]::-moz-range-thumb{
  width:20px;height:20px;border-radius:50%;background:#fff;border:2px solid #d7c9a7;cursor:pointer;
}

/* Form inputs: gradient focus ring */
form.contact input:focus,form.contact textarea:focus{
  box-shadow:0 0 0 4px rgba(17,17,17,.08),0 0 0 1px #111,0 10px 24px rgba(215,201,167,.25);
}
.form-block::after{
  content:"";position:absolute;right:-60px;top:-60px;width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(215,201,167,.35),transparent 65%);
  pointer-events:none;animation:float-a 12s ease-in-out infinite;
}

/* Aside steps — hover slide */
.steps li{transition:transform .35s cubic-bezier(.2,.8,.2,1)}
.steps li:hover{transform:translateX(4px)}
.steps .n{transition:background .3s ease,border-color .3s ease,transform .35s ease}
.steps li:hover .n{background:#d7c9a7;border-color:#d7c9a7;color:#111;transform:rotate(-8deg)}

/* FAQ: gradient left bar on open */
details.faq{position:relative;overflow:hidden}
details.faq::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,#111,#d7c9a7);
  transform:scaleY(0);transform-origin:top;transition:transform .4s ease;
}
details.faq[open]::before{transform:scaleY(1)}

/* Footer: subtle pattern */
footer.site{position:relative;overflow:hidden}
footer.site::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:
    radial-gradient(circle at 10% 20%,rgba(215,201,167,.25),transparent 40%),
    radial-gradient(circle at 90% 80%,rgba(17,17,17,.06),transparent 45%);
}
footer.site .container{position:relative;z-index:1}

/* Noise overlay (very subtle) */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.035;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' seed='4'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.6'/></svg>");
}

/* Selection */
::selection{background:#d7c9a7;color:#111}

/* Custom scrollbar (desktop) */
@media (hover:hover){
  html{scrollbar-width:thin;scrollbar-color:#bfb69c #f6f5f2}
  html::-webkit-scrollbar{width:10px;height:10px}
  html::-webkit-scrollbar-track{background:#f6f5f2}
  html::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#d7c9a7,#8a7c57);border-radius:999px;border:2px solid #f6f5f2}
  html::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#111,#555)}
}

/* Responsive tweaks for advanced effects */
@media (max-width:780px){
  .hero::before{width:340px;height:340px;left:-120px;top:-100px}
  .hero::after{width:280px;height:280px;right:-100px;bottom:-90px}
  .form-block::after{width:140px;height:140px;right:-40px;top:-40px}
  .scroll-progress{height:2px}
}
@media (max-width:560px){
  .hero::before,.hero::after{filter:blur(50px);opacity:.45}
  body::before{opacity:.025}
}

@media (prefers-reduced-motion: reduce){
  .scroll-progress,.hero::before,.hero::after,.hero-image,.hero-image::after,
  .calc::before,.num::before,.h1,section h2,.form-block::after{
    animation:none !important;
  }
  .reveal{opacity:1 !important;transform:none !important}
  .h1,section h2{-webkit-text-fill-color:#111;color:#111;background:none}
}

/* ============================================================
   Page load / intro animations
   ============================================================ */

/* Curtain overlay that slides away after load */
.page-loader{
  position:fixed;inset:0;z-index:300;pointer-events:none;
  display:grid;place-items:center;
  background:#f6f5f2;
  transform-origin:top;
  animation:curtain-up .55s .45s cubic-bezier(.7,0,.2,1) forwards;
}
.page-loader::before,.page-loader::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,#111 0 50%,#d7c9a7 50% 100%);
  transform:scaleY(0);transform-origin:bottom;
  animation:loader-bars .5s cubic-bezier(.7,0,.2,1) forwards;
}
.page-loader::after{
  background:linear-gradient(135deg,#d7c9a7 0 50%,#111 50% 100%);
  clip-path:polygon(50% 0,100% 0,100% 100%,50% 100%);
  animation-delay:.05s;
}
.page-loader .pl-mark{
  position:relative;z-index:2;width:56px;height:56px;border-radius:14px;
  background:linear-gradient(135deg,#111 0 50%,#d7c9a7 50% 100%);
  box-shadow:0 20px 60px rgba(0,0,0,.35);
  animation:pl-mark .5s cubic-bezier(.2,.8,.2,1) both, pl-mark-fade .25s .3s forwards;
}
@keyframes loader-bars{
  0%{transform:scaleY(0)}
  50%{transform:scaleY(1)}
  100%{transform:scaleY(0);transform-origin:top}
}
@keyframes pl-mark{
  0%{opacity:0;transform:scale(.6) rotate(-30deg)}
  40%{opacity:1;transform:scale(1.1) rotate(0)}
  100%{opacity:1;transform:scale(1)}
}
@keyframes pl-mark-fade{to{opacity:0;transform:scale(.9)}}
@keyframes curtain-up{
  0%{transform:translateY(0)}
  100%{transform:translateY(-101%)}
}
.loaded .page-loader{display:none}

/* Intro entrance — applied while body has .preload or just-loaded class */
.intro-fade{opacity:0;transform:translateY(10px);filter:blur(4px);
  animation:intro-fade .5s cubic-bezier(.2,.8,.2,1) forwards}
@keyframes intro-fade{to{opacity:1;transform:none;filter:blur(0)}}

/* Header items stagger in */
body.just-loaded header.site .brand{animation:intro-fade .5s .5s cubic-bezier(.2,.8,.2,1) both}
body.just-loaded .nav-menu ul > li{opacity:0;transform:translateY(-8px);animation:intro-fade .4s cubic-bezier(.2,.8,.2,1) forwards}
body.just-loaded .nav-menu ul > li:nth-child(1){animation-delay:.55s}
body.just-loaded .nav-menu ul > li:nth-child(2){animation-delay:.6s}
body.just-loaded .nav-menu ul > li:nth-child(3){animation-delay:.65s}
body.just-loaded .nav-menu ul > li:nth-child(4){animation-delay:.7s}
body.just-loaded .nav-menu ul > li:nth-child(5){animation-delay:.75s}
body.just-loaded .nav-menu ul > li:nth-child(6){animation-delay:.8s}
body.just-loaded .nav-menu ul > li:nth-child(7){animation-delay:.85s}
body.just-loaded .nav-menu ul > li:nth-child(8){animation-delay:.9s}

/* Hero intro */
body.just-loaded .hero .eyebrow{opacity:0;animation:intro-fade .45s .55s cubic-bezier(.2,.8,.2,1) forwards}
body.just-loaded .hero .h1{
  opacity:0;
  animation:intro-h1 .6s .6s cubic-bezier(.2,.8,.2,1) forwards;
  background-size:220% 100%;
}
@keyframes intro-h1{
  0%{opacity:0;transform:translateY(20px) scale(.98);letter-spacing:.02em;filter:blur(6px)}
  100%{opacity:1;transform:none;letter-spacing:-.01em;filter:blur(0)}
}
body.just-loaded .hero .lede{opacity:0;animation:intro-fade .5s .75s cubic-bezier(.2,.8,.2,1) forwards}
body.just-loaded .hero-cta > *{opacity:0;animation:intro-pop .45s cubic-bezier(.2,.8,.2,1) forwards}
body.just-loaded .hero-cta > *:nth-child(1){animation-delay:.85s}
body.just-loaded .hero-cta > *:nth-child(2){animation-delay:.93s}
body.just-loaded .hero-cta > *:nth-child(3){animation-delay:1s}
@keyframes intro-pop{
  0%{opacity:0;transform:translateY(14px) scale(.92)}
  70%{transform:translateY(-2px) scale(1.02)}
  100%{opacity:1;transform:none}
}

/* Hero image reveal via clip-path */
body.just-loaded .hero-media .hero-image{
  clip-path:inset(0 0 100% 0);
  animation:hero-clip .7s .55s cubic-bezier(.7,0,.2,1) forwards, hero-float 7s 1.3s ease-in-out infinite;
}
@keyframes hero-clip{
  0%{clip-path:inset(0 0 100% 0);transform:scale(1.08)}
  100%{clip-path:inset(0 0 0 0);transform:scale(1)}
}

/* Hero orbs fade in */
body.just-loaded .hero::before{animation:float-a 14s ease-in-out infinite, orb-in .7s .5s ease-out both}
body.just-loaded .hero::after{animation:float-b 18s ease-in-out infinite, orb-in .7s .6s ease-out both}
@keyframes orb-in{0%{opacity:0}100%{opacity:.55}}

@media (prefers-reduced-motion: reduce){
  .page-loader,.page-loader::before,.page-loader::after,.page-loader .pl-mark{animation:none !important;display:none !important}
  body.just-loaded *{animation:none !important;opacity:1 !important;transform:none !important;filter:none !important;clip-path:none !important}
}
