/* ============================================================
   FS YOGA  shared brand styles  (V7 edition)
   Cream + sand canvas, espresso ink, sage + copper accents.
   Display: Cormorant Garamond. Body: Manrope.
   Ported from the approved V7 prototype, adapted for the
   multi-page (index / packages / assessment / admin) site.
   ============================================================ */
:root{
  --ink:#211914;
  --espresso:#35251e;
  --espresso-2:#4b352b;
  --sage:#66745b;
  --sage-dark:#44513b;
  --sage-soft:#e1e7d9;
  --cream:#fffaf4;
  --milk:#fffdf8;
  --sand:#f2e7d8;
  --sand-2:#e8dac8;
  --copper:#d79b7f;
  --copper-deep:#a76a50;
  --rose:#f1c7b1;
  --muted:#786a60;
  --line:rgba(48,34,27,.14);
  --glass:rgba(255,250,244,.70);
  --white:#ffffff;
  /* dosha accents (used only in the admin submission views) */
  --vata:#4d8aa6;
  --pitta:#c2603f;
  --kapha:#5e8b48;
  --shadow:0 28px 80px rgba(42,30,24,.14);
  --shadow-soft:0 14px 40px rgba(42,30,24,.10);
  --radius:30px;
  --radius-sm:18px;
  --radius-pill:999px;
  --font-display:'Cormorant Garamond', Georgia, serif;
  --font-body:'Manrope', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-y:scroll;scrollbar-gutter:stable}
