
/* Know Yoga – Vuori‑inspired, clean + airy design
   NOTE: Original Vuori assets, logos, and code are NOT used.
   Adjust brand tokens below to quickly re‑skin.
*/
:root{
  --bg:#f6f6f4;          /* warm off‑white */
  --bg-soft:#fafaf8;     /* panels / sections */
  --text:#222222;        /* charcoal */
  --muted:#666a6d;       /* cool gray */
  --border:#e7e5e0;      /* subtle lines */
  --card:#ffffff;        /* cards */
  --accent:#7A5C3A;      /* warm earth (buttons/links) */
  --accent-2:#6C8E7B;    /* muted sage (hover) */
  --radius:14px;
  --shadow: 0 8px 28px rgba(0,0,0,.06);
  --maxw: 1200px;
  --gap: 18px;
  --focus: 0 0 0 2px #000, 0 0 0 6px rgba(0,0,0,.12);
}
/* Optional dark mode */
[data-theme="dark"]{
  --bg:#0f1214;
  --bg-soft:#111418;
  --text:#e9edf1;
  --muted:#aeb4bb;
  --border:#1f2429;
  --card:#12161a;
  --shadow: 0 8px 28px rgba(0,0,0,.45);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font: 16px/1.6 ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  background: var(--bg);
  color: var(--text);
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
.container{max-width:var(--maxw); margin:0 auto; padding:0 20px}

/* ----- Header / Nav (transparent over hero) ----- */
.header{
  position:sticky; top:0; z-index:50;
  backdrop-filter: saturate(180%) blur(10px);
  background: color-mix(in oklab, var(--bg) 70%, transparent);
  border-bottom: 1px solid var(--border);
}
.nav{display:flex; align-items:center; justify-content:space-between; padding:12px 0}
.brand{display:flex; align-items:center; gap:10px; font-weight:800; letter-spacing:.4px}
.brand-mark{
  width:34px; height:34px; border-radius:8px;
  background: conic-gradient(from 230deg, var(--accent) 0 40%, var(--accent-2) 40% 80%, #000 80%);
  box-shadow: var(--shadow);
}
.nav ul{display:flex; gap:14px; list-style:none; margin:0; padding:0}
.nav a{padding:10px 12px; border-radius:10px}
.nav a.active, .nav a:focus-visible{outline:none; box-shadow: var(--focus)}
.nav-toggle{display:none; background:none; border:1px solid var(--border); padding:8px 12px; border-radius:10px}

/* Mobile menu */
@media(max-width: 900px){
  .nav ul{display:none; position:absolute; left:16px; right:16px; top:64px; padding:12px; background:var(--card); border-radius:14px; box-shadow:var(--shadow); border:1px solid var(--border)}
  .nav ul.open{display:block}
  .nav-toggle{display:block}
}

/* ----- Hero (big, lifestyle‑ready) ----- */
.hero{
  position:relative;
  display:grid; grid-template-columns: 1.1fr .9fr; gap:36px; align-items:center;
  padding: 60px 0 36px;
}
.hero .media{
  border-radius: 18px; overflow:hidden; border:1px solid var(--border);
  box-shadow: var(--shadow);
  aspect-ratio: 4/3;
  background: linear-gradient( to bottom right, #efede9, #e3e0db );
  display:grid; place-items:center;
  color:#a1988e;
}
.hero h1{ font-family: "Fraunces", ui-serif, Georgia, serif; font-weight:800; font-size: clamp(36px, 5vw, 62px); line-height:1.02; margin:0 0 10px }
.hero p{ color: var(--muted); margin:0 0 22px; font-size: clamp(16px, 1.6vw, 18px) }

.btn{
  display:inline-block; padding:12px 18px; border-radius: 999px;
  background: var(--text); color: #fff; border: 1px solid #000;
  transition: transform .12s ease, opacity .12s ease;
}
.btn:hover{transform: translateY(-1px)}
.btn.ghost{ background: transparent; color: var(--text); border: 1px solid var(--text) }

/* ----- Section blocks ----- */
section{ padding: 56px 0 }
.section-title{ font-family:"Fraunces", ui-serif, Georgia, serif; font-weight:800; font-size: clamp(26px, 3vw, 36px); margin:0 0 8px }
.section-sub{ color: var(--muted); margin:0 0 24px }

/* Feature cards (minimal) */
.cards{ display:grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap) }
.card{
  background: var(--card); border:1px solid var(--border); border-radius: 16px;
  padding: 18px; box-shadow: var(--shadow);
}
.card h3{ margin: 0 0 6px; font-size: 18px }
.card p{ color: var(--muted); margin: 0 }

/* Mosaic (lookbook vibe) */
.mosaic{ display:grid; gap: var(--gap); grid-template-columns: 2fr 1fr 1fr; }
.mosaic .tile{ border-radius:16px; overflow:hidden; border:1px solid var(--border); background: #eceae6; aspect-ratio: 3/4 }
.mosaic .tile.tall{ grid-row: span 2; aspect-ratio: auto }
@media(max-width: 1000px){ .mosaic{ grid-template-columns: 1fr 1fr } }
@media(max-width: 680px){ .mosaic{ grid-template-columns: 1fr } }

/* People list */
.people{ display:grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap) }
.person{ background: var(--card); border:1px solid var(--border); border-radius:16px; overflow:hidden; box-shadow: var(--shadow) }
.person .ph{ background:#eceae6; aspect-ratio: 4/3 }
.person .body{ padding: 14px 16px }
.person h3{ margin:0 0 6px }
.person p{ margin:0; color: var(--muted) }
@media(max-width: 900px){ .people{ grid-template-columns: 1fr 1fr } }
@media(max-width: 540px){ .people{ grid-template-columns: 1fr } }

/* Pricing */
.pricing{ display:grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap) }
.price{
  background: var(--card); border:1px solid var(--border); border-radius:16px; padding:20px; box-shadow: var(--shadow)
}
.price h3{ margin:0 0 6px }
.price .amt{ font-size: 28px; font-weight:800; margin: 6px 0 12px; font-family:"Fraunces", ui-serif, Georgia, serif }
.price ul{ list-style:none; padding:0; margin: 0 }
.price li{ padding:8px 0; border-top:1px solid var(--border) }
@media(max-width: 900px){ .pricing{ grid-template-columns: 1fr 1fr } }
@media(max-width: 600px){ .pricing{ grid-template-columns: 1fr } }

/* Blog list */
.post-list{ display:grid; grid-template-columns: 1fr 1fr; gap: var(--gap) }
.post{ background: var(--card); border:1px solid var(--border); border-radius:16px; padding:18px; box-shadow: var(--shadow) }
.post time{ color: var(--muted); font-size: 14px }
@media(max-width: 900px){ .post-list{ grid-template-columns: 1fr } }

/* Forms */
label{ display:block; margin: 14px 0 6px; font-weight: 600 }
input, select, textarea{
  width:100%; padding:12px 14px; background: var(--bg-soft); color: var(--text);
  border:1px solid var(--border); border-radius:12px; outline:none;
}
input:focus, select:focus, textarea:focus{ box-shadow: var(--focus) }
.form-row{ display:grid; grid-template-columns: 1fr 1fr; gap: 12px }
@media(max-width: 680px){ .form-row{ grid-template-columns: 1fr } }

/* Footer */
.footer{ border-top:1px solid var(--border); padding: 28px 0 60px; color: var(--muted); background: color-mix(in oklab, var(--bg) 80%, #fff 20%) }
.footer a{ color: inherit }
.footer .cols{ display:grid; grid-template-columns: 2fr 1fr 1fr; gap: var(--gap) }
.footer small{ display:block; margin-top:8px; opacity:.8 }
@media(max-width: 900px){ .footer .cols{ grid-template-columns: 1fr 1fr } }
@media(max-width: 640px){ .footer .cols{ grid-template-columns: 1fr } }

/* Utilities */
.badge-pill{ display:inline-block; padding:6px 10px; border-radius:999px; background:#eeeae3; border:1px solid var(--border) }
.kbd{ padding:2px 6px; border-radius:6px; background:#efefef; border:1px solid var(--border) }
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0 }
