:root{--ink:#211914;--muted:#675e55;--paper:#faf5ea;--paper2:#fffdf7;--gold:#c99b27;--line:#302821;--wine:#791730;--bg:#130b0b;--safe-top:env(safe-area-inset-top);--safe-bottom:env(safe-area-inset-bottom)}
*{box-sizing:border-box}html,body{margin:0;height:100%;overflow:hidden}body{font-family:Inter,system-ui,sans-serif;background:radial-gradient(circle at 20% 0,#4d0f20 0,#160c0c 45%,#080707 100%);color:var(--ink)}
.topbar{height:92px;padding:calc(12px + var(--safe-top)) 18px 12px;display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(90deg,rgba(80,10,30,.94),rgba(8,8,8,.94));color:#fff;position:fixed;z-index:20;top:0;left:0;right:0}.brand{display:flex;align-items:center;gap:13px;font-weight:800;font-size:clamp(19px,4vw,28px);white-space:nowrap}.logo{width:54px;height:38px;object-fit:contain;border:1px solid rgba(212,170,55,.45);border-radius:8px;background:#111}.call,.big-call{background:linear-gradient(#ecc748,#c69318);color:#111;text-decoration:none;font-weight:900;border-radius:999px;padding:16px 24px;font-size:22px;box-shadow:inset 0 1px rgba(255,255,255,.4)}
.stage{position:fixed;top:92px;bottom:calc(88px + var(--safe-bottom));left:0;right:0;display:flex;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;overscroll-behavior:none}.stage::-webkit-scrollbar{display:none}.page{min-width:100%;height:100%;scroll-snap-align:start;padding:12px 16px;display:flex;align-items:center;justify-content:center}.paper{width:min(92vw,680px);height:100%;max-height:100%;background:var(--paper);background-image:linear-gradient(rgba(255,255,255,.5),rgba(255,255,255,.1));box-shadow:0 18px 40px rgba(0,0,0,.38);border:1px solid #ded1bd;border-radius:3px;padding:clamp(22px,5vw,42px);overflow:hidden;position:relative;color:var(--ink)}.paper:before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.55),transparent 30%),repeating-linear-gradient(0deg,rgba(0,0,0,.012),rgba(0,0,0,.012) 1px,transparent 1px,transparent 6px);mix-blend-mode:multiply}
h1,h2,h3{font-family:'Cormorant Garamond',Georgia,serif;margin:0;color:var(--ink)}h1{font-size:clamp(52px,13vw,96px);line-height:.86;text-align:center}h2{font-size:clamp(42px,11vw,72px);line-height:.88}h3{font-size:clamp(30px,7vw,44px);line-height:1;margin-top:10px}.eyebrow,.cover-mark{letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:800;font-size:13px}.lead{font-size:clamp(18px,4.4vw,28px);line-height:1.3}.small{font-size:18px}.tiny{font-size:16px;text-align:center;text-transform:uppercase;letter-spacing:.08em;line-height:1.5}.rule{height:2px;background:var(--line);margin:24px auto;width:72%}.cover-paper{display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:18px}.cover-logo{width:160px;max-width:40%;height:auto}.subtitle{font-family:'Cormorant Garamond';font-size:30px;color:var(--wine);font-weight:700;margin:0}.recipe-grid{display:grid;grid-template-rows:auto auto auto 1fr auto auto;gap:14px}.meta-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;border-top:2px solid var(--line);border-bottom:2px solid var(--line);padding:10px 0;text-align:center}.meta-row.three{grid-template-columns:repeat(3,1fr)}.meta-row span{text-transform:uppercase;letter-spacing:.16em;font-size:10px;font-weight:900;color:#51463c;border-left:1px solid #9d9183;padding:4px}.meta-row span:first-child{border-left:0}.hero-img,.product-img{width:100%;object-fit:cover;border:1px solid #2c251f;box-shadow:0 4px 12px rgba(0,0,0,.18)}.hero-img{height:min(35vh,320px)}.chef-img{height:min(38vh,360px);object-position:center 24%;border-radius:2px}.wide{object-position:center}.recipe-grid p{font-size:clamp(16px,3.7vw,22px);line-height:1.38;margin:0;color:#2f2923}.signature{font-family:'Cormorant Garamond';font-size:44px!important;color:var(--wine)!important}.clean-list{margin:0;padding-left:20px;color:#3c332b;font-weight:600;line-height:1.42}.note-card,.ingredients-box{background:#fffdf7;border:1.5px solid var(--line);padding:18px 20px;box-shadow:8px 8px 0 rgba(0,0,0,.08)}.overlay-card{margin-top:-36px;width:88%;justify-self:center}.ingredients-box h3,.note-card h3{margin:0 0 8px}.ingredients-box ul{font-size:20px;line-height:1.35;margin:8px 0 12px}.yellow{background:#fff2a8}.blush{background:#fff0eb}.product-img{height:min(30vh,260px);object-fit:contain;background:#050505;padding:10px}.chips{display:flex;gap:10px;flex-wrap:wrap;margin:10px 0 18px}.chips span{border:2px solid var(--line);border-radius:999px;padding:9px 14px;font-weight:900;background:rgba(255,255,255,.35)}.menu-page{display:flex;flex-direction:column;gap:14px}.menu-stack{position:relative;flex:1;min-height:0}.menu-stack img{position:absolute;width:62%;max-height:86%;object-fit:cover;border:1px solid #222;box-shadow:0 12px 25px rgba(0,0,0,.28);background:#fff}.menu-stack img:nth-child(1){left:0;top:6%;transform:rotate(-4deg)}.menu-stack img:nth-child(2){right:0;top:14%;transform:rotate(5deg)}.menu-stack img:nth-child(3){left:18%;bottom:0;transform:rotate(-1deg)}.review-page{display:flex;flex-direction:column;gap:18px}.review-notes{display:grid;gap:14px}.review-notes blockquote{margin:0;background:#fffdf7;border:1px solid #d7cbbb;box-shadow:6px 6px 0 rgba(0,0,0,.08);padding:18px;font-size:20px;line-height:1.25;transform:rotate(-1deg)}.review-notes blockquote:nth-child(even){transform:rotate(1deg);background:#fff8d7}.review-notes b{display:block;color:#d19c13;margin-bottom:6px}cite{display:block;margin-top:10px;color:#665a4f;font-style:normal;font-weight:800}.back-cover{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;justify-content:center}.booking-card{background:#fffdf7;border:1px solid #e8dece;border-radius:24px;padding:14px 18px;font-weight:900;font-size:clamp(18px,4vw,24px);width:100%}.big-call{font-size:22px;margin-top:4px;display:inline-block}.controls{position:fixed;left:0;right:0;bottom:0;height:calc(92px + var(--safe-bottom));padding:10px 16px calc(12px + var(--safe-bottom));display:grid;grid-template-columns:54px 1fr 54px;align-items:center;gap:12px;background:linear-gradient(180deg,rgba(8,8,8,.15),rgba(8,8,8,.88) 28%,rgba(8,8,8,.96));backdrop-filter:blur(18px);z-index:25}.nav-btn{width:54px;height:54px;border-radius:18px;border:1px solid rgba(255,255,255,.14);background:linear-gradient(180deg,rgba(255,255,255,.15),rgba(255,255,255,.06));color:#fff;font-size:38px;line-height:1;box-shadow:0 10px 30px rgba(0,0,0,.35),inset 0 1px rgba(255,255,255,.18)}.nav-btn:active{transform:scale(.96);background:rgba(201,155,39,.24)}.page-status{min-width:0;display:grid;gap:8px;padding:10px 12px;border:1px solid rgba(255,255,255,.1);border-radius:22px;background:rgba(255,255,255,.065);box-shadow:inset 0 1px rgba(255,255,255,.08)}.status-top{display:flex;align-items:center;justify-content:space-between;gap:10px;color:#fff;font-weight:900;font-size:13px;letter-spacing:.08em;text-transform:uppercase}.status-top span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#f7e8ba}.status-top span:last-child{color:rgba(255,255,255,.65);font-variant-numeric:tabular-nums}.progress-track{height:5px;border-radius:999px;background:rgba(255,255,255,.16);overflow:hidden}.progress-fill{height:100%;width:10%;border-radius:999px;background:linear-gradient(90deg,#f1d05a,#c99b27);box-shadow:0 0 14px rgba(201,155,39,.65);transition:width .32s ease}.dots{display:flex;gap:6px;overflow:hidden;justify-content:center}.dot{width:8px;height:8px;border-radius:999px;border:0;background:rgba(255,255,255,.25);flex:0 0 8px;padding:0;transition:width .25s ease,background .25s ease}.dot.active{width:28px;background:linear-gradient(90deg,#f1d05a,#c99b27);box-shadow:0 0 12px rgba(201,155,39,.55)}.dot-label{display:none}
@media (max-height:740px){.topbar{height:80px}.stage{top:80px;bottom:calc(82px + var(--safe-bottom))}.controls{height:calc(82px + var(--safe-bottom));padding-top:8px}.nav-btn{width:48px;height:48px;border-radius:16px}.page-status{padding:8px 10px}.status-top{font-size:12px}.paper{padding:20px}.lead{font-size:17px}.hero-img{height:min(30vh,245px)}.chef-img{height:min(32vh,260px)}h2{font-size:40px}.recipe-grid{gap:10px}.ingredients-box,.note-card{padding:14px}.menu-stack img{max-height:78%}}
@media (min-width:800px){.stage{bottom:104px}.controls{height:104px}.page{padding:22px}.paper{max-width:760px}.hero-img{height:330px}.chef-img{height:360px}}

/* v4 mobile readability + forms */
.paper{
  overflow-y:auto;
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  padding-bottom:calc(clamp(22px,5vw,42px) + 18px);
}
.paper::-webkit-scrollbar{width:0;height:0}
.page{align-items:flex-start;padding-top:14px;padding-bottom:14px}
.stage{overscroll-behavior-x:none;overscroll-behavior-y:contain}

.mini-form,.book-form{position:relative;z-index:2;background:#fffdf7;border:1.5px solid var(--line);box-shadow:6px 6px 0 rgba(0,0,0,.08);padding:14px;display:grid;gap:10px;color:var(--ink)}
.mini-form{grid-template-columns:1fr 1fr;align-items:center}.mini-form .form-title{grid-column:1/-1;font-weight:900;text-transform:uppercase;letter-spacing:.14em;color:var(--gold);font-size:12px}.mini-form input,.book-form input,.book-form textarea,.book-form select{width:100%;border:1px solid #cfc3b2;background:#fff;border-radius:10px;padding:12px 12px;font:600 15px Inter,system-ui,sans-serif;color:var(--ink)}.mini-form button,.book-form button{border:0;border-radius:999px;background:linear-gradient(#ecc748,#c69318);color:#17110c;font-weight:900;padding:13px 16px;font-size:15px;box-shadow:inset 0 1px rgba(255,255,255,.5)}.mini-form button{grid-column:1/-1}.book-form{width:100%;text-align:left}.book-form label{display:grid;gap:6px;font-weight:900;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#4b4037}.book-form textarea{resize:vertical;text-transform:none;font-weight:600}.booking-page{justify-content:flex-start;text-align:left;align-items:stretch}.booking-page h2,.booking-page .lead{text-align:center}.booking-page .booking-card{text-align:center}

@media (max-width:430px){
  .topbar{height:86px;padding-left:16px;padding-right:16px}.stage{top:86px;bottom:calc(104px + var(--safe-bottom))}.controls{height:calc(104px + var(--safe-bottom));grid-template-columns:54px 1fr 54px;padding-left:18px;padding-right:18px}.paper{width:calc(100vw - 28px);height:auto;min-height:calc(100% - 16px);max-height:calc(100% - 16px);padding:24px 20px 30px}.page{padding:8px 14px 12px}.brand{font-size:19px;gap:10px}.logo{width:50px;height:36px}.call{font-size:21px;padding:15px 22px}h2{font-size:clamp(38px,11vw,52px);line-height:.9}.lead{font-size:18px;line-height:1.35}.recipe-grid{grid-template-rows:auto;gap:12px}.hero-img{height:auto;max-height:none;aspect-ratio:1.25/1}.chef-img{height:auto;aspect-ratio:1/0.78;object-position:center 18%}.product-img{height:auto;aspect-ratio:1.45/1}.meta-row{gap:0}.meta-row span{font-size:10px;letter-spacing:.13em;padding:7px 3px}.ingredients-box,.note-card{padding:16px}.ingredients-box ul{font-size:18px}.review-notes blockquote{font-size:18px}.mini-form{grid-template-columns:1fr}.book-form{gap:9px}.book-form input,.book-form textarea,.book-form select{padding:10px 11px}.booking-card{font-size:16px;border-radius:16px;padding:12px}.big-call{font-size:18px;text-align:center}.menu-stack{min-height:440px}.cover-paper{min-height:100%}.controls{background:linear-gradient(180deg,rgba(8,8,8,.05),rgba(8,8,8,.94) 32%,#050505)}
}

/* v5 brand update: Chef Joel logo system */
.logo{width:64px;height:42px;border-radius:10px;object-fit:cover;object-position:center;background:#050505;border:1px solid rgba(212,170,55,.55);box-shadow:0 4px 14px rgba(0,0,0,.25)}
.cover-logo-feature{width:100%;max-width:720px;aspect-ratio:1.64/1;object-fit:cover;border:1px solid rgba(34,28,22,.55);box-shadow:0 18px 38px rgba(0,0,0,.24);margin:8px 0 12px;background:#050505}
.cover-paper{gap:16px}.cover-paper .tiny{max-width:620px}
@media (max-width: 680px){.logo{width:58px;height:40px}.cover-logo-feature{aspect-ratio:1.26/1;object-position:center top}.cover-paper{justify-content:center}.cover-paper .tiny{font-size:13px}}

/* v6 fixes: compact icon logo + uncropped cover hero */
.logo{
  width:56px;
  height:56px;
  border-radius:16px;
  object-fit:cover;
  object-position:center;
  padding:0;
  background:#050505;
}
.cover-logo-feature{
  object-fit:contain !important;
  object-position:center center !important;
  background:#050505;
  aspect-ratio:1.64/1;
}
@media (max-width:680px){
  .brand{gap:12px}
  .logo{width:50px;height:50px;border-radius:14px}
  .cover-logo-feature{aspect-ratio:1.64/1 !important;width:100%;max-height:42vh}
  .cover-paper{justify-content:flex-start;gap:18px}
}
@media (max-width:390px){
  .brand span{font-size:18px}
  .logo{width:46px;height:46px}
}

/* v8: make persistent header logo/title return to cover */
.brand-home{
  border:0;
  background:transparent;
  color:inherit;
  padding:0;
  margin:0;
  font:inherit;
  cursor:pointer;
  -webkit-tap-highlight-color:transparent;
}
.brand-home:active{transform:scale(.985)}
.brand-home:focus-visible{outline:2px solid rgba(236,199,72,.85);outline-offset:4px;border-radius:14px}

/* v9: luxury printed cookbook cover */
.luxury-cover-paper{
  padding:0 !important;
  overflow:hidden !important;
  background:#f8f3ea;
  border-radius:6px;
  justify-content:center;
  align-items:center;
}
.luxury-cover-img{
  width:100%;
  height:100%;
  display:block;
  object-fit:contain;
  object-position:center;
  background:#f8f3ea;
}
@media (max-width:430px){
  .luxury-cover-paper{
    width:calc(100vw - 28px);
    height:calc(100% - 16px);
    min-height:0;
    max-height:calc(100% - 16px);
  }
  .luxury-cover-img{
    object-fit:contain;
  }
}

/* v10: live seasonal menu pages */
.live-menu-page{grid-template-rows:auto auto auto auto auto;gap:12px}
.live-menu-page .eyebrow{font-size:12px;letter-spacing:.2em;color:var(--gold);}
.live-menu-page h2{font-size:clamp(36px,9.5vw,64px)}
.live-menu-frame{position:relative;z-index:1;border:1.5px solid var(--line);box-shadow:0 10px 24px rgba(0,0,0,.22);background:#fffdf7;padding:10px;display:flex;align-items:center;justify-content:center;min-height:0}
.live-menu-frame img{display:block;width:100%;height:auto;max-height:48vh;object-fit:contain;border:1px solid rgba(33,25,20,.25)}
.live-menu-frame.wood{background:linear-gradient(135deg,#f7ecd8,#fff8ed)}
.live-menu-frame.autumn{background:linear-gradient(135deg,#fff1cf,#f5c26f)}
.compact-menu-note{padding:14px 16px;box-shadow:6px 6px 0 rgba(0,0,0,.07)}
.compact-menu-note h3{font-size:clamp(26px,6vw,38px);margin:0 0 4px}.compact-menu-note p{font-size:clamp(15px,3.3vw,19px)!important;line-height:1.32!important}
@media (max-width:430px){
  .live-menu-page{gap:10px}
  .live-menu-frame{padding:8px}
  .live-menu-frame img{max-height:43vh}
  .compact-menu-note{padding:12px 14px}
}
@media (max-height:740px){.live-menu-frame img{max-height:38vh}.compact-menu-note p{font-size:14px!important}.compact-menu-note h3{font-size:26px}}

/* v11: replace live menu screenshots with custom cookbook-style menu artwork */
.menu-art-page{
  padding:0 !important;
  background:#f6eddd;
  overflow:auto;
  display:flex;
  align-items:flex-start;
  justify-content:center;
}
.cookbook-menu-art{
  display:block;
  width:100%;
  height:auto;
  min-height:100%;
  object-fit:contain;
  object-position:top center;
  background:#f6eddd;
}
@media (max-width:600px){
  .menu-art-page{width:calc(100vw - 28px);max-height:calc(100% - 16px);}
  .cookbook-menu-art{width:100%;min-height:auto;}
}

/* v12: premium private chef + dessert studio cookbook artwork pages */
.premium-feature-page{
  background:#f8f1e5;
  box-shadow:0 18px 40px rgba(0,0,0,.38);
}
.premium-feature-page .cookbook-menu-art{
  max-width:100%;
  margin:0 auto;
}
@media (max-width:600px){
  .premium-feature-page{overflow:auto;-webkit-overflow-scrolling:touch;}
  .premium-feature-page .cookbook-menu-art{width:100%;height:auto;min-height:auto;}
}


/* v14: family dedication pages */
.family-note-page{
  background:#f8f1e5;
  overflow:auto;
  -webkit-overflow-scrolling:touch;
}
.family-note-page .cookbook-menu-art{
  width:100%;
  height:auto;
  min-height:auto;
  object-fit:contain;
  object-position:top center;
}
@media (max-width:600px){
  .family-note-page{width:calc(100vw - 28px);max-height:calc(100% - 16px);}
}

/* v18: desktop two-page cookbook spread */
@media (min-width:1024px){
  html,body{overflow:hidden;}
  .topbar{
    height:78px;
    padding:12px 34px;
  }
  .brand{font-size:26px;}
  .logo{width:58px;height:58px;}
  .call{font-size:22px;padding:15px 30px;}
  .stage{
    top:78px;
    bottom:116px;
    left:0;
    right:0;
    padding:18px clamp(28px,4vw,72px);
    gap:0;
    align-items:stretch;
    scroll-snap-type:x mandatory;
    background:radial-gradient(circle at 50% 0,rgba(123,18,48,.2),transparent 40%);
  }
  .page{
    min-width:50%;
    width:50%;
    height:100%;
    padding:0 10px;
    align-items:center;
    justify-content:center;
    scroll-snap-align:start;
  }
  .page:nth-child(odd){padding-right:5px;}
  .page:nth-child(even){padding-left:5px;}
  .paper{
    width:100%;
    max-width:none;
    height:100%;
    max-height:100%;
    border-radius:5px;
    overflow:auto;
    box-shadow:0 22px 55px rgba(0,0,0,.42);
  }
  .page:nth-child(odd) .paper{
    border-top-right-radius:0;
    border-bottom-right-radius:0;
    box-shadow:-12px 18px 45px rgba(0,0,0,.34), inset -18px 0 25px rgba(80,60,30,.06);
  }
  .page:nth-child(even) .paper{
    border-top-left-radius:0;
    border-bottom-left-radius:0;
    box-shadow:12px 18px 45px rgba(0,0,0,.34), inset 18px 0 25px rgba(80,60,30,.06);
  }
  .menu-art-page,
  .luxury-cover-paper,
  .back-cover-art-page,
  .family-note-page,
  .premium-feature-page{
    overflow:hidden!important;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:0!important;
  }
  .cookbook-menu-art,
  .luxury-cover-img{
    width:100%;
    height:100%;
    min-height:0!important;
    max-height:100%;
    object-fit:contain!important;
    object-position:center center!important;
  }
  .cover .paper{background:#f8f3ea;}
  .recipe-grid{gap:14px;}
  .hero-img{height:min(34vh,330px);}
  .chef-img{height:min(38vh,380px);}
  .lead{font-size:20px;}
  .controls{
    height:116px;
    padding:18px clamp(36px,6vw,110px) 24px;
    grid-template-columns:70px minmax(360px,620px) 70px;
    justify-content:center;
    background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.72) 30%,rgba(0,0,0,.96));
  }
  .nav-btn{width:70px;height:70px;border-radius:22px;font-size:48px;}
  .page-status{padding:14px 20px;border-radius:26px;}
  .status-top{font-size:15px;}
  .progress-track{height:7px;}
  .dot{width:10px;height:10px;flex-basis:10px;}
  .dot.active{width:36px;}
}

@media (min-width:1440px){
  .stage{padding-left:clamp(80px,8vw,160px);padding-right:clamp(80px,8vw,160px);}
  .page{padding-left:14px;padding-right:14px;}
}
