*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --paper:#FAF9F6;
  --ink:#2B2826;
  --ink-soft:#5b5650;
  --sand:#D8C8B8;
  --sage:#A8B89C;
  --clay:#E8967A;
  --white:#FFFFFF;
  --line:rgba(43,40,38,0.12);
}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:'Work Sans',sans-serif;overflow-x:hidden;font-weight:400}

/* loader */
.loader{position:fixed;inset:0;z-index:999;background:var(--paper);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;transition:opacity 0.7s ease,transform 0.7s ease}
.loader.gone{opacity:0;pointer-events:none;transform:scale(1.02)}
.loader-mark{animation:loader-spin 1.6s ease-in-out infinite}
@keyframes loader-spin{0%,100%{transform:rotate(0deg)}50%{transform:rotate(8deg)}}
.loader-word{font-family:'Fraunces',serif;font-size:1.1rem;color:var(--ink-soft);letter-spacing:0.04em}

/* nav */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1.4rem 3rem;background:rgba(250,249,246,0.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);transition:background 0.3s}
.nav-mark{display:flex;align-items:center;gap:0.6rem;font-family:'Fraunces',serif;font-size:1.15rem;color:var(--ink)}
.nav-links{display:flex;gap:2.2rem;list-style:none}
.nav-links a{position:relative;color:var(--ink-soft);text-decoration:none;font-size:0.85rem;letter-spacing:0.02em;transition:color 0.2s}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-7px;width:0;height:1px;background:var(--clay);transition:width 0.35s ease}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{width:100%}
.nav-cta{background:var(--ink);color:var(--paper);border:none;padding:0.55rem 1.3rem;font-size:0.82rem;font-family:'Work Sans',sans-serif;cursor:pointer;border-radius:30px;font-weight:500;transition:background 0.25s,transform 0.15s;text-decoration:none}
.nav-cta:hover{background:var(--clay);transform:translateY(-1px)}

/* hero — asymmetric two column, off-center */
.hero{min-height:100vh;display:grid;grid-template-columns:1.1fr 0.9fr;align-items:center;gap:3rem;padding:9rem 4rem 4rem;max-width:1400px;margin:0 auto}
.hero-kicker{font-size:0.8rem;letter-spacing:0.12em;color:var(--ink-soft);margin-bottom:1.4rem;opacity:0;animation:rise 0.8s 0.2s forwards}
.hero-title{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(3rem,6.5vw,5.4rem);line-height:1.02;letter-spacing:-0.01em;margin-bottom:1.6rem;opacity:0;animation:rise 0.9s 0.35s forwards}
.scribble-wrap{position:relative;display:inline-block;font-style:italic;color:var(--ink)}
.scribble{position:absolute;left:0;bottom:-0.18em;width:100%;height:0.3em;overflow:visible}
.scribble path{stroke-dasharray:340;stroke-dashoffset:340;animation:draw-scribble 1.1s 1.1s ease forwards}
@keyframes draw-scribble{to{stroke-dashoffset:0}}
.hero-sub{font-size:1.05rem;color:var(--ink-soft);line-height:1.7;max-width:420px;margin-bottom:2.2rem;opacity:0;animation:rise 0.9s 0.5s forwards}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2.6rem;opacity:0;animation:rise 0.9s 0.65s forwards}
.btn-ink{background:var(--ink);color:var(--paper);padding:0.85rem 1.8rem;border-radius:30px;font-size:0.88rem;font-weight:500;text-decoration:none;display:inline-block;transition:transform 0.25s ease,background 0.25s ease;position:relative;overflow:hidden}
.btn-ink:hover{background:var(--clay);transform:translateY(-2px)}
.btn-line{padding:0.85rem 1.8rem;border-radius:30px;font-size:0.88rem;font-weight:500;text-decoration:none;display:inline-block;color:var(--ink);border:1px solid var(--ink);transition:all 0.25s ease}
.btn-line:hover{background:var(--ink);color:var(--paper);transform:translateY(-2px)}
.hero-rating{display:flex;align-items:center;gap:0.6rem;opacity:0;animation:rise 0.9s 0.8s forwards}
.hero-rating-num{font-family:'Fraunces',serif;font-size:1.3rem;color:var(--ink)}
.hero-rating-stars{color:var(--clay);font-size:0.9rem}
.hero-rating-label{font-size:0.78rem;color:var(--ink-soft)}
@keyframes rise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}

