/* Thaiyo — "Good Cultures, Good Times" (bold illustrated, v5)
   Type: Rammetto One (strong chunky retro display) + Figtree (body) + Space Mono (labels)
   Real photos used throughout. No plant-based claims (not something they advertise). */

:root{
  --cream:#fdefcf;
  --cream-2:#fff8e8;
  --ink:#241a3a;
  --cobalt:#2a2fd0;
  --cobalt-deep:#1c1f9c;
  --orange:#ee7a29;
  --orange-deep:#d4640f;
  --green:#37a349;
  --green-deep:#1f7d2c;
  --pink:#f47a9d;
  --sky:#8fd6de;
  --marigold:#f6c246;

  --font-display:"Rammetto One",system-ui,sans-serif;
  --font-body:"Figtree",system-ui,sans-serif;
  --font-mono:"Space Mono",ui-monospace,monospace;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;background:var(--cream);color:var(--ink);
  font-family:var(--font-body);font-size:17.5px;line-height:1.6;font-weight:450;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative;
}
img{max-width:100%;display:block;}
a{color:inherit;}
h1,h2,h3{font-family:var(--font-display);font-weight:400;margin:0;line-height:1.02;letter-spacing:0;}
p{margin:0;}

.wrap{max-width:1160px;margin:0 auto;padding:0 clamp(20px,5vw,48px);position:relative;z-index:2;}
.kick{display:inline-block;font-family:var(--font-mono);font-weight:700;font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;}