body{margin:0;background:linear-gradient(180deg,var(--cream),#f6ecdf 52%,#efe2d2);color:var(--ink);font-family:var(--font-body);line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;min-width:320px;min-height:100vh}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,textarea,select{font:inherit}
button{cursor:pointer}
:focus-visible{outline:3px solid rgba(215,155,127,.42);outline-offset:3px}

.container{width:min(1160px,calc(100% - 40px));margin:0 auto}
.skip-link{position:absolute;left:-999px;top:8px;background:var(--ink);color:#fff;padding:10px 14px;border-radius:10px;z-index:1000}
.skip-link:focus{left:8px}

/* ---------------------------------------------- Header (glass pill) */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;padding:16px 0;transition:background .25s ease,box-shadow .25s ease}
.site-header.scrolled,.site-header.open{background:rgba(43,31,25,.80);backdrop-filter:blur(18px);box-shadow:0 18px 42px rgba(0,0,0,.14)}
.header-shell{min-height:68px;border:1px solid rgba(255,255,255,.22);border-radius:var(--radius-pill);background:rgba(52,38,30,.34);backdrop-filter:blur(18px);display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 10px;color:#fffaf4;box-shadow:0 18px 50px rgba(0,0,0,.10)}
.brand{display:flex;align-items:center;gap:12px;padding-left:4px;min-width:0}
.brand-logo{width:50px;height:50px;border-radius:50%;background:#050403;overflow:hidden;border:1px solid rgba(241,199,177,.55);box-shadow:0 0 0 8px rgba(255,255,255,.06);flex:0 0 auto}
.brand-logo img{width:100%;height:100%;object-fit:cover}
.brand-copy{display:grid;gap:2px;min-width:0}
.brand-name{font-family:var(--font-display);font-size:1.68rem;font-weight:700;line-height:1;letter-spacing:.02em;white-space:nowrap}
.brand-tag{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,250,244,.74);font-weight:800;white-space:nowrap}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{min-height:48px;display:flex;align-items:center;padding:0 19px;border-radius:var(--radius-pill);font-weight:800;color:rgba(255,250,244,.82);transition:background .2s ease,color .2s ease}
.nav-links a:hover,.nav-links a.active{background:rgba(255,250,244,.15);color:#fffaf4}
.nav-cta{background:var(--cream)!important;color:var(--espresso)!important;box-shadow:0 12px 28px rgba(0,0,0,.12)}
.menu-toggle{display:none;min-width:48px;height:48px;border-radius:50%;border:0;background:rgba(255,250,244,.15);color:#fff;font-weight:800;font-size:1.1rem}

/* page that is not the home hero needs to clear the fixed header */
.section.page-top{padding-top:128px}

/* ---------------------------------------------- Type + sections */
.section{padding:72px 0;scroll-margin-top:80px}
.section-soft{background:linear-gradient(180deg,rgba(255,253,248,.72),rgba(242,231,216,.38));border-top:1px solid rgba(48,34,27,.07);border-bottom:1px solid rgba(48,34,27,.07)}
.eyebrow{display:inline-flex;align-items:center;gap:10px;color:var(--sage-dark);font-size:.76rem;letter-spacing:.24em;text-transform:uppercase;font-weight:900;margin-bottom:14px}
.eyebrow:before{content:'';width:38px;height:1px;background:var(--copper)}
h1,h2,h3{margin:0;color:var(--ink);font-family:var(--font-display);line-height:1.02;letter-spacing:-.025em}
h1{font-size:clamp(4rem,9vw,7.8rem);max-width:740px}
h2{font-size:clamp(2.5rem,5vw,4.4rem);max-width:760px}
h3{font-size:clamp(1.45rem,2.4vw,2rem);letter-spacing:-.01em}
p{margin:0;color:var(--muted)}
.lead{font-size:clamp(1.05rem,1.6vw,1.26rem);max-width:600px;color:#f6ede3}
.lead-dark{font-size:1.08rem;max-width:650px;color:var(--muted)}
.section-head{display:flex;justify-content:space-between;gap:28px;align-items:flex-end;margin-bottom:24px}
.section-head p{max-width:460px}

/* ---------------------------------------------- Buttons */
.btn{min-height:50px;border:0;border-radius:var(--radius-pill);display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:0 24px;font-weight:900;letter-spacing:-.01em;transition:transform .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease;white-space:nowrap}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:linear-gradient(135deg,var(--copper),var(--copper-deep));color:#fffaf4;box-shadow:0 16px 38px rgba(167,106,80,.28)}
.btn-dark{background:var(--espresso);color:#fffaf4;box-shadow:0 16px 36px rgba(53,37,30,.22)}
.btn-light{background:#fffaf4;color:var(--espresso);box-shadow:0 16px 38px rgba(255,250,244,.20)}
.btn-outline{background:rgba(255,250,244,.55);color:var(--espresso);border:1px solid var(--line)}
.btn-small{min-height:44px;padding:0 17px;font-size:.92rem}

/* ---------------------------------------------- Hero */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;background-image:linear-gradient(180deg,rgba(33,25,20,.46),rgba(33,25,20,.62)),url("../assets/hero.jpg");background-size:cover;background-position:center}
.hero:after{content:'';position:absolute;inset:auto 0 0;height:120px;background:linear-gradient(0deg,var(--cream),rgba(255,250,244,0));pointer-events:none}
.hero-content{position:relative;z-index:1;padding:170px 0 110px}
.hero-kicker{display:inline-flex;align-items:center;gap:12px;margin-bottom:16px;color:rgba(255,250,244,.88);font-size:.78rem;text-transform:uppercase;letter-spacing:.28em;font-weight:900}
.hero-kicker:before{content:'';width:42px;height:1px;background:var(--rose)}
.hero h1{color:#fffaf4;text-shadow:0 15px 50px rgba(0,0,0,.32);font-size:clamp(4.5rem,14vw,10rem);max-width:760px;line-height:.92}
.hero-tagline{margin:22px 0 26px;color:rgba(255,250,244,.82);font-size:.88rem;letter-spacing:.32em;text-transform:uppercase;font-weight:900}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:34px}
.hero-note{margin-top:22px;display:flex;gap:10px;align-items:center;color:rgba(255,250,244,.78);font-weight:700;font-size:.95rem}
.hero-note span{width:8px;height:8px;border-radius:50%;background:var(--rose);box-shadow:0 0 0 8px rgba(241,199,177,.14)}

/* ---------------------------------------------- Cards + steps */
.cards-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.card{background:rgba(255,253,248,.86);border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-soft);position:relative;overflow:hidden}
.card:before{content:'';position:absolute;inset:0;background:radial-gradient(500px 180px at 20% 0%,rgba(241,199,177,.20),transparent 60%);pointer-events:none}
.card > *{position:relative}
.step-card{min-height:250px;display:grid;gap:18px;align-content:start}
.step-number{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:var(--sage-soft);color:var(--sage-dark);font-family:var(--font-display);font-size:1.65rem;font-weight:800}

/* ---------------------------------------------- Packages */
.package-card{display:flex;flex-direction:column;gap:14px}
.package-card.featured{background:linear-gradient(180deg,#fffdf8,#fbefe5);border-color:rgba(167,106,80,.32);box-shadow:0 28px 80px rgba(167,106,80,.17)}
.package-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.badge{display:inline-flex;align-items:center;border-radius:var(--radius-pill);padding:7px 12px;background:var(--sage-soft);color:var(--sage-dark);font-size:.76rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase}
.price{font-family:var(--font-display);font-size:3.1rem;font-weight:700;line-height:1;color:var(--espresso)}
.price small{font-family:var(--font-body);font-size:.96rem;color:var(--muted);font-weight:700}
.package-list{list-style:none;padding:0;margin:0;display:grid;gap:10px;color:var(--muted)}
.package-list li{display:flex;gap:10px;align-items:flex-start}
.package-list li:before{content:'•';color:var(--copper-deep);font-weight:900}
.package-footer{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:18px;border-top:1px solid var(--line)}

/* ---------------------------------------------- Stories / videos */
.community-section{background:linear-gradient(180deg,#f5eadc,#f1e4d3)}
.community-head{margin-bottom:34px}
.story-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.story-card{background:rgba(255,253,248,.86);border:1px solid var(--line);border-radius:26px;padding:28px;box-shadow:var(--shadow-soft)}
.story-thumb{aspect-ratio:16/9;border-radius:22px;overflow:hidden;display:grid;place-items:center;background:linear-gradient(135deg,var(--espresso),var(--espresso-2)) center/cover no-repeat;background-image:linear-gradient(135deg,rgba(53,37,30,.45),rgba(75,53,43,.45)),url("../assets/story.jpg");position:relative}
.story-thumb iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.story-thumb .play-icon{width:66px;height:66px;background:rgba(255,250,244,.92);border:1px solid rgba(255,250,244,.76);box-shadow:0 18px 42px rgba(33,25,20,.18)}
.story-thumb .play-icon:after{border-left-color:var(--ink)}
.story-card h3{font-family:var(--font-body);font-size:1.15rem;line-height:1.22;letter-spacing:-.03em;font-weight:900;margin-top:18px;color:var(--ink)}
.story-card p{font-size:.96rem;margin-top:14px;color:var(--muted)}
.play-icon{width:76px;height:76px;border-radius:50%;background:rgba(255,250,244,.18);border:1px solid rgba(255,250,244,.28);display:grid;place-items:center;backdrop-filter:blur(10px);position:relative}
.play-icon:after{content:'';margin-left:5px;border-left:18px solid #fffaf4;border-top:12px solid transparent;border-bottom:12px solid transparent}

/* ---------------------------------------------- Assessment wizard */
.assessment-shell{display:grid;place-items:center}
.assessment-card{width:min(760px,100%);background:rgba(255,253,248,.92);border:1px solid var(--line);border-radius:34px;box-shadow:var(--shadow);overflow:hidden}
.assessment-inner{padding:34px}
.progress-row{display:flex;justify-content:space-between;align-items:center;gap:16px;color:var(--sage-dark);font-weight:900;font-size:.86rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:14px}
.progress-count{font-size:1rem;letter-spacing:0;text-transform:none;color:var(--sage-dark)}
.progress-track{height:8px;background:rgba(68,81,59,.12);border-radius:var(--radius-pill);overflow:hidden;margin-bottom:30px}
.progress-fill{height:100%;width:0;background:linear-gradient(90deg,var(--sage),var(--copper));border-radius:inherit;transition:width .28s ease}
.guidance-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:26px 0}
.guidance-card{min-height:150px;text-align:left;border:1px solid var(--line);border-radius:24px;background:#fffaf4;padding:20px;color:var(--ink);transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}
.guidance-card:hover,.guidance-card.selected{transform:translateY(-2px);border-color:rgba(167,106,80,.48);box-shadow:0 18px 42px rgba(167,106,80,.12)}
.guidance-card b{display:block;font-family:var(--font-display);font-size:1.55rem;margin-bottom:4px}
.guidance-card span{color:var(--muted);font-weight:700;font-size:.95rem}
.wizard-content h2{font-size:clamp(2.25rem,5vw,4rem);margin-bottom:14px}
.wizard-kicker{display:inline-flex;align-items:center;gap:10px;color:var(--sage-dark);font-size:.76rem;letter-spacing:.24em;text-transform:uppercase;font-weight:900;margin-bottom:14px}
.wizard-encourage{font-family:var(--font-display);font-size:1.6rem;color:var(--copper-deep);margin-bottom:10px}
.wizard-sub{font-size:1.02rem;margin-bottom:26px}
.choice-grid{display:grid;gap:12px;margin-top:24px}
.choice-btn{min-height:58px;border-radius:20px;border:1px solid var(--line);background:#fffdf8;color:var(--ink);padding:16px 18px;text-align:left;font-weight:850;transition:background .2s ease,border-color .2s ease,transform .2s ease}
.choice-btn:hover,.choice-btn.selected{background:#f8eee3;border-color:rgba(167,106,80,.45);transform:translateY(-1px)}
.wizard-actions{display:flex;justify-content:space-between;gap:12px;margin-top:34px}
.wizard-actions .btn-primary{min-width:200px}
.thanks-card{text-align:center;padding:46px 34px;display:none}
.thanks-card.active{display:block}
.thanks-mark{width:82px;height:82px;border-radius:50%;background:var(--sage-soft);display:grid;place-items:center;margin:0 auto 18px;color:var(--sage-dark);font-family:var(--font-display);font-size:2.6rem;font-weight:800}
/* wizard steps shown one at a time */
.wiz-step{display:none}
.wiz-step.active{display:block;animation:stepIn .35s ease both}
@keyframes stepIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
/* radio/checkbox choices styled as V7 choice buttons */
.choice-grid label{position:relative;min-height:58px;border-radius:20px;border:1px solid var(--line);background:#fffdf8;color:var(--ink);padding:16px 18px;display:flex;align-items:center;gap:10px;font-weight:850;cursor:pointer;transition:background .2s ease,border-color .2s ease,transform .2s ease}
.choice-grid label:hover{background:#f8eee3;border-color:rgba(167,106,80,.45);transform:translateY(-1px)}
.choice-grid input{position:absolute;opacity:0;pointer-events:none}
.choice-grid label:has(input:checked){background:#f6e7d8;border-color:rgba(167,106,80,.6);box-shadow:0 0 0 1px rgba(167,106,80,.55) inset}
.field-stack{display:grid;gap:14px;margin-top:22px}

/* ---------------------------------------------- Forms */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:22px}
.field,.form-row{display:grid;gap:8px}
.field label,.form-row label{font-weight:900;color:var(--sage-dark);font-size:.9rem}
.field .hint,.form-row .hint{font-size:.82rem;color:var(--muted);font-weight:600}
.input,.textarea,.select{width:100%;min-height:56px;border-radius:18px;border:1px solid var(--line);background:#fffdf8;padding:0 16px;color:var(--ink);font-size:16px;transition:border-color .2s ease,box-shadow .2s ease}
.textarea{min-height:120px;padding:16px;resize:vertical}
.input:focus,.textarea:focus,.select:focus{outline:0;border-color:rgba(167,106,80,.55);box-shadow:0 0 0 4px rgba(215,155,127,.18)}

/* ---------------------------------------------- Reach out / contact */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:28px;align-items:start}
.reach-grid{align-items:stretch}
.reach-title{margin-bottom:28px}
.reach-copy{display:flex;flex-direction:column;gap:18px}
.reach-copy .location-card{margin-top:0;flex:1}
.contact-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.contact-card{min-height:112px;border-radius:24px;background:rgba(255,253,248,.86);border:1px solid var(--line);padding:18px;box-shadow:var(--shadow-soft);display:grid;grid-template-columns:auto 1fr;align-items:center;gap:14px;text-decoration:none}
.contact-icon{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:var(--sage-soft);color:var(--sage-dark);font-style:normal;font-size:1rem;font-weight:900;box-shadow:inset 0 0 0 1px rgba(68,81,59,.12);flex:0 0 auto}
.contact-icon svg{width:21px;height:21px;display:block}
.contact-text{display:grid;gap:4px;min-width:0}
.contact-card span{font-weight:900;color:var(--sage-dark);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase}
.contact-card b{font-size:.92rem;line-height:1.35;color:var(--ink)}
.location-card{margin-top:14px;border-radius:24px;background:linear-gradient(135deg,var(--espresso),var(--espresso-2));color:#fffaf4;padding:26px;box-shadow:var(--shadow)}
.location-card p,.location-card b{color:#fffaf4}
.reach-form-card{background:rgba(255,253,248,.92);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:30px;display:grid;align-content:start;height:100%}
.reach-form-card h3{margin-bottom:10px}
.reach-form{display:grid;gap:18px;margin-top:24px}
.contact-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.contact-form-grid .full{grid-column:1/-1}
.form-note{min-height:22px;font-size:.94rem;font-weight:800;color:var(--sage-dark)}

/* ---------------------------------------------- Footer */
.footer{padding:56px 0 34px;border-top:1px solid var(--line);background:#f0e3d3}
.footer-grid{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;flex-wrap:wrap}
.footer .brand{color:var(--ink);padding:0}
.footer .brand-tag{color:var(--muted)}
.footer-links{display:flex;gap:18px;flex-wrap:wrap;color:var(--muted);font-weight:800}
.footer-links a:hover{color:var(--ink)}

/* ---------------------------------------------- Admin portal */
body.admin-page{background:#f6f0e8}
.admin-login{min-height:100vh;display:grid;place-items:center;padding:28px}
.login-card{width:min(440px,100%);background:#fffdf8;border:1px solid var(--line);border-radius:32px;box-shadow:var(--shadow);padding:32px}
.login-card .brand{color:var(--ink);margin-bottom:28px}
.login-card .brand-logo{background:#050403}
.login-card .brand-name{color:var(--ink)}
.login-card .brand-tag{color:var(--muted)}
.login-toggle{background:none;border:0;font:inherit;cursor:pointer;color:var(--copper-deep);text-decoration:underline;padding:6px 0;text-align:center;font-weight:800}
.login-msg{margin:0;padding:10px 12px;border-radius:12px;font-size:.86rem;color:var(--copper-deep);background:rgba(215,155,127,.14);border:1px solid rgba(167,106,80,.3)}
.admin-dashboard{min-height:100vh}
.admin-dashboard.active{display:grid;grid-template-columns:270px 1fr}
.admin-side{background:var(--espresso);color:#fffaf4;padding:26px;display:flex;flex-direction:column;gap:26px}
.admin-side .brand{color:#fffaf4}
.admin-side .brand-name{color:#fffaf4}
.admin-side .brand-tag{color:rgba(255,250,244,.65)}
.admin-menu{display:grid;gap:8px}
.admin-menu button{min-height:48px;border:0;border-radius:16px;background:transparent;color:rgba(255,250,244,.70);text-align:left;padding:0 14px;font-weight:850}
.admin-menu button:hover,.admin-menu button.active{background:rgba(255,250,244,.12);color:#fffaf4}
.admin-main{padding:34px;overflow:auto}
.admin-top{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px}
.admin-top h1{font-size:clamp(2.4rem,4vw,4rem);color:var(--ink)}
.admin-panel{display:none}
.admin-panel.active{display:block}
.stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:20px}
.stat{background:#fffdf8;border:1px solid var(--line);border-radius:22px;padding:20px}
.stat span{color:var(--muted);font-weight:900;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase}
.stat b{display:block;font-family:var(--font-display);font-size:2.6rem;line-height:1;margin-top:8px;color:var(--ink)}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:22px;background:#fffdf8}
table{width:100%;border-collapse:collapse;min-width:680px}
th,td{text-align:left;padding:15px 16px;border-bottom:1px solid var(--line);font-size:.94rem}
th{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sage-dark);background:#f5eee5}
tr:last-child td{border-bottom:0}
.admin-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:20px}
.preview-list{display:grid;gap:10px}
.preview-row{display:flex;justify-content:space-between;gap:16px;padding:14px;border-radius:16px;background:#fffaf4;border:1px solid var(--line)}
.preview-row b{color:var(--sage-dark)}

/* ---------------------------------------------- Modal (admin edit forms) */
.modal-backdrop{position:fixed;inset:0;background:rgba(33,25,20,.5);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:100;padding:24px}
.modal{width:min(640px,100%);max-height:88vh;overflow:auto;background:var(--milk);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.modal h3{margin-top:0}
.modal .actions{display:flex;gap:10px;justify-content:flex-end;margin-top:22px}

/* ---------------------------------------------- QR generator */
.qr-block{display:flex;gap:24px;flex-wrap:wrap;align-items:center;margin-top:18px}
.qr-canvas{background:#fff;padding:12px;border-radius:22px;width:220px;height:220px;display:grid;place-items:center;border:1px solid var(--line)}
.qr-canvas img,.qr-canvas canvas{width:100%;height:100%}
.qr-card-preview{min-width:280px;display:grid;place-items:center}
.qr-card-img{width:300px;max-width:100%;height:auto;border-radius:18px;box-shadow:var(--shadow)}

/* ---------------------------------------------- Chips, toast, utilities */
.chip{display:inline-flex;gap:6px;align-items:center;font-size:.75rem;padding:4px 11px;border-radius:var(--radius-pill);background:var(--sage-soft);color:var(--sage-dark);border:1px solid var(--line);font-weight:800;text-transform:capitalize}
.chip.vata{color:var(--vata);border-color:rgba(77,138,166,.4);background:rgba(77,138,166,.10)}
.chip.pitta{color:var(--pitta);border-color:rgba(194,96,63,.4);background:rgba(194,96,63,.10)}
.chip.kapha{color:var(--kapha);border-color:rgba(94,139,72,.4);background:rgba(94,139,72,.10)}
.toast{position:fixed;right:22px;bottom:22px;z-index:120;background:var(--espresso);color:#fffaf4;border-radius:20px;padding:14px 18px;box-shadow:var(--shadow);opacity:0;transform:translateY(12px);transition:opacity .2s ease,transform .2s ease;font-weight:850}
.toast.show{opacity:1;transform:translateY(0)}
.row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.row-between{display:flex;gap:12px;justify-content:space-between;align-items:center;flex-wrap:wrap}
.muted{color:var(--muted)}
.center{text-align:center}
.mt-2{margin-top:14px}
.mt-4{margin-top:28px}
.mb-2{margin-bottom:14px}
.hidden{display:none!important}

/* ---------------------------------------------- Responsive */
@media(max-width:980px){
  .cards-grid,.guidance-grid,.contact-card-grid,.stat-grid,.story-card-grid{grid-template-columns:1fr 1fr}
  .section-head,.contact-grid,.admin-grid{grid-template-columns:1fr;display:grid;align-items:start}
  .contact-form-grid{grid-template-columns:1fr}
  .admin-dashboard.active{grid-template-columns:1fr}
  .admin-side{position:relative}
  .admin-menu{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:760px){
  .contact-card b{white-space:normal;overflow-wrap:anywhere}
  .story-card-grid{grid-template-columns:1fr}
  .story-card{padding:22px}
  .container{width:min(100% - 28px,1160px)}
  .site-header{padding:10px 0}
  .header-shell{border-radius:26px;height:auto;min-height:64px;align-items:flex-start;flex-wrap:wrap}
  .brand-logo{width:46px;height:46px}
  .brand-name{font-size:1.42rem}
  .brand-tag{font-size:.58rem;letter-spacing:.18em}
  .menu-toggle{display:grid;place-items:center;margin-left:auto}
  .nav-links{display:none;width:100%;padding:8px 0 2px;grid-template-columns:1fr;gap:6px}
  .site-header.open .nav-links{display:grid}
  .nav-links a{justify-content:center;background:rgba(255,250,244,.10)}
  .hero{min-height:92vh;background-position:58% center}
  .hero-content{padding:140px 0 72px}
  h1{font-size:clamp(3.5rem,17vw,5.6rem)}
  h2{font-size:clamp(2.25rem,12vw,3.7rem)}
  .section{padding:72px 0;scroll-margin-top:96px}
  .section.page-top{padding-top:108px}
  .cards-grid,.guidance-grid,.contact-card-grid,.stat-grid,.form-grid,.contact-form-grid{grid-template-columns:1fr}
  .assessment-inner{padding:24px}
  .assessment-card{border-radius:28px}
  .wizard-actions{position:sticky;bottom:0;background:linear-gradient(0deg,#fffdf8 70%,rgba(255,253,248,0));padding-top:18px;margin-left:-24px;margin-right:-24px;padding-left:24px;padding-right:24px;padding-bottom:10px}
  .wizard-actions .btn-primary{min-width:0;flex:1}
  .admin-main{padding:22px 16px}
  .admin-menu{grid-template-columns:1fr}
  .footer-grid{display:grid}
}
@media(max-width:420px){
  .hero-actions .btn{width:100%}
  .package-footer{display:grid}
  .wizard-actions{display:grid;grid-template-columns:1fr}
  .wizard-actions .btn{width:100%}
}