.hero-frame{position:relative;opacity:0;animation:frame-in 1s 0.5s forwards}
@keyframes frame-in{from{opacity:0;transform:translateY(24px) scale(0.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.hero-photo{border-radius:28px;overflow:hidden;aspect-ratio:4/5;background:var(--sand);animation:float-photo 6s ease-in-out infinite}
@keyframes float-photo{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.hero-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.7s ease}
.hero-photo:hover img{transform:scale(1.05)}
.hero-photo-tag{position:absolute;bottom:-14px;left:24px;background:var(--white);border-radius:30px;padding:0.55rem 1.2rem;font-size:0.78rem;color:var(--ink-soft);box-shadow:0 8px 24px rgba(43,40,38,0.1);font-family:'Fraunces',serif;font-style:italic}

/* marquee strip */
.marquee-strip{background:var(--ink);padding:0.8rem 0;overflow:hidden;white-space:nowrap}
.marquee-track{display:inline-flex;gap:0.6rem;animation:marquee-move 32s linear infinite;font-family:'Fraunces',serif;font-style:italic}
.marquee-track span{color:var(--paper);font-size:0.95rem;padding:0 0.5rem}
.marquee-track .sep{color:var(--clay);font-style:normal}
@keyframes marquee-move{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* shared */
.eyebrow{display:inline-block;font-size:0.78rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--clay);font-weight:500}
.eyebrow-light{color:var(--sand)}
.fade-up{opacity:0;transform:translateY(28px);transition:opacity 0.7s ease,transform 0.7s ease}
.fade-up.visible{opacity:1;transform:none}

/* story */
.story{padding:7rem 4rem 3rem;max-width:1400px;margin:0 auto}
.story-grid{display:grid;grid-template-columns:0.7fr 1.6fr 1fr;gap:3rem;margin-bottom:4rem}
.story-title{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(1.8rem,3vw,2.6rem);line-height:1.2;margin:0.6rem 0 1.4rem}
.story-title em{font-style:italic;color:var(--clay)}
.story-text{color:var(--ink-soft);font-size:1rem;line-height:1.75;margin-bottom:1rem;max-width:480px}
.story-col-stats{display:flex;flex-direction:column;gap:1.4rem;border-left:1px solid var(--line);padding-left:2rem}
.stat-line{display:flex;flex-direction:column}
.stat-num{font-family:'Fraunces',serif;font-size:2.1rem;color:var(--ink)}
.stat-label{font-size:0.78rem;color:var(--ink-soft);letter-spacing:0.02em}
.story-photos{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}
.story-photo{border-radius:20px;overflow:hidden;height:320px}
.story-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.6s ease}
.story-photo:hover img{transform:scale(1.05)}

/* menu */
.menu{padding:6rem 4rem;max-width:1100px;margin:0 auto}
.menu-head{margin-bottom:3rem}
.menu-title{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(2rem,4vw,3rem);margin-top:0.6rem}
.menu-list{display:flex;flex-direction:column}
.menu-row{display:grid;grid-template-columns:96px 1fr auto;align-items:center;gap:1.8rem;padding:1.6rem 0;border-bottom:1px solid var(--line);transition:padding-left 0.3s ease}
.menu-row:hover{padding-left:0.6rem}
.menu-row:first-child{border-top:1px solid var(--line)}
.menu-row-img{width:96px;height:96px;border-radius:16px;overflow:hidden;flex-shrink:0}
.menu-row-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.5s ease}
.menu-row:hover .menu-row-img img{transform:scale(1.08)}
.menu-row-cat{font-size:0.72rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--clay);font-weight:500}
.menu-row-name{font-family:'Fraunces',serif;font-weight:400;font-size:1.3rem;margin:0.25rem 0 0.35rem}
.menu-row-desc{font-size:0.88rem;color:var(--ink-soft);line-height:1.6;max-width:440px}
.menu-row-price{font-family:'Fraunces',serif;font-size:1.4rem;color:var(--ink);white-space:nowrap}

