:root{
  --bg:#f6faf9;
  --bg-2:#eef6f4;
  --surface:#ffffff;
  --paper:#faf7f1;
  --ink:#1a1f1d;
  --ink-2:#2f3a37;
  --muted:#5b6a66;
  --line:#e2e8e5;
  --line-2:#d8e1dd;

  --accent:#2f7a6b;
  --accent-ink:#174a42;
  --accent-soft:#d6ebe5;
  --accent-glow:rgba(47,122,107,.32);

  --warm:#c78a4a;
  --warm-soft:#f6e9d8;
  --cream:#f5ead6;

  --ok:#1f6b3e;
  --ok-bg:#e6f3ea;
  --err:#9a2222;
  --err-bg:#fbe8e8;
  --info-bg:#eef4f2;
  --focus:#8ec7bb;

  --radius:14px;
  --radius-sm:10px;
  --radius-lg:22px;

  --shadow:0 8px 28px rgba(20,40,36,.08);
  --shadow-soft:0 2px 10px rgba(20,40,36,.05);

  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:20px; --s-6:24px; --s-7:32px; --s-8:40px; --s-9:56px;

  --maxw:1180px;

  --ease-smooth:cubic-bezier(.2,.7,.2,1);
  --ease-warm:cubic-bezier(.33,1.2,.3,1);
  --ease-out:cubic-bezier(.22,.61,.36,1);
  --ease-in:cubic-bezier(.55,.06,.68,.19);

  --font:"Inter","Segoe UI","Helvetica Neue",Arial,sans-serif;
  --font-h:"Playfair Display","Georgia",serif;

  --scrollbar-w:0px;
  --header-h:72px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body.scroll-locked{
  overflow:hidden;
  padding-right:var(--scrollbar-w);
}
img{max-width:100%;height:auto;display:block}

a{color:var(--accent-ink);text-decoration:none}
:focus{outline:none}
:focus-visible{
  outline:3px solid var(--focus);
  outline-offset:2px;
  border-radius:6px;
}

main a.text-link,
.card p a:not(.btn),
.info p a:not(.btn),
.doc a:not(.btn),
.section-sub a:not(.btn),
.disclaimer a:not(.btn),
.note a:not(.btn),
.contact-card a:not(.btn){
  color:var(--accent-ink);
  background-image:linear-gradient(var(--accent),var(--accent));
  background-position:50% 100%;
  background-size:0% 1.5px;
  background-repeat:no-repeat;
  padding-bottom:1px;
  transition:background-size 320ms var(--ease-smooth), background-position 320ms var(--ease-smooth), color 200ms var(--ease-smooth);
}
main a.text-link:hover,
.card p a:not(.btn):hover,
.info p a:not(.btn):hover,
.doc a:not(.btn):hover,
.section-sub a:not(.btn):hover,
.disclaimer a:not(.btn):hover,
.note a:not(.btn):hover,
.contact-card a:not(.btn):hover{
  background-size:100% 1.5px;
  background-position:0% 100%;
  color:var(--accent);
}

.skip-link{
  position:absolute;
  top:var(--s-4);
  left:var(--s-4);
  background:var(--ink);
  color:#fff;
  padding:10px 14px;
  border-radius:8px;
  z-index:9999;
  transform:translateY(calc(-100% - 24px));
  opacity:0;
  pointer-events:none;
  transition:transform 220ms var(--ease-smooth), opacity 200ms var(--ease-smooth);
}
.skip-link:focus,.skip-link:focus-visible{
  transform:translateY(0);
  opacity:1;
  pointer-events:auto;
}

.wrap{
  width:100%;
  max-width:var(--maxw);
  margin:0 auto;
  padding-inline:clamp(1.25rem, 3vw, 1.75rem);
}

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.9);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.site-header .wrap{padding-inline:1.25rem}
@media (min-width: 961px){
  .site-header .wrap{padding-inline:clamp(1.5rem, 3vw, 1.75rem)}
}
.header-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  min-height:var(--header-h);
}
.brand{
  display:inline-flex;
  align-items:center;
  gap:12px;
  color:var(--ink);
  font-family:var(--font-h);
  font-weight:700;
  font-size:1.16rem;
  letter-spacing:.2px;
  transition:color 260ms var(--ease-smooth);
}
.brand:hover{color:var(--accent-ink)}
.brand-name{
  position:relative;
  background-image:linear-gradient(currentColor,currentColor);
  background-repeat:no-repeat;
  background-position:0 100%;
  background-size:0% 1.5px;
  transition:background-size 420ms var(--ease-smooth);
  padding-bottom:2px;
}
.brand:hover .brand-name{background-size:100% 1.5px}

