/* =============================
   KAVA ATELIER — повністю новий стиль
   Інша типографіка, палітра, компоненти
   ============================= */

/* Reset */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
img{max-width:100%;display:block;height:auto}
button,input,textarea,select{font:inherit}
:focus-visible{outline:2px solid #6a4d2f;outline-offset:2px}
.sr-only{position:absolute;clip-path:inset(50%);width:1px;height:1px;overflow:hidden;white-space:nowrap}

/* Tokens */
:root{
  --bg:#FAF6F1;
  --ink:#261E19;
  --muted:#6E6159;
  --panel:#FFFFFF;
  --line:#E7DED6;

  --a:#CF8E52;            /* caramel */
  --a-ink:#2E1E0F;
  --b:#7F5539;            /* mocha */
  --c:#E2B659;            /* honey */

  --rad:18px;
  --shadow:0 12px 40px rgba(38,30,25,.08);

  --h:'Playfair Display', serif;
  --b:'Nunito Sans', system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, 'Helvetica Neue', Arial;
}

/* Base */
body.site{
  background:
    radial-gradient(900px 500px at 10% -10%, rgba(207,142,82,.12), transparent 40%),
    radial-gradient(800px 520px at 110% 0%, rgba(126,85,57,.10), transparent 42%),
    var(--bg);
  color:var(--ink);
  font-family:var(--b);
  line-height:1.65;
}

/* Link style */
a{color:inherit}
a:hover{opacity:.9}

/* Skip */
.skip{position:absolute;left:-9999px}
.skip:focus{left:12px;top:10px;background:#000;color:#fff;padding:.5rem .8rem;border-radius:8px;z-index:10}

/* Topbar */
.topbar{
  position:sticky;top:0;z-index:40;
  backdrop-filter:saturate(160%) blur(8px);
  background:color-mix(in srgb, var(--bg), transparent 10%);
  border-bottom:1px solid var(--line);
}
.topbar__inner{max-width:1180px;margin:0 auto;padding:.9rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand{display:inline-flex;align-items:center;gap:.6rem;text-decoration:none}
.brand__mark{display:inline-grid;place-items:center;width:32px;height:32px;border-radius:10px;background:linear-gradient(120deg,var(--c),var(--a));box-shadow:var(--shadow)}
.brand__name{font-family:var(--h);font-weight:800;letter-spacing:.03em}

.navbtn{display:none;position:relative;width:44px;height:44px;border:1px solid var(--line);border-radius:12px;background:var(--panel)}
.navbtn__bar,.navbtn__bar::before,.navbtn__bar::after{content:"";position:absolute;left:50%;width:18px;height:2px;background:var(--ink);transform:translateX(-50%)}
.navbtn__bar{top:50%}
.navbtn__bar::before{top:-6px}
.navbtn__bar::after{top:6px}

.nav{}
.nav__list{display:flex;gap:1rem;list-style:none}
.nav__list a{display:inline-block;padding:.5rem .8rem;border-radius:999px;text-decoration:none;border:1px solid transparent}
.nav__list a:hover{background:color-mix(in srgb, var(--c), transparent 86%);border-color:color-mix(in srgb, var(--c), transparent 70%)}
.nav__cta a{background:linear-gradient(120deg,var(--c),var(--a));border:none;color:#1b1209;font-weight:700}

/* Hero */
.hero{padding:clamp(1.2rem,3vw,2rem) 1rem 1rem}
.hero__grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center}
.overline{text-transform:uppercase;letter-spacing:.18em;color:var(--muted);font-weight:700;font-size:.75rem}
.display{font-family:var(--h);font-weight:800;line-height:1.1;font-size:clamp(2rem,5vw,3.4rem);margin:.5rem 0 1rem}
.accent{background:linear-gradient(90deg,var(--c),var(--a));-webkit-background-clip:text;background-clip:text;color:transparent}
.lede{color:var(--muted);max-width:60ch}
.btns{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:1rem}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:.8rem 1.1rem;border-radius:14px;border:1px solid var(--line);text-decoration:none;transition:transform .15s ease, box-shadow .2s ease}
.btn--fill{background:linear-gradient(120deg,var(--c),var(--a));color:#1b1209;border:none;box-shadow:var(--shadow)}
.btn--ghost{background:var(--panel)}
.btn:hover{transform:translateY(-2px)}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1rem}
.stats dt{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}
.stats dd{font-family:var(--h);font-weight:800;font-size:1.5rem}

.hero__media{position:relative;display:grid;gap:1rem}
.hero__media img{border-radius:20px;border:1px solid var(--line);box-shadow:var(--shadow)}
.floater{position:absolute;right:-14%;bottom:-10%;width:50%;transform:rotate(3deg)}
@media (max-width:1000px){.floater{position:static;width:100%;transform:none}}

/* Sections */
.section{padding:1rem 0 2rem}
.section--alt{background:color-mix(in srgb, var(--panel), var(--bg) 60%)}
.section__head{max-width:1180px;margin:2rem auto 1rem;padding:0 1rem}
.section__head h2{font-family:var(--h);font-size:clamp(1.6rem,3.2vw,2.2rem)}
.muted{color:var(--muted)}

.cards{max-width:1180px;margin:0 auto;display:grid;gap:1rem;grid-template-columns:repeat(12,1fr);padding:0 1rem;list-style:none}
.card{grid-column:span 4;background:var(--panel);border:1px solid var(--line);border-radius:var(--rad);box-shadow:var(--shadow);overflow:hidden;display:grid}
.card__media img{aspect-ratio:4/3;object-fit:cover}
.card__body{padding:1rem}
.pill{display:inline-block;margin-top:.4rem;padding:.2rem .6rem;border-radius:999px;background:color-mix(in srgb, var(--c), transparent 80%);border:1px solid color-mix(in srgb, var(--c), transparent 60%);font-size:.85rem}

.timeline{max-width:1180px;margin:0 auto;display:grid;gap:1rem;padding:0 1rem}
.slot{background:var(--panel);border:1px dashed var(--line);border-radius:var(--rad);padding:1rem}
.slot__time{font-weight:800;color:var(--b)}
.slot__title{font-family:var(--h);margin:.2rem 0 .3rem}

.banner{max-width:1180px;margin:0 auto;border:1px solid var(--line);border-radius:24px;background:linear-gradient(120deg, color-mix(in srgb, var(--c), white 60%), color-mix(in srgb, var(--a), white 60%));display:grid;grid-template-columns:1.2fr .8fr;gap:1rem;align-items:center;padding:1.1rem 1.2rem;box-shadow:var(--shadow)}
.banner__copy h3{font-family:var(--h);font-size:1.6rem}
.banner__media img{border-radius:16px;border:1px solid var(--line);box-shadow:var(--shadow)}

.section--contact{padding-bottom:3rem}
.formgrid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:0 1rem}
.info{background:var(--panel);border:1px solid var(--line);border-radius:var(--rad);padding:1rem}
.micro{color:var(--muted);font-size:.9rem;margin-top:.6rem}
.form{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.field{display:grid;gap:.3rem}
.field>span{font-size:.9rem;color:var(--muted)}
.field input,.field textarea{border:1px solid var(--line);background:var(--panel);border-radius:12px;padding:.9rem;color:var(--ink)}
.field input:focus,.field textarea:focus{border-color:var(--a);box-shadow:0 0 0 4px color-mix(in srgb, var(--a), transparent 82%)}
.field--full{grid-column:1/-1}
.hp{position:absolute;left:-9999px}

/* Footer */
.footer{border-top:1px solid var(--line);padding:1.2rem 1rem}
.footer__grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:1rem;align-items:start}
.brand--sm .brand__mark{transform:scale(.9)}
.flinks{list-style:none;display:grid;gap:.4rem}
.flinks a{text-decoration:none}
.social{list-style:none;display:flex;gap:.6rem;justify-content:flex-end;flex-wrap:wrap}
.social a{border:1px solid var(--line);padding:.35rem .55rem;border-radius:999px;text-decoration:none}
.copy{text-align:center;color:var(--muted);margin-top:1rem}

/* Reveal */
.reveal{opacity:0;transform:translateY(10px);transition:opacity .35s ease, transform .35s ease}
.reveal[data-in]{opacity:1;transform:none}

/* Responsive */
@media (max-width:960px){
  .hero__grid{grid-template-columns:1fr}
  .formgrid{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
  .social{justify-content:flex-start}
}
@media (max-width:760px){
  .navbtn{display:inline-block}
  .nav{display:none;position:absolute;right:1rem;top:58px;background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow)}
  .nav__list{flex-direction:column;padding:.4rem}
  .nav__list li{border-bottom:1px dashed var(--line)}
  .nav__list li:last-child{border-bottom:none}
}