/* order */
.order{background:var(--ink);padding:6rem 4rem;text-align:center}
.order-inner{max-width:600px;margin:0 auto}
.order-title{font-family:'Fraunces',serif;font-weight:400;color:var(--paper);font-size:clamp(2rem,4vw,3rem);margin:0.8rem 0 1rem;line-height:1.15}
.order-sub{color:var(--sand);font-size:1rem;margin-bottom:2.6rem}
.order-cards{display:flex;gap:1.2rem;justify-content:center;flex-wrap:wrap}
.order-card{position:relative;display:flex;align-items:center;gap:1rem;background:rgba(250,249,246,0.06);border:1px solid rgba(250,249,246,0.15);border-radius:18px;padding:1.2rem 1.6rem;text-decoration:none;color:var(--paper);min-width:230px;overflow:hidden;transition:transform 0.3s ease,border-color 0.3s ease}
.order-card:hover{transform:translateY(-4px);border-color:rgba(250,249,246,0.3)}
.order-card-glow{position:absolute;left:var(--mx,50%);top:var(--my,50%);width:160px;height:160px;background:radial-gradient(circle,rgba(250,249,246,0.12),transparent 70%);transform:translate(-50%,-50%);opacity:0;transition:opacity 0.3s;pointer-events:none}
.order-card:hover .order-card-glow{opacity:1}
.order-icon{width:46px;height:46px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--paper);transition:transform 0.4s ease}
.order-icon img{width:100%;height:100%;object-fit:cover;display:block}
.order-card:hover .order-icon{transform:scale(1.08) rotate(-4deg)}
.order-card-text{display:flex;flex-direction:column;text-align:left;flex:1}
.order-card-name{font-family:'Fraunces',serif;font-size:1.1rem}
.order-card-tag{font-size:0.75rem;color:var(--sand)}
.order-arrow{font-size:1rem;color:var(--sand);transition:transform 0.25s ease,color 0.25s ease}
.order-card:hover .order-arrow{transform:translateX(4px);color:var(--clay)}

/* gelato */
.gelato{padding:7rem 4rem;max-width:1400px;margin:0 auto}
.gelato-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;align-items:start;margin-bottom:3.5rem}
.gelato-title{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(2rem,4vw,3rem);margin:0.6rem 0 1rem}
.gelato-desc{color:var(--ink-soft);font-size:1rem;line-height:1.7;max-width:420px;margin-bottom:1.8rem}
.gelato-legend{display:flex;flex-direction:column;gap:0.7rem}
.gelato-legend-item{display:flex;align-items:center;gap:0.7rem;font-size:0.9rem;color:var(--ink)}
.gelato-legend-item.muted{color:var(--ink-soft)}
.gelato-dot{width:11px;height:11px;border-radius:50%;flex-shrink:0;animation:dot-breathe 2.6s ease-in-out infinite}
.gelato-legend-item:nth-child(2) .gelato-dot{animation-delay:0.3s}
.gelato-legend-item:nth-child(3) .gelato-dot{animation-delay:0.6s}
.gelato-legend-item:nth-child(4) .gelato-dot{animation-delay:0.9s}
.gelato-legend-item:nth-child(5) .gelato-dot{animation-delay:1.2s}
@keyframes dot-breathe{0%,100%{transform:scale(1)}50%{transform:scale(1.3)}}
.gelato-photo{border-radius:24px;overflow:hidden;height:420px}
.gelato-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 6s ease}
.gelato-photo:hover img{transform:scale(1.05)}
.gelato-strip{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:1.2rem 0}
.gelato-strip-track{display:flex;gap:2.4rem;width:max-content;animation:strip-slide 20s linear infinite}
.gelato-strip-track:hover{animation-play-state:paused}
.gelato-strip-track span{font-family:'Fraunces',serif;font-style:italic;font-size:1.1rem;color:var(--ink-soft);white-space:nowrap}
@keyframes strip-slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* reviews */
.reviews{padding:7rem 4rem;max-width:1400px;margin:0 auto;background:var(--white);border-radius:36px}
.reviews-head{text-align:center;margin-bottom:3.5rem}
.reviews-title{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(2rem,4vw,3rem);margin-top:0.6rem}
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.6rem;margin-bottom:3rem}
.review-card{background:var(--paper);border-radius:20px;padding:2rem;transition:transform 0.3s ease}
.review-card:hover{transform:translateY(-4px)}
.review-stars{color:var(--clay);font-size:0.95rem;margin-bottom:1rem;display:inline-block;transition:transform 0.3s ease}
.review-card:hover .review-stars{transform:scale(1.08)}
.review-text{font-family:'Fraunces',serif;font-style:italic;font-size:0.98rem;color:var(--ink);line-height:1.7;margin-bottom:1.4rem}
.review-foot{display:flex;flex-direction:column;gap:0.1rem}
.review-name{font-size:0.88rem;font-weight:500;color:var(--ink)}
.review-meta{font-size:0.76rem;color:var(--ink-soft)}
.reviews-score{display:flex;align-items:baseline;justify-content:center;gap:0.7rem}
.reviews-score-num{font-family:'Fraunces',serif;font-size:2.4rem;color:var(--ink)}
.reviews-score-stars{color:var(--clay);font-size:1.1rem}
.reviews-score-label{font-size:0.85rem;color:var(--ink-soft)}