.brand-mark{
  position:relative;
  width:44px;
  height:44px;
  border-radius:14px;
  background:
    radial-gradient(circle at 30% 26%, #ffffff 0%, #f4efe4 55%, #e6dcc4 100%);
  border:1px solid #e2d6bc;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.9),
    inset 0 -2px 0 rgba(140,100,40,.08),
    0 4px 10px rgba(80,48,12,.12);
  overflow:hidden;
  flex-shrink:0;
  transition:transform 520ms var(--ease-warm), box-shadow 420ms var(--ease-smooth), border-color 300ms var(--ease-smooth);
}
.brand-svg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:block;
}
.brand-svg .bm-drop{
  transform-origin:20px 13px;
  transition:transform 620ms var(--ease-warm);
}
.brand-svg .bm-caramel{
  transition:filter 520ms var(--ease-smooth);
}
.brand-svg .bm-sprinkle{
  transform-origin:20px 12px;
  transition:transform 580ms var(--ease-warm);
}
.brand-shine{
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  background:linear-gradient(115deg,
    rgba(255,255,255,0) 30%,
    rgba(255,255,255,.75) 48%,
    rgba(255,255,255,0) 66%);
  transform:translateX(-120%);
  transition:transform 720ms var(--ease-smooth);
  mix-blend-mode:screen;
}
.brand:hover .brand-mark{
  transform:rotate(-6deg) scale(1.08);
  border-color:#c78a4a;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -2px 0 rgba(140,100,40,.12),
    0 10px 24px rgba(199,138,74,.45);
}
.brand:hover .brand-shine{transform:translateX(120%)}
.brand:hover .brand-svg .bm-drop{transform:translateY(-1.2px) scale(1.08)}
.brand:hover .brand-svg .bm-caramel{filter:saturate(1.2) brightness(1.05)}
.brand:hover .brand-svg .bm-sprinkle{transform:rotate(-12deg)}
.brand:focus-visible{outline:none}
.brand:focus-visible .brand-mark{
  border-color:var(--accent);
  box-shadow:
    0 0 0 3px var(--focus),
    inset 0 1px 0 rgba(255,255,255,.95),
    0 10px 24px rgba(47,122,107,.35);
}

.nav-toggle{
  display:none;
  background:transparent;
  border:1px solid var(--line);
  border-radius:10px;
  padding:10px;
  cursor:pointer;
  width:44px;
  height:44px;
  align-items:center;
  justify-content:center;
  position:relative;
}
.nav-toggle .bars{
  position:relative;
  display:block;
  width:22px;
  height:16px;
}
.nav-toggle .bar{
  position:absolute;
  left:0;
  right:0;
  height:2px;
  background:var(--ink);
  border-radius:2px;
  transition:transform 320ms var(--ease-smooth), opacity 240ms var(--ease-smooth);
  transform-origin:center;
}
.nav-toggle .bar:nth-child(1){top:0}
.nav-toggle .bar:nth-child(2){top:7px}
.nav-toggle .bar:nth-child(3){top:14px}
.nav-toggle[aria-expanded="true"] .bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .bar:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle[aria-expanded="true"] .bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.main-nav{
  display:flex;
  align-items:center;
  gap:22px;
}
.main-nav a{
  position:relative;
  color:var(--ink-2);
  font-weight:500;
  font-size:.96rem;
  padding:8px 2px;
  transition:color 240ms var(--ease-smooth);
}
.main-nav a::after{
  content:"";
  position:absolute;
  left:50%;
  right:50%;
  bottom:2px;
  height:2px;
  background:var(--accent);
  border-radius:2px;
  transition:left 300ms var(--ease-smooth), right 300ms var(--ease-smooth);
}
.main-nav a:hover,
.main-nav a.is-active,
.main-nav a[aria-current="page"]{
  color:var(--accent);
}
.main-nav a:hover::after,
.main-nav a.is-active::after,
.main-nav a[aria-current="page"]::after{
  left:0;
  right:0;
}
.main-nav .cta{
  background:var(--ink);
  color:#fff;
  padding:0 18px;
  min-height:42px;
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  line-height:1;
  transition:background 240ms var(--ease-smooth), box-shadow 260ms var(--ease-smooth), transform 260ms var(--ease-smooth);
}
.main-nav .cta::after{display:none}
.main-nav .cta:hover{
  background:var(--accent-ink);
  color:#fff;
  box-shadow:0 0 0 4px var(--accent-glow), 0 10px 24px rgba(23,74,66,.28);
}

@media (max-width: 960px){
  .brand,.nav-toggle{position:relative;z-index:45}
  .nav-toggle{display:inline-flex}
  .main-nav{
    position:fixed;
    top:0;
    left:0;
    right:0;
    bottom:0;
    width:100%;
    height:100vh;
    height:100dvh;
    background:var(--paper);
    flex-direction:column;
    align-items:flex-start;
    justify-content:flex-start;
    gap:10px;
    padding:calc(var(--header-h) + 18px) 1.5rem 32px;
    overflow-y:auto;
    overscroll-behavior:contain;
    z-index:40;
    opacity:0;
    transform:translateY(-6px) scale(.98);
    pointer-events:none;
    transition:opacity 280ms var(--ease-smooth), transform 320ms var(--ease-smooth);
  }
  .main-nav.is-open{
    opacity:1;
    transform:none;
    pointer-events:auto;
  }
  .main-nav a{
    width:100%;
    padding:14px 4px;
    border-bottom:1px solid var(--line-2);
    font-size:1.05rem;
  }
  .main-nav a::after{display:none}
  .main-nav .cta{
    margin-top:14px;
    width:100%;
    justify-content:center;
    min-height:52px;
  }
}