/* buttons: flat, chunky, ink border, no offset shadow */
.btn{
  display:inline-flex;align-items:center;gap:9px;justify-content:center;
  font-family:var(--font-display);font-weight:400;font-size:15px;letter-spacing:.01em;
  padding:15px 26px;border-radius:999px;text-decoration:none;cursor:pointer;
  border:3px solid var(--ink);transition:transform .13s ease,background .13s ease,color .13s ease;
}
.btn:hover{transform:translateY(-2px);}
.btn:active{transform:translateY(0);}
.btn-cobalt{background:var(--cobalt);color:#fff;}
.btn-orange{background:var(--orange);color:var(--ink);}
.btn-cream{background:var(--cream-2);color:var(--ink);}
.btn-white{background:#fff;color:var(--ink);}
.btn-lg{font-size:17px;padding:17px 32px;}

/* header */
.head{position:sticky;top:0;z-index:60;background:var(--cream);border-bottom:3px solid var(--ink);}
.head .wrap{display:flex;align-items:center;justify-content:space-between;height:70px;gap:16px;}
.head .brand img{height:34px;width:auto;}
.head .nav{display:flex;align-items:center;gap:24px;}
.head .nav a.nlink{font-family:var(--font-body);font-weight:800;font-size:14px;letter-spacing:.02em;text-transform:uppercase;text-decoration:none;color:var(--ink);}
.head .nav a.nlink:hover{color:var(--orange-deep);}
@media(max-width:760px){.head .nav a.nlink{display:none;}}

/* HERO */
.hero{position:relative;background:var(--cobalt);color:#fff;overflow:hidden;padding:clamp(46px,7vw,84px) 0 clamp(84px,10vw,140px);}
.hero .rays{position:absolute;top:-45%;left:50%;transform:translateX(-50%);width:150vw;height:150vw;z-index:0;opacity:.12;pointer-events:none;background:repeating-conic-gradient(from 0deg at 50% 50%, var(--marigold) 0deg 8deg, transparent 8deg 16deg);}
.hero .wrap{position:relative;z-index:2;}
.hero .grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,56px);align-items:center;}
@media(max-width:900px){.hero .grid{grid-template-columns:1fr;gap:34px;}}
.hero .kick{color:var(--marigold);margin:0 0 20px;}
.hero h1{font-size:clamp(38px,6.4vw,80px);line-height:.98;color:#fff;text-shadow:3px 3px 0 rgba(0,0,0,.18);}
.hero h1 .o{color:var(--orange);}
.hero h1 .p{color:var(--pink);}
.hero .sub{font-size:clamp(18px,2vw,21px);color:#dfe0ff;max-width:40ch;margin:24px 0 0;font-weight:500;}
.hero .cta-row{display:flex;gap:13px;flex-wrap:wrap;margin:30px 0 0;}
.hero .shot{position:relative;justify-self:center;max-width:400px;}
.hero .shot .frame{position:relative;background:var(--cream-2);border:4px solid var(--ink);border-radius:30px;padding:12px;transform:rotate(-3deg);box-shadow:12px 12px 0 rgba(0,0,0,.22);}
.hero .shot img{display:block;border-radius:20px;width:100%;height:auto;}
.hero .shot .sticker{position:absolute;bottom:-20px;right:-14px;background:var(--marigold);color:var(--ink);border:3px solid var(--ink);border-radius:999px;padding:11px 18px;transform:rotate(6deg);font-family:var(--font-display);font-size:14px;line-height:1;z-index:3;}

/* wave divider */
.wave{display:block;line-height:0;position:relative;z-index:1;}
.wave svg{display:block;width:100%;height:clamp(36px,6vw,74px);}

/* CATCH (gig-flyer stop) */
.catch{background:var(--orange);color:var(--ink);padding:clamp(28px,4vw,42px) 0 clamp(44px,6vw,68px);}
.catch .flyer{background:var(--cream-2);border:4px solid var(--ink);border-radius:22px;overflow:hidden;box-shadow:10px 10px 0 rgba(0,0,0,.16);max-width:900px;margin:0 auto;}
.catch .flyer .bar{background:var(--ink);color:var(--marigold);padding:12px 26px;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;}
.catch .flyer .bar .l{font-family:var(--font-display);font-size:15px;}
.catch .flyer .bar .r{font-family:var(--font-body);font-weight:800;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#fff;display:inline-flex;align-items:center;gap:8px;}
.catch .flyer .bar .r .dot{width:9px;height:9px;border-radius:50%;background:var(--green);animation:pulse 2s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(55,163,73,.6);}70%{box-shadow:0 0 0 9px rgba(55,163,73,0);}100%{box-shadow:0 0 0 0 rgba(55,163,73,0);}}
.catch .flyer .body{padding:clamp(24px,3.5vw,38px);display:grid;grid-template-columns:1.3fr .7fr;gap:clamp(20px,3vw,40px);align-items:center;}
@media(max-width:720px){.catch .flyer .body{grid-template-columns:1fr;gap:22px;}}
.catch .flyer .where{font-family:var(--font-display);font-size:clamp(24px,4vw,40px);line-height:1.05;color:var(--ink);}
.catch .flyer .when{margin:16px 0 0;font-family:var(--font-body);font-weight:800;font-size:clamp(15px,2vw,19px);color:var(--orange-deep);}
.catch .flyer .acts{display:flex;flex-direction:column;gap:11px;}
.catch .flyer .acts .btn{width:100%;}
.catch .note{text-align:center;margin:22px auto 0;font-weight:600;max-width:60ch;}
.catch .note a{color:var(--ink);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:2px;}

/* section heading block */
.hblock{text-align:center;max-width:46ch;margin:0 auto clamp(28px,4vw,44px);}
.hblock .kick{color:var(--orange-deep);margin:0 0 14px;}
.hblock h2{font-size:clamp(30px,5vw,58px);color:var(--cobalt);line-height:1.02;}
.hblock p{margin:14px 0 0;font-weight:500;opacity:.85;}

/* GALLERY (fresh from the pop-up) */
.gallery{background:var(--cream);padding:clamp(46px,6vw,84px) 0;}
.ggrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
@media(max-width:640px){.ggrid{grid-template-columns:repeat(2,1fr);}}
.gcell{position:relative;aspect-ratio:1/1;border:3px solid var(--ink);border-radius:18px;overflow:hidden;background:var(--ink);}
.gcell img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease;}
.gcell:hover img{transform:scale(1.06);}

/* MENU (rainbow) */
.menu{background:var(--cream);padding:clamp(20px,3vw,36px) 0 clamp(52px,7vw,92px);}
.menu .plant{display:inline-block;background:var(--green);color:#fff;border:3px solid var(--ink);border-radius:999px;padding:7px 16px;font-family:var(--font-body);font-weight:800;font-size:12px;letter-spacing:.12em;text-transform:uppercase;margin:0 0 4px;transform:rotate(-2deg);}
.rainbow{display:grid;grid-template-columns:repeat(auto-fit,minmax(215px,1fr));gap:16px;}
.drink{border:4px solid var(--ink);border-radius:22px;padding:22px 22px 24px;position:relative;transition:transform .15s ease;}
.drink:hover{transform:translateY(-5px) rotate(-1deg);}
.drink .num{font-family:var(--font-body);font-weight:800;font-size:12px;letter-spacing:.1em;opacity:.6;}
.drink h3{font-size:clamp(21px,2.4vw,26px);margin:8px 0 0;line-height:1;}
.drink p{font-size:14.5px;margin:10px 0 0;font-weight:500;line-height:1.45;}
.drink .price{margin:14px 0 0;font-family:var(--font-display);font-size:15px;}
.d-tea{background:var(--orange);color:var(--ink);}
.d-matcha{background:var(--green);color:#fff;}
.d-hojicha{background:#c98a3e;color:var(--ink);}
.d-pandan{background:var(--sky);color:var(--ink);}
.d-calamansi{background:var(--marigold);color:var(--ink);}
.d-seasonal{background:var(--pink);color:var(--ink);}
.d-ube{background:#9d7cc0;color:#fff;}
.menu-more{max-width:64ch;margin:clamp(24px,3vw,34px) auto 0;text-align:center;font-weight:500;color:var(--ink);opacity:.85;}
.menu-more a{color:var(--cobalt);font-weight:800;text-decoration:underline;text-underline-offset:3px;white-space:nowrap;}
.menu .mfoot{display:flex;gap:clamp(20px,4vw,44px);align-items:center;flex-wrap:wrap;margin:clamp(28px,4vw,44px) 0 0;}
.menu .mfoot .shot{flex:0 0 auto;position:relative;transform:rotate(2deg);}
.menu .mfoot .shot img{width:clamp(200px,28vw,280px);height:auto;border:4px solid var(--ink);border-radius:22px;display:block;}
.menu .mfoot .shot .tag{position:absolute;top:-14px;left:-12px;background:var(--cobalt);color:#fff;border:3px solid var(--ink);border-radius:999px;padding:8px 14px;font-family:var(--font-display);font-size:12px;transform:rotate(-6deg);}
.menu .mfoot .txt{flex:1;min-width:240px;}
.menu .mfoot .txt h3{font-family:var(--font-display);font-size:clamp(22px,3vw,32px);color:var(--ink);line-height:1.05;}
.menu .mfoot .txt p{margin:14px 0 0;font-weight:500;}
.menu .mfoot .txt a{color:var(--cobalt);font-weight:800;text-decoration:underline;text-underline-offset:3px;}

/* STORY */
.story{background:var(--green);color:#fff;padding:clamp(54px,8vw,100px) 0;position:relative;overflow:hidden;}
.story .grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(30px,5vw,60px);align-items:center;}
@media(max-width:860px){.story .grid{grid-template-columns:1fr;gap:30px;}}
.story .shot{position:relative;transform:rotate(-2deg);}
.story .shot img{width:100%;height:auto;border:4px solid var(--ink);border-radius:24px;display:block;box-shadow:10px 10px 0 rgba(0,0,0,.18);}
.story .kick{color:#eafff0;opacity:.9;margin:0 0 14px;}
.story h2{font-size:clamp(30px,5.4vw,64px);color:#fff;line-height:1;text-shadow:3px 3px 0 rgba(0,0,0,.14);}
.story h2 .y{color:var(--marigold);}
.story .lead{font-size:clamp(17px,2vw,20px);color:#e6fff0;max-width:46ch;margin:22px 0 26px;font-weight:500;}
.story .tenets{display:grid;gap:12px;}
.story .tenet{display:flex;gap:14px;align-items:baseline;background:rgba(255,255,255,.12);border:3px solid var(--ink);border-radius:16px;padding:16px 18px;}
.story .tenet .n{font-family:var(--font-display);font-size:15px;color:var(--marigold);}
.story .tenet b{font-family:var(--font-display);font-size:16px;color:#fff;display:block;line-height:1.1;}
.story .tenet p{margin:6px 0 0;color:#eafff0;font-size:14px;font-weight:500;}

/* ROUTE */
.route{background:var(--cream);padding:clamp(54px,7vw,92px) 0;}
.route .rgrid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,34px);align-items:center;}
@media(max-width:820px){.route .rgrid{grid-template-columns:1fr;}}
.route .rphotos{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.route .rphotos .rp{position:relative;border:3px solid var(--ink);border-radius:18px;overflow:hidden;}
.route .rphotos .rp img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:3/4;}
.route .rphotos .rp.tall{grid-row:span 2;}
.route .rphotos .rp.tall img{aspect-ratio:3/5;}
.route h2{font-size:clamp(30px,5vw,54px);color:var(--cobalt);line-height:1.02;}
.route .intro{margin:14px 0 24px;font-weight:500;opacity:.85;max-width:42ch;}
.stops{display:grid;gap:10px;}
.stopr{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;background:var(--cream-2);border:3px solid var(--ink);border-radius:16px;padding:15px 18px;}
.stopr .date{font-family:var(--font-display);font-size:13px;color:var(--orange-deep);white-space:nowrap;}
.stopr .spot{font-family:var(--font-body);font-weight:800;font-size:clamp(16px,2vw,19px);color:var(--ink);}
.stopr .spot small{display:block;font-weight:500;font-size:13.5px;opacity:.7;}
.stopr .tag{font-family:var(--font-body);font-weight:800;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;border:3px solid var(--ink);border-radius:999px;padding:5px 11px;white-space:nowrap;}
.tag-next{background:var(--green);color:#fff;}
.tag-past{background:transparent;color:var(--ink);opacity:.6;}
.route .rnote{margin:22px 0 0;font-weight:600;}
.route .rnote a{color:var(--cobalt);text-decoration:underline;text-underline-offset:3px;}
@media(max-width:600px){.stopr{grid-template-columns:1fr auto;}.stopr .date{grid-column:1/-1;}}

/* DROP */
.drop{background:var(--pink);color:var(--ink);padding:clamp(56px,8vw,110px) 0;position:relative;overflow:hidden;}
.drop .rays{position:absolute;top:-60%;left:50%;transform:translateX(-50%);width:150vw;height:150vw;z-index:0;opacity:.12;pointer-events:none;background:repeating-conic-gradient(from 0deg at 50% 50%, #fff 0deg 7deg, transparent 7deg 14deg);}
.drop .wrap{position:relative;z-index:2;}
.drop .grid{display:grid;grid-template-columns:1fr .8fr;gap:clamp(28px,5vw,56px);align-items:center;}
@media(max-width:820px){.drop .grid{grid-template-columns:1fr;gap:30px;text-align:center;}}
.drop .kick{color:var(--cobalt);margin:0 0 12px;}
.drop h2{font-size:clamp(38px,7vw,84px);color:var(--ink);line-height:.98;text-shadow:3px 3px 0 rgba(255,255,255,.4);}
.drop p{font-size:18px;max-width:40ch;margin:20px 0 30px;font-weight:600;}
@media(max-width:820px){.drop p{margin-left:auto;margin-right:auto;}}
.drop .acts{display:flex;gap:14px;flex-wrap:wrap;}
@media(max-width:820px){.drop .acts{justify-content:center;}}
.drop .handles{margin:26px 0 0;display:flex;gap:20px;flex-wrap:wrap;font-family:var(--font-mono);font-weight:700;font-size:13px;}
@media(max-width:820px){.drop .handles{justify-content:center;}}
.drop .handles a{color:var(--ink);text-decoration:none;border-bottom:3px solid var(--cobalt);padding-bottom:2px;}
.drop .shot{position:relative;transform:rotate(2deg);}
.drop .shot img{width:100%;height:auto;border:4px solid var(--ink);border-radius:24px;display:block;box-shadow:10px 10px 0 rgba(36,26,58,.2);}

/* FOOTER */
.foot{background:var(--ink);color:#e7e3f5;padding:clamp(44px,6vw,68px) 0 30px;}
.foot .top{display:flex;justify-content:space-between;gap:34px;flex-wrap:wrap;align-items:flex-start;}
.foot .fbrand{max-width:34ch;}
.foot .fbrand img{height:40px;width:auto;margin:0 0 14px;filter:brightness(0) invert(1);opacity:.95;}
.foot .fbrand p{margin:0;font-size:15px;color:#b3aecf;font-weight:500;}
.foot .cols{display:flex;gap:54px;flex-wrap:wrap;}
.foot h4{font-family:var(--font-body);font-weight:800;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--marigold);margin:0 0 14px;}
.foot a.flink{display:block;color:#e7e3f5;text-decoration:none;font-size:15.5px;margin:0 0 10px;font-weight:600;}
.foot a.flink:hover{color:#fff;}
.foot .colo{margin:clamp(34px,4vw,50px) 0 0;padding:20px 0 0;border-top:2px solid rgba(255,255,255,.16);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-family:var(--font-mono);font-size:12px;color:#8f89b0;}

/* sticky mobile bar */
.mobar{position:fixed;left:0;right:0;bottom:0;z-index:70;display:none;gap:10px;padding:10px 14px calc(10px + env(safe-area-inset-bottom));background:var(--cream);border-top:3px solid var(--ink);}
.mobar .btn{flex:1;padding:13px 12px;font-size:14px;}
@media(max-width:760px){.mobar{display:flex;}body{padding-bottom:76px;}}

/* reveal */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s cubic-bezier(.2,.7,.2,1),transform .6s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}