/* visit */
.visit{padding:7rem 4rem;max-width:1400px;margin:0 auto}
.visit-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:4rem;align-items:start}
.visit-title{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(2.2rem,4vw,3.4rem);line-height:1.1;margin:0.6rem 0 2rem}
.visit-block{margin-bottom:1.6rem}
.visit-label{font-size:0.75rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--clay);font-weight:500;display:block;margin-bottom:0.4rem}
.visit-value{font-size:0.95rem;color:var(--ink-soft);line-height:1.7}
.visit-value a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--clay)}
.visit-tags{display:flex;flex-wrap:wrap;gap:0.5rem;margin-bottom:2rem}
.visit-tag{background:var(--white);border:1px solid var(--line);border-radius:20px;padding:0.4rem 0.9rem;font-size:0.78rem;color:var(--ink-soft)}
.visit-map{border-radius:24px;overflow:hidden;height:460px;background:var(--sand)}
.visit-map iframe{width:100%;height:100%;border:none;filter:saturate(0.75) contrast(1.05)}

/* footer */
footer{background:var(--ink);color:rgba(250,249,246,0.6);padding:4rem 4rem 2rem;font-size:0.85rem}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:3rem;margin-bottom:3rem;max-width:1400px;margin-left:auto;margin-right:auto}
.footer-mark{display:flex;align-items:center;gap:0.6rem;font-family:'Fraunces',serif;font-size:1.2rem;color:var(--paper);margin-bottom:0.9rem}
.footer-desc{line-height:1.7;max-width:300px}
.footer-col{display:flex;flex-direction:column;gap:0.7rem}
.footer-col-title{font-size:0.75rem;letter-spacing:0.12em;text-transform:uppercase;color:rgba(250,249,246,0.4);margin-bottom:0.5rem}
.footer-col a{color:rgba(250,249,246,0.6);text-decoration:none;transition:color 0.2s}
.footer-col a:hover{color:var(--clay)}
.footer-bottom{border-top:1px solid rgba(250,249,246,0.12);padding-top:1.5rem;text-align:center;max-width:1400px;margin:0 auto}

/* fab */
.fab{position:fixed;bottom:2rem;right:2rem;z-index:90;background:var(--ink);color:var(--paper);border:none;border-radius:30px;padding:0.85rem 1.6rem;font-size:0.82rem;font-weight:500;cursor:pointer;box-shadow:0 8px 24px rgba(43,40,38,0.25);transition:all 0.3s;text-decoration:none;animation:fab-bob 2.8s ease-in-out infinite}
.fab:hover{background:var(--clay);transform:translateY(-3px);animation:none}
@keyframes fab-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}

@media(max-width:980px){
  nav{padding:1.1rem 1.5rem}
  .nav-links{display:none}
  .hero{grid-template-columns:1fr;padding:8rem 1.5rem 3rem;gap:2.5rem}
  .hero-frame{order:-1}
  .story,.menu,.gelato,.visit{padding:5rem 1.5rem}
  .story-grid{grid-template-columns:1fr;gap:1.5rem}
  .story-col-stats{border-left:none;padding-left:0;flex-direction:row;flex-wrap:wrap;gap:2rem}
  .story-photos{grid-template-columns:1fr 1fr}
  .story-photo{height:240px}
  .story-photo:first-child{grid-column:1/-1;height:280px}
  .menu-row{grid-template-columns:72px 1fr;row-gap:0.4rem}
  .menu-row-price{grid-column:2;justify-self:start}
  .gelato-grid{grid-template-columns:1fr}
  .visit-grid{grid-template-columns:1fr}
  .reviews{padding:5rem 1.5rem;border-radius:0}
  .footer-top{grid-template-columns:1fr 1fr}
}