/* Buttons */
.btn{
  position:relative;
  isolation:isolate;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:0 26px;
  line-height:1;
  font-weight:600;
  border-radius:999px;
  border:1px solid transparent;
  cursor:pointer;
  font-size:1rem;
  text-decoration:none;
  font-family:inherit;
  overflow:hidden;
  will-change:transform;
  transition:
    color 320ms var(--ease-smooth),
    border-color 320ms var(--ease-smooth),
    box-shadow 520ms var(--ease-smooth),
    transform 420ms var(--ease-warm);
}
.btn::before,
.btn::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  z-index:-1;
}
.btn::before{
  background-image:linear-gradient(180deg, transparent, transparent);
  transition:opacity 520ms var(--ease-smooth);
  opacity:0;
}
.btn::after{
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(255,255,255,.22), transparent 55%);
  opacity:0;
  transition:opacity 420ms var(--ease-smooth);
}
.btn:hover::after,
.btn:focus-visible::after{opacity:1}
.btn:active{transform:translateY(0) scale(.98);transition-duration:120ms}

a.btn,
.btn{
  background-size:auto;
  padding-bottom:0;
}

/* Primary */
.btn.btn-primary,
a.btn.btn-primary{
  background-color:#3a1a08;
  background-image:linear-gradient(180deg, #52270d 0%, #2b1405 100%);
  color:#ffffff;
  box-shadow:
    0 6px 18px rgba(30,14,4,.32),
    inset 0 1px 0 rgba(255,255,255,.18),
    inset 0 -1px 0 rgba(0,0,0,.25);
}
.btn.btn-primary::before,
a.btn.btn-primary::before{
  background-image:linear-gradient(180deg, #7a4219 0%, #1a0b02 100%);
}
.btn.btn-primary:hover,
.btn.btn-primary:focus-visible,
a.btn.btn-primary:hover,
a.btn.btn-primary:focus-visible{
  color:#ffffff;
  box-shadow:
    0 0 0 4px rgba(199,138,74,.42),
    0 22px 44px rgba(30,14,4,.5),
    inset 0 1px 0 rgba(255,255,255,.28),
    inset 0 -2px 0 rgba(0,0,0,.32);
  transform:translateY(-2px);
}
.btn.btn-primary:hover::before,
.btn.btn-primary:focus-visible::before,
a.btn.btn-primary:hover::before,
a.btn.btn-primary:focus-visible::before{opacity:1}

/* Strong (dark) */
.btn-strong{
  background-color:#1f2725;
  color:#fff;
  box-shadow:0 4px 14px rgba(0,0,0,.15);
}
.btn-strong::before{background-image:linear-gradient(180deg, #2d3a37, #0b1010)}
.btn-strong:hover,
.btn-strong:focus-visible{
  color:#fff;
  box-shadow:0 0 0 4px rgba(31,39,37,.28), 0 16px 32px rgba(0,0,0,.3);
  transform:translateY(-2px);
}
.btn-strong:hover::before,
.btn-strong:focus-visible::before{opacity:1}

/* Secondary (light) */
.btn-secondary{
  background-color:#ffffff;
  color:var(--ink);
  border-color:var(--line);
}
.btn-secondary::before{background-image:linear-gradient(180deg, #ffffff, var(--accent-soft))}
.btn-secondary:hover,
.btn-secondary:focus-visible{
  border-color:var(--accent);
  color:var(--accent-ink);
  box-shadow:0 0 0 3px var(--accent-glow), 0 10px 22px rgba(47,122,107,.18);
  transform:translateY(-1.5px);
}
.btn-secondary:hover::before,
.btn-secondary:focus-visible::before{opacity:1}

/* Ghost */
.btn-ghost{
  background-color:transparent;
  color:var(--ink);
  border-color:var(--line);
}
.btn-ghost::before{background-image:linear-gradient(180deg, var(--accent-soft), #ffffff)}
.btn-ghost:hover,
.btn-ghost:focus-visible{
  border-color:var(--accent);
  color:var(--accent-ink);
  box-shadow:0 8px 18px rgba(47,122,107,.14);
  transform:translateY(-1.5px);
}
.btn-ghost:hover::before,
.btn-ghost:focus-visible::before{opacity:1}

.btn[disabled],.btn[aria-disabled="true"]{opacity:.7;cursor:progress;transform:none}

/* Sections */
section{
  padding-block:clamp(44px,6vw,72px);
  border-bottom:1px solid var(--line);
}
section:last-of-type{border-bottom:none}
.section-head{max-width:720px;margin:0 0 28px}
.eyebrow{
  display:inline-block;
  font-size:.78rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--accent);
  background:var(--accent-soft);
  padding:5px 12px;
  border-radius:999px;
  margin-bottom:12px;
  font-weight:600;
}
h1,h2.section-title,.hero h1{
  font-family:var(--font-h);
  line-height:1.14;
  margin:0 0 10px;
  color:var(--ink);
}
h2.section-title{font-size:clamp(1.6rem,2.4vw,2.2rem)}
.section-sub{color:var(--muted);margin:0;max-width:70ch}

/* Hero */
.hero{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(900px 520px at 85% -10%, #dfeee9 0%, transparent 60%),
    radial-gradient(700px 420px at -10% 10%, #f1f8f5 0%, transparent 60%),
    linear-gradient(180deg,#ffffff 0%, #eef6f3 100%);
  border-bottom:1px solid var(--line);
}
.hero-inner{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:clamp(22px, 3vw, 40px);
  padding-block:clamp(40px,6vw,84px);
  align-items:center;
}
.hero h1{font-size:clamp(1.95rem, 3.6vw, 3rem)}
.hero p.lead{
  font-size:clamp(1rem,1.2vw,1.12rem);
  color:var(--ink-2);
  margin:8px 0 22px;
  max-width:58ch;
}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}
.hero-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px}
.tag{
  font-size:.82rem;
  background:#ffffff;
  border:1px solid var(--line);
  padding:6px 12px;
  border-radius:999px;
  color:var(--ink-2);
}
.hero-media{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:#ffffff;
  border:1px solid var(--line-2);
  box-shadow:var(--shadow);
  aspect-ratio:5/4;
}
.hero-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transform:translate3d(calc(var(--px,0) * 8px), calc(var(--py,0) * 8px), 0) scale(1.04);
  transition:transform 600ms var(--ease-smooth);
}
.hero-ribbon{
  position:absolute;
  left:18px;
  top:18px;
  background:var(--warm-soft);
  color:#6e4717;
  border:1px solid #e4cfa8;
  padding:6px 12px;
  border-radius:999px;
  font-size:.8rem;
  font-weight:600;
  letter-spacing:.05em;
}
@media (max-width: 860px){
  .hero-inner{grid-template-columns:1fr}
}

/* Grids */
.grid{display:grid;gap:clamp(16px, 2.4vw, 28px)}
.grid-2{grid-template-columns:repeat(auto-fit, minmax(280px, 1fr))}
.grid-3{grid-template-columns:repeat(auto-fit, minmax(260px, 1fr))}
.grid-4{grid-template-columns:repeat(auto-fit, minmax(220px, 1fr))}
.container-wrap{container-type:inline-size}

/* Cards */
.card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:24px;
  box-shadow:var(--shadow-soft);
  transition:transform 300ms var(--ease-smooth), box-shadow 300ms var(--ease-smooth), border-color 240ms var(--ease-smooth);
}
.card:hover{
  transform:translateY(-2px) rotate(-.2deg);
  box-shadow:0 12px 30px rgba(20,40,36,.1);
  border-color:#cadfd9;
  filter:saturate(1.05);
}
.card h3{margin:0 0 8px;font-size:1.1rem;font-family:var(--font-h);color:var(--ink)}
.card p{margin:0;color:var(--ink-2)}

/* Thematic bullets (sütlü tatlı: layered ramekin) */
.list-themed{list-style:none;margin:0;padding:0}
.list-themed li{
  position:relative;
  padding-left:38px;
  margin:10px 0;
  color:var(--ink-2);
}
.list-themed li::before{
  content:"";
  position:absolute;
  left:2px;
  top:6px;
  width:22px;
  height:16px;
  border-radius:7px 7px 9px 9px / 5px 5px 11px 11px;
  background:
    linear-gradient(#f5e7c9 0%, #f5e7c9 35%, #e5c07a 35%, #e5c07a 55%, #fffaf0 55%, #fffaf0 100%);
  border:1px solid #d4b676;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6), 0 3px 6px rgba(120,80,20,.15);
  transition:transform 320ms var(--ease-warm), filter 300ms var(--ease-smooth);
}
.list-themed li:nth-child(3n)::before{
  background:linear-gradient(#f7eadd 0%, #f7eadd 35%, #c78a4a 35%, #c78a4a 55%, #fffaf0 55%, #fffaf0 100%);
  border-color:#b5773b;
}
.list-themed li:nth-child(4n)::before{
  background:linear-gradient(#e8f2ee 0%, #e8f2ee 35%, #2f7a6b 35%, #2f7a6b 55%, #fffaf0 55%, #fffaf0 100%);
  border-color:#1f5a4e;
}
.list-themed li:hover::before{
  transform:rotate(-6deg) scale(1.08);
  filter:saturate(1.15);
}

/* Cat (category) card */
.cat{
  display:flex;
  flex-direction:column;
  gap:10px;
  background:linear-gradient(180deg,#ffffff,#f0f7f4);
  border:1px solid #dbe6e1;
  border-radius:var(--radius);
  padding:22px;
  transition:transform 300ms var(--ease-smooth), border-color 240ms var(--ease-smooth), box-shadow 300ms var(--ease-smooth);
}
.cat:hover{
  transform:translateY(-2px);
  border-color:var(--accent);
  box-shadow:0 10px 26px rgba(47,122,107,.15);
}
.cat .name{font-family:var(--font-h);font-size:1.12rem;color:var(--ink)}
.cat .desc{color:var(--ink-2);font-size:.96rem;margin:0}
.cat .meta{display:flex;gap:8px;flex-wrap:wrap}
.cat .meta span{
  background:#fff;
  border:1px solid var(--line);
  padding:4px 10px;
  border-radius:999px;
  font-size:.8rem;
  color:var(--muted);
}
.cat-fig{
  aspect-ratio:4/3;
  border-radius:var(--radius-sm);
  overflow:hidden;
  background:#f2f1ee;
  margin-bottom:6px;
}
.cat-fig img{width:100%;height:100%;object-fit:cover;transition:transform 520ms var(--ease-smooth), filter 320ms var(--ease-smooth)}
.cat:hover .cat-fig img{transform:scale(1.04);filter:saturate(1.08)}

/* Steps */
.steps{display:grid;gap:clamp(14px, 2vw, 22px)}
.step{
  position:relative;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:22px 22px 22px 76px;
  box-shadow:var(--shadow-soft);
}
.step::before{
  content:counter(step);
  counter-increment:step;
  position:absolute;
  left:18px;
  top:18px;
  width:42px;
  height:42px;
  border-radius:14px;
  background:linear-gradient(160deg,var(--accent),var(--accent-ink));
  color:#fff;
  font-weight:700;
  font-family:var(--font-h);
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 10px var(--accent-glow);
}
.steps{counter-reset:step}
.step h3{margin:0 0 6px;font-family:var(--font-h);font-size:1.08rem;color:var(--ink)}
.step p{margin:0;color:var(--ink-2)}

/* Prices */
.prices{display:grid;gap:14px;grid-template-columns:repeat(auto-fit, minmax(220px, 1fr))}
.price{
  background:linear-gradient(180deg,#ffffff,#eef6f3);
  border:1px solid #d6e5df;
  border-radius:var(--radius);
  padding:20px;
  transition:transform 300ms var(--ease-smooth), box-shadow 300ms var(--ease-smooth);
}
.price:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.price .label{font-size:.85rem;color:var(--muted);margin-bottom:6px}
.price .amount{font-family:var(--font-h);font-size:1.35rem;color:var(--ink)}
.price .note{font-size:.86rem;color:var(--muted);margin-top:8px}

.disclaimer{
  margin-top:18px;
  font-size:.92rem;
  color:var(--ink-2);
  background:var(--warm-soft);
  border:1px solid #e6d0a8;
  padding:14px 16px;
  border-radius:var(--radius-sm);
}

/* FAQ grid-template-rows expand */
.faq{display:grid;gap:10px}
.faq-item{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  overflow:hidden;
  transition:border-color 240ms var(--ease-smooth), background 240ms var(--ease-smooth);
}
.faq-item.open{
  border-color:#cfe1dc;
  background:#f7fbf9;
}
.faq-q{
  all:unset;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  width:100%;
  cursor:pointer;
  padding:14px 16px;
  font-weight:600;
  color:var(--ink);
  font-family:inherit;
  font-size:1rem;
}
.faq-q:focus-visible{outline:3px solid var(--focus);outline-offset:-3px;border-radius:var(--radius-sm)}
.faq-icon{
  width:16px;
  height:16px;
  position:relative;
  flex-shrink:0;
}
.faq-icon::before,.faq-icon::after{
  content:"";
  position:absolute;
  background:var(--accent);
  border-radius:2px;
  transition:transform 320ms var(--ease-smooth), opacity 260ms var(--ease-smooth);
}
.faq-icon::before{left:0;right:0;top:7px;height:2px}
.faq-icon::after{top:0;bottom:0;left:7px;width:2px}
.faq-item.open .faq-icon::after{transform:scaleY(0)}
.faq-a{
  display:grid;
  grid-template-rows:0fr;
  transition:grid-template-rows 380ms var(--ease-smooth);
}
.faq-a-inner{overflow:hidden;min-height:0}
.faq-a-inner > div{padding:0 16px 14px;color:var(--ink-2)}
.faq-item.open .faq-a{grid-template-rows:1fr}

/* Planner */
.planner{
  background:linear-gradient(180deg,#ffffff,#eaf3f0);
  border:1px solid #cce0d9;
  border-radius:var(--radius);
  padding:clamp(18px, 3vw, 26px);
  box-shadow:var(--shadow-soft);
  display:grid;
  grid-template-columns:minmax(0, 1.05fr) minmax(0, .95fr);
  gap:clamp(16px, 2.4vw, 28px);
  align-items:stretch;
}
.planner > *{min-width:0}
@media (max-width: 860px){
  .planner{
    grid-template-columns:1fr;
    gap:16px;
  }
  .planner .result{order:2}
}
.planner .group{margin-bottom:14px}
.planner label{display:block;font-size:.9rem;color:var(--ink-2);margin-bottom:6px;font-weight:600}
.planner select,.planner input[type="number"],.planner input[type="text"]{
  width:100%;
  padding:10px 12px;
  border-radius:10px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--ink);
  font-size:1rem;
  font-family:inherit;
  transition:border-color 240ms var(--ease-smooth), box-shadow 240ms var(--ease-smooth);
}
.planner select:focus,
.planner input:focus,
.planner select:focus-visible,
.planner input:focus-visible{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 1px var(--accent);
}
.slider-row{display:flex;align-items:center;gap:12px}
.slider-row input[type="range"]{flex:1;accent-color:var(--accent)}
.slider-row .val{min-width:40px;text-align:right;font-weight:700;color:var(--accent-ink);font-family:var(--font-h)}

.switch{
  --sw-w:48px;
  --sw-h:28px;
  --sw-pad:3px;
  --sw-knob:calc(var(--sw-h) - var(--sw-pad) * 2);
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:12px;
  cursor:pointer;
  user-select:none;
  padding:2px 0;
  line-height:1.4;
  min-width:0;
}
.switch-wrap{
  position:relative;
  display:inline-block;
  width:var(--sw-w);
  height:var(--sw-h);
  flex:0 0 var(--sw-w);
  vertical-align:middle;
}
.switch-wrap input[type="checkbox"]{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  margin:0;
  opacity:0;
  cursor:pointer;
  z-index:2;
}
.switch-track{
  position:absolute;
  inset:0;
  border-radius:999px;
  background:#cdd8d5;
  box-shadow:inset 0 1px 2px rgba(0,0,0,.12);
  transition:background-color 320ms var(--ease-smooth), box-shadow 320ms var(--ease-smooth);
  z-index:0;
}
.switch-knob{
  position:absolute;
  top:var(--sw-pad);
  left:var(--sw-pad);
  width:var(--sw-knob);
  height:var(--sw-knob);
  background:#ffffff;
  border-radius:50%;
  box-shadow:0 2px 6px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.9);
  pointer-events:none;
  z-index:1;
  transform:translateX(0);
  transition:transform 360ms var(--ease-warm), box-shadow 320ms var(--ease-smooth), background-color 240ms var(--ease-smooth);
}
.switch-wrap input[type="checkbox"]:checked ~ .switch-track{
  background:var(--accent);
  box-shadow:inset 0 1px 2px rgba(0,0,0,.18), 0 0 0 0 rgba(47,122,107,.12);
}
.switch-wrap input[type="checkbox"]:checked ~ .switch-knob{
  transform:translateX(calc(var(--sw-w) - var(--sw-knob) - var(--sw-pad) * 2));
  box-shadow:0 2px 8px rgba(20,60,50,.3), inset 0 1px 0 rgba(255,255,255,.95);
}
.switch-wrap input[type="checkbox"]:focus-visible ~ .switch-track{
  outline:3px solid var(--focus);
  outline-offset:2px;
}
.switch-wrap input[type="checkbox"]:disabled{cursor:not-allowed}
.switch-wrap input[type="checkbox"]:disabled ~ .switch-track{opacity:.7}
.switch-wrap input[type="checkbox"]:disabled ~ .switch-knob{opacity:.85}
.switch-wrap:hover input[type="checkbox"]:not(:disabled):not(:checked) ~ .switch-track{background:#b8c5c1}
.switch-wrap:active input[type="checkbox"]:not(:disabled) ~ .switch-knob{width:calc(var(--sw-knob) + 3px)}

.result{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:10px;
  min-width:0;
}
.result .label{font-size:.86rem;color:var(--muted)}
.result .range{
  font-family:var(--font-h);
  font-size:clamp(1.25rem, 1.2rem + 1.2vw, 1.8rem);
  color:var(--ink);
  line-height:1.2;
  overflow-wrap:anywhere;
  word-break:break-word;
}
.result small{color:var(--muted);display:block}

/* Contact cards */
.contact-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:20px;
  display:flex;
  gap:14px;
  align-items:flex-start;
  min-width:0;
  transition:transform 300ms var(--ease-smooth), border-color 240ms var(--ease-smooth), box-shadow 300ms var(--ease-smooth);
}
.contact-card:hover{transform:translateY(-2px);border-color:#cfe1dc;box-shadow:var(--shadow)}
.contact-card .ico{
  width:44px;
  height:44px;
  border-radius:12px;
  background:var(--accent-soft);
  color:var(--accent-ink);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.contact-card > div{
  flex:1 1 auto;
  min-width:0;
}
.contact-card h3{margin:0 0 4px;font-family:var(--font-h);font-size:1.05rem;color:var(--ink)}
.contact-card p{margin:0;color:var(--ink-2);overflow-wrap:anywhere;word-break:break-word}
.contact-card a{overflow-wrap:anywhere;word-break:break-word}

/* Form */
.form-grid{
  display:grid;
  grid-template-columns:1fr 1.6fr;
  gap:clamp(18px, 3vw, 32px);
  align-items:start;
}
@media (max-width: 860px){
  .form-grid{grid-template-columns:1fr}
}
.form-aside{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:22px;
  box-shadow:var(--shadow-soft);
  position:sticky;
  top:calc(var(--header-h) + 16px);
}
.form-aside h3{margin:0 0 10px;font-family:var(--font-h);font-size:1.08rem}
.form-aside ul{margin:0;padding-left:1.2rem;color:var(--ink-2)}
.form-aside li{margin:6px 0}

.form{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:26px;
  box-shadow:var(--shadow-soft);
  display:grid;
  gap:16px;
}
.form .row{display:grid;gap:16px;grid-template-columns:repeat(auto-fit, minmax(220px, 1fr))}
.form label{font-weight:600;font-size:.92rem;color:var(--ink-2)}
.form .req{color:var(--err);margin-left:4px}
.form .opt{color:var(--muted);font-weight:400;margin-left:6px;font-size:.86rem}
.form input,.form textarea{
  width:100%;
  padding:12px 14px;
  border-radius:10px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--ink);
  font-size:1rem;
  font-family:inherit;
  transition:border-color 240ms var(--ease-smooth), box-shadow 240ms var(--ease-smooth);
}
.form input:focus,
.form textarea:focus,
.form input:focus-visible,
.form textarea:focus-visible{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 1px var(--accent);
}
.form textarea{min-height:150px;resize:vertical}
.form .hint{font-size:.86rem;color:var(--muted)}
.form .consent{display:flex;align-items:flex-start;gap:10px;font-size:.94rem;color:var(--ink-2);line-height:1.5}
.form .consent input{width:18px;height:18px;margin-top:3px;accent-color:var(--accent)}
.form .hp{position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;overflow:hidden}

.form-status{
  max-height:0;
  opacity:0;
  padding:0;
  overflow:hidden;
  transform:translateY(-4px);
  border-radius:10px;
  font-size:.95rem;
  background:var(--info-bg);
  color:var(--ink-2);
  transition:max-height 320ms var(--ease-smooth), opacity 260ms var(--ease-smooth), transform 300ms var(--ease-smooth), padding 300ms var(--ease-smooth), color 240ms var(--ease-smooth), background-color 240ms var(--ease-smooth);
}
.form-status:not(:empty){
  max-height:8em;
  opacity:1;
  transform:none;
  padding:12px 16px;
}
.form-status.ok{background:var(--ok-bg);color:var(--ok);border-left:3px solid var(--ok)}
.form-status.err{background:var(--err-bg);color:var(--err);border-left:3px solid var(--err)}

/* Info / long read */
.info{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:22px;
}
.info h3{margin:0 0 8px;font-family:var(--font-h);font-size:1.1rem;color:var(--ink)}
.info p{margin:0 0 8px;color:var(--ink-2)}
.info ul{margin:0;padding-left:0;list-style:none}

.longread{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(16px, 2.4vw, 28px)}
@media (max-width: 860px){.longread{grid-template-columns:1fr}}
.longread h3{font-family:var(--font-h);margin-top:0}
.longread p{color:var(--ink-2)}

/* Chips */
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.chip{
  background:#fff;
  border:1px solid var(--line);
  padding:6px 12px;
  border-radius:999px;
  font-size:.86rem;
  color:var(--ink-2);
}

/* Key-value */
.kv{display:grid;grid-template-columns:180px 1fr;gap:8px 16px}
@media (max-width: 560px){.kv{grid-template-columns:1fr}}
.kv dt{color:var(--muted)}
.kv dd{margin:0;color:var(--ink)}

/* Doc pages */
.page-intro{padding-block:clamp(28px,4vw,48px)}
.doc h1{font-family:var(--font-h);margin:0 0 10px;font-size:clamp(1.7rem,2.6vw,2.2rem)}
.doc h2{font-family:var(--font-h);margin:28px 0 8px;font-size:1.3rem;color:var(--ink)}
.doc h3{font-family:var(--font-h);margin:18px 0 6px;font-size:1.1rem;color:var(--ink)}
.doc p,.doc li{color:var(--ink-2)}
.doc ul{padding-left:1.25rem}
.doc .updated{color:var(--muted);font-size:.92rem;margin-bottom:16px}
.doc .box{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin:12px 0}

/* 404 */
.e404{
  min-height:70vh;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding-block:40px;
}
.e404 h1{font-family:var(--font-h);font-size:clamp(2.2rem,5vw,3.6rem);margin:0 0 10px}
.e404 p{color:var(--ink-2);max-width:48ch;margin:0 auto 20px}
.e404-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}

/* Footer */
.site-footer{
  background:#101814;
  color:#cad3cf;
  padding:44px 0 22px;
  margin-top:0;
}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:24px}
@media (max-width: 860px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width: 520px){.footer-grid{grid-template-columns:1fr}}
.site-footer h4{
  color:#fff;
  font-family:var(--font-h);
  font-size:1.05rem;
  margin:0 0 10px;
}
.site-footer p{color:#a7b3ae;margin:0;font-size:.94rem}
.site-footer a{
  color:#cad3cf;
  display:block;
  margin:6px 0;
  font-size:.94rem;
  transition:color 240ms var(--ease-smooth);
}
.site-footer a:hover{color:#fff}
.foot-bottom{
  border-top:1px solid #2a3631;
  margin-top:26px;
  padding-top:16px;
  font-size:.86rem;
  color:#8c9792;
  text-align:center;
}
.foot-bottom p{margin:0;text-align:center}
.foot-reopen{
  background:#2a3631;
  color:#e6ede9;
  border:1px solid #354440;
  padding:10px 16px;
  border-radius:999px;
  cursor:pointer;
  font-size:.9rem;
  transition:background 240ms var(--ease-smooth), border-color 240ms var(--ease-smooth);
}
.foot-reopen:hover{background:#34423d;border-color:#4a5a54}

/* Cookie banner */
.cookie-banner[hidden],.cookie-settings[hidden]{display:none !important}
.cookie-banner{
  position:fixed;
  left:clamp(12px, 2vw, 24px);
  right:clamp(12px, 2vw, 24px);
  bottom:clamp(12px, 2vw, 24px);
  z-index:60;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:0 18px 44px rgba(16,32,28,.2);
  padding:20px;
  max-width:860px;
  margin:0 auto;
  opacity:0;
  transform:translateY(10px) scale(.98);
  transition:opacity 300ms var(--ease-smooth), transform 320ms var(--ease-smooth);
}
.cookie-banner.visible{opacity:1;transform:none}
.cookie-banner h2{margin:0 0 6px;font-family:var(--font-h);font-size:1.08rem}
.cookie-banner p{margin:0 0 12px;color:var(--ink-2);font-size:.94rem}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-actions .btn{min-height:44px;padding:0 20px;font-size:.94rem}

.cookie-settings{
  position:fixed;
  inset:0;
  z-index:70;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(10,20,18,.5);
  opacity:0;
  pointer-events:none;
  transition:opacity 260ms var(--ease-smooth);
}
.cookie-settings.visible{opacity:1;pointer-events:auto}
.cookie-settings-dialog{
  width:min(520px, 92vw);
  background:#fff;
  border-radius:var(--radius);
  padding:24px;
  box-shadow:0 24px 60px rgba(10,20,18,.28);
  transform:translateY(10px) scale(.98);
  transition:transform 320ms var(--ease-smooth);
  max-height:85vh;
  overflow-y:auto;
}
.cookie-settings.visible .cookie-settings-dialog{transform:none}
.cookie-settings-dialog h2{margin:0 0 6px;font-family:var(--font-h);font-size:1.2rem}
.cookie-settings-dialog p.lede{margin:0 0 14px;color:var(--ink-2);font-size:.95rem}
.cookie-row{
  display:flex;
  align-items:center;
  gap:14px;
  padding:12px 0;
  border-bottom:1px dashed var(--line);
}
.cookie-row:last-child{border-bottom:none}
.cookie-row .meta{flex:1}
.cookie-row .name{font-weight:600;color:var(--ink)}
.cookie-row .desc{font-size:.88rem;color:var(--muted);margin-top:2px}
.cookie-settings-foot{display:flex;gap:10px;justify-content:flex-end;margin-top:16px;flex-wrap:wrap}

/* Site map cards */
.map-group-title{
  font-family:var(--font-h);
  font-size:1.12rem;
  margin:24px 0 10px;
  color:var(--ink);
}

/* Reveal */
[data-reveal]{
  opacity:0;
  transform:translateY(20px);
  transition:opacity 700ms var(--ease-out), transform 700ms var(--ease-out), filter 700ms var(--ease-out);
}
[data-reveal="right"]{transform:translateX(-20px)}
[data-reveal="left"]{transform:translateX(20px)}
[data-reveal="zoom"]{transform:scale(.96)}
[data-reveal].is-visible{opacity:1;transform:none;filter:none}

/* Intro (loaded stagger) */
body:not(.is-loaded) .intro-item{opacity:0;transform:translateY(10px)}
.intro-item{
  opacity:1;
  transform:none;
  animation:stev-intro 680ms var(--ease-warm) both;
  animation-delay:var(--d, 0ms);
}
@keyframes stev-intro{
  0%{opacity:0;transform:translateY(14px) scale(.98);filter:blur(2px)}
  60%{filter:blur(0)}
  100%{opacity:1;transform:none;filter:none}
}
body:not(.is-loaded) .intro-item{animation:none}

/* Numeric tick */
.num-tick{font-variant-numeric:tabular-nums}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  [data-reveal]{opacity:1 !important;transform:none !important;filter:none !important}
  body:not(.is-loaded) .intro-item{opacity:1 !important;transform:none !important}
}

/* Utility */
.center{text-align:center}
.flex-wrap{display:flex;flex-wrap:wrap;gap:10px}
.mt-2{margin-top:10px}
.mt-4{margin-top:20px}
.mt-6{margin-top:30px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;border:0;padding:0}
