/* ============================================================
   TANGERINE PHUKET — site styles
   Identity: v2H "Hobo Edition" · Midnight #061E2D
   Rules: 2-3 inks + ground · flat fills · 3px ink borders ·
   no shadows, no gradients, no rounded corners (except the fruit)
   ============================================================ */

@font-face{
  font-family:'Hobo BT';
  src:url('../assets/fonts/hobo-bt.ttf') format('truetype');
  font-weight:400;
  font-style:normal;
  font-display:swap;
}

:root{
  --paper:#F6F0E4; --paper-warm:#F3EBDC; --card:#FFFDF7;
  --ink:#1A1612;
  --midnight:#061E2D; --midnight-deep:#03141F;
  --moon:#EFE6CF; --moon-dim:#9FB6C4;
  --tangerine:#EE7F3F; --tango:#CE4028; --terracotta:#C0653A;
  --purple:#8F79B7; --monk:#774A1E; --chardonnay:#DCCB8B;
  --teal:#2F6F6A; --mustard:#E0B84F; --brick:#B2492E;
  --hobo:'Hobo BT','Hobo Std','Hobo',serif;
  --mono:'Space Mono',monospace;
  --border:3px solid var(--ink);
  --wrap:1100px;
  --page-pad:24px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:var(--mono);font-size:15.5px;line-height:1.65}
img,svg{display:block;max-width:100%}
a{color:inherit}
button,input,select,textarea{font:inherit}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--page-pad)}

h1,h2,h3{font-family:var(--hobo);font-weight:400;line-height:1.08}
h1{font-size:clamp(44px,7vw,92px)}
h2{font-size:clamp(30px,4.5vw,52px);margin-bottom:10px}
h3{font-size:clamp(19px,2.2vw,24px)}

.kicker{font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--terracotta);margin-bottom:12px}
.night .kicker{color:var(--mustard)}

/* ---------- buttons ---------- */
.btn{display:inline-block;font-family:var(--mono);font-weight:700;font-size:14px;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;border:var(--border);padding:12px 22px;background:var(--tangerine);color:var(--ink);cursor:pointer;transition:transform .08s ease}
.btn:hover{transform:translate(-2px,-2px)}
.btn:active{transform:translate(0,0)}
.btn.ghost{background:transparent}
.night .btn{border-color:var(--moon);color:var(--ink)}
.night .btn.ghost{color:var(--moon);background:transparent}
.btn.small{padding:7px 14px;font-size:12px}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:50;background:var(--paper);border-bottom:var(--border)}
.nav .bar{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;font-family:var(--hobo);font-size:24px;letter-spacing:.02em}
.brand img{height:34px;width:auto;flex:0 0 auto}
.navlinks{display:flex;gap:26px;list-style:none;align-items:center}
.navlinks a{text-decoration:none;font-weight:700;font-size:13px;letter-spacing:.1em;text-transform:uppercase;border-bottom:3px solid transparent;padding:4px 0}
.navlinks a:hover,.navlinks a.active{border-bottom-color:var(--tangerine)}
.navlinks .cta{border:var(--border);background:var(--tangerine);padding:8px 14px}
.navlinks .cta:hover{border-bottom-color:var(--ink)}
.burger{display:none;background:none;border:var(--border);padding:6px 10px;font-family:var(--mono);font-weight:700;cursor:pointer}

/* ---------- split hero ---------- */
.hero{display:grid;grid-template-columns:1fr 1fr;border-bottom:var(--border);min-height:560px}
.hero .half{padding-block:84px 56px;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end}
.hero .day-half{padding-left:max(40px,calc((100vw - var(--wrap)) / 2 + var(--page-pad)));padding-right:40px}
.hero .night-half{padding-left:40px;padding-right:max(40px,calc((100vw - var(--wrap)) / 2 + var(--page-pad)))}
.hero .day-half{background:var(--paper-warm)}
.hero .night-half{background:var(--midnight);color:var(--moon)}
.hero h1{margin-left:-.06em}
.hero h1 .dot{color:var(--tangerine)}
.hero .night-half h1{color:var(--moon)}
.hero .sub{font-weight:700;margin:14px 0 22px;font-size:14px;max-width:330px}
.hero .night-half .sub{color:var(--moon-dim)}
.hero .hours{font-size:12.5px;letter-spacing:.14em;text-transform:uppercase}
.hero .night-half .hours{color:var(--moon-dim)}
.heromoon{position:absolute;top:38px;right:44px;width:92px;height:auto}
.herolockup{width:100%;max-width:430px;margin-bottom:18px}
.herolockup span,.herolockup strong{display:block;font-family:var(--hobo);font-weight:400;line-height:.9;letter-spacing:.01em}
.herolockup span{font-size:clamp(38px,5.2vw,70px);color:var(--moon)}
.herolockup strong{font-size:clamp(58px,8vw,112px);color:var(--tangerine);text-transform:none;margin-top:-2px}
.herolockup small{display:block;font-family:var(--mono);font-weight:700;font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--moon-dim);margin-top:12px}
.herosteam{position:absolute;top:30px;left:max(40px,calc((100vw - var(--wrap)) / 2 + var(--page-pad)))}

/* stripes strip under hero */
.stripebar{display:flex;height:12px;border-bottom:var(--border)}
.stripebar div{flex:1}

/* ---------- sections ---------- */
section{padding:78px 0}
section.bordered{border-bottom:var(--border)}
.night{background:var(--midnight);color:var(--moon)}
.night h2,.night h3{color:var(--moon)}
.lede{max-width:640px;margin-bottom:18px}
.night .muted,.muted{font-size:13px}
.muted{color:#5a5248}
.night .muted{color:var(--moon-dim)}

/* two-column info */
.twocol{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:start}

/* ---------- tempo cards (hours) ---------- */
.tempo{display:grid;grid-template-columns:1fr 1fr;border:var(--border);margin-top:26px}
.tempo>div{padding:30px}
.tempo .t-day{background:var(--card)}
.tempo .t-night{background:var(--midnight);color:var(--moon)}
.tempo h3 span{color:var(--tangerine)}
.tempo .hrs{margin-top:12px;font-size:13.5px;line-height:2}
.tempo .t-night .hrs{color:var(--moon-dim)}

/* ---------- menu teaser ---------- */
.menucols{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:26px}
.menucard{border:var(--border);background:var(--card);padding:26px}
.night .menucard{background:var(--midnight-deep);border-color:var(--moon)}
.menucard h3{margin-bottom:14px}
.menucard table{width:100%;border-collapse:collapse;font-size:13.5px}
.menucard td{padding:7px 0;border-bottom:1.5px dashed currentColor}
.menucard tr:last-child td{border-bottom:none}
.menucard td:last-child{text-align:right;font-weight:700}

/* ---------- event cards ---------- */
.evgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));gap:22px;margin-top:26px}
.evcard{border:var(--border);display:flex;flex-direction:column;text-align:left}
.evcard.day-ev{background:var(--card);color:var(--ink)}
.evcard.night-ev{background:var(--midnight);color:var(--moon);border-color:var(--ink)}
.on-night .evcard.night-ev{border-color:var(--moon)}
.evcard .evdate{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-bottom:var(--border);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.evcard.night-ev .evdate{border-bottom-color:var(--moon);color:var(--moon-dim)}
.evcard .evbody{padding:18px 16px;flex:1}
.evcard h3{font-size:21px;margin-bottom:8px}
.evcard .evmeta{font-size:12.5px;line-height:1.9}
.evcard.night-ev .evmeta{color:var(--moon-dim)}
.evcard .evfoot{padding:0 16px 18px}
.tempo-pill{font-size:10px;letter-spacing:.14em;padding:2px 8px;border:1.5px solid currentColor;text-transform:uppercase}

/* ---------- calendar ---------- */
.calhead{display:flex;align-items:center;justify-content:space-between;margin:26px 0 14px}
.calhead h3{font-size:clamp(22px,3vw,30px)}
.calnav{display:flex;gap:10px}
.calnav button{border:var(--border);background:var(--card);font-family:var(--mono);font-weight:700;font-size:16px;width:42px;height:42px;cursor:pointer}
.calnav button:hover{background:var(--tangerine)}
.calendar{border:var(--border);background:var(--card);overflow-x:auto;-webkit-overflow-scrolling:touch}
.calrow{display:grid;grid-template-columns:repeat(7,1fr)}
.caldow{padding:10px 6px;text-align:center;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;border-bottom:var(--border);background:var(--paper-warm)}
.calcell{min-height:96px;border-right:1.5px solid #d8cfbc;border-bottom:1.5px solid #d8cfbc;padding:6px;font-size:12px;position:relative}
.calcell:nth-child(7n){border-right:none}
.calrow:last-child .calcell{border-bottom:none}
.calcell .dnum{font-weight:700;font-size:12px}
.calcell.other{background:#EDE5D2;color:#a39880}
.calcell.today .dnum{display:inline-block;background:var(--tangerine);border:1.5px solid var(--ink);padding:0 5px}
.calev{display:block;width:100%;text-align:left;margin-top:4px;border:1.5px solid var(--ink);font-family:var(--mono);font-size:10.5px;font-weight:700;padding:3px 5px;cursor:pointer;line-height:1.3;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.calev.day-ev{background:var(--paper);color:var(--ink)}
.calev.night-ev{background:var(--midnight);color:var(--moon)}
.calev:hover{border-color:var(--tangerine)}
.callegend{display:flex;gap:22px;margin-top:14px;font-size:12px;align-items:center}
.callegend .key{display:inline-block;width:14px;height:14px;border:1.5px solid var(--ink);margin-right:7px;vertical-align:-2px}

/* ---------- modal ---------- */
.modalback{position:fixed;inset:0;background:rgba(6,30,45,.82);display:none;align-items:flex-start;justify-content:center;z-index:100;padding:40px 16px;overflow-y:auto}
.modalback.open{display:flex}
.modal{background:var(--card);border:var(--border);max-width:560px;width:100%;color:var(--ink)}
.modal .mhead{display:flex;justify-content:space-between;align-items:flex-start;padding:22px 24px;border-bottom:var(--border)}
.modal .mhead.nightside{background:var(--midnight);color:var(--moon);border-bottom:none}
.modal .mhead h3{font-size:26px;max-width:420px}
.modal .x{background:none;border:var(--border);font-family:var(--mono);font-weight:700;font-size:15px;width:38px;height:38px;cursor:pointer;flex:0 0 auto;margin-left:14px;background:var(--card)}
.modal .mbody{padding:24px}
.modal .evmeta{font-size:13px;line-height:2;margin-bottom:14px}
.modal .desc{font-size:13.5px;margin-bottom:18px}
.spots{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;display:inline-block;border:1.5px solid var(--ink);padding:3px 9px;margin-bottom:18px}
.spots.low{background:var(--mustard)}
.spots.full{background:var(--tango);color:var(--paper)}

/* form */
.bform label{display:block;font-size:11.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin:14px 0 5px}
.bform input,.bform select,.bform textarea{width:100%;border:var(--border);background:var(--paper);font-family:var(--mono);font-size:14px;padding:10px 12px;color:var(--ink)}
.bform input:focus,.bform select:focus,.bform textarea:focus{outline:3px solid var(--tangerine);outline-offset:-1px}
.bform .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.bform .btn{width:100%;margin-top:20px}
.formnote{font-size:11.5px;color:#5a5248;margin-top:10px}
.confirm{border:var(--border);background:var(--paper-warm);padding:18px;margin-top:18px;font-size:13.5px;display:none}
.confirm.show{display:block}
.confirm b{display:block;font-family:var(--hobo);font-size:19px;margin-bottom:6px;color:var(--teal)}
.confirm.error b{color:var(--tango)}

/* ---------- find us ---------- */
.findus .mapbox{border:var(--border);background:var(--card);padding:26px}
.findus .mapbox p{margin-bottom:8px;font-size:14px}

/* ---------- footer ---------- */
footer{background:var(--midnight);color:var(--moon);border-top:var(--border)}
footer .fgrid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:36px;padding:56px 0 40px}
footer h3{font-family:var(--hobo);font-size:24px;margin-bottom:12px;color:var(--moon)}
footer ul{list-style:none;font-size:13px;line-height:2.2}
footer a{color:var(--moon-dim);text-decoration:none}
footer a:hover{color:var(--tangerine)}
footer .seal{width:56px;height:auto;margin-bottom:16px}
footer .legal{border-top:1.5px dashed #1E4258;padding:18px 0 26px;font-size:11.5px;color:var(--moon-dim);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}

/* ---------- page head (inner pages) ---------- */
.pagehead{background:var(--midnight);color:var(--moon);border-bottom:var(--border);padding:64px 0 48px}
.pagehead h1{color:var(--moon);font-size:clamp(38px,6vw,72px)}
.pagehead h1 .dot{color:var(--tangerine)}
.pagehead p{max-width:560px;color:var(--moon-dim);margin-top:10px;font-size:14px}

/* ---------- responsive ---------- */
@media(max-width:1040px){
  .twocol{grid-template-columns:1fr;gap:28px}
  .tempo{max-width:620px}
}

@media(max-width:860px){
  .hero{grid-template-columns:1fr}
  .hero .half{min-height:300px;padding:60px 26px 36px}
  .hero .day-half,.hero .night-half{padding-inline:var(--page-pad)}
  .herosteam{left:var(--page-pad)}
  .twocol,.menucols,.tempo{grid-template-columns:1fr}
  footer .fgrid{grid-template-columns:1fr}
  .navlinks{display:none;position:absolute;top:64px;left:0;right:0;background:var(--paper);border-bottom:var(--border);flex-direction:column;padding:18px;gap:14px}
  .navlinks.open{display:flex}
  .burger{display:block}
  .calcell{min-height:64px}
  .calev{font-size:9px;padding:2px 3px}
}

@media(max-width:640px){
  body{font-size:14.5px;overflow-x:hidden}
  :root{--page-pad:18px}
  .wrap{padding:0 var(--page-pad)}
  h1{font-size:clamp(38px,14vw,54px)}
  h2{font-size:clamp(30px,10vw,40px)}
  section{padding:54px 0}
  .btn{display:block;width:100%;text-align:center;padding:13px 16px;min-height:48px}
  .btn.small{padding:10px 12px;min-height:42px}

  .nav .bar{height:58px}
  .brand{font-size:22px;min-width:0}
  .brand img{height:30px}
  .burger{min-height:42px;min-width:72px}
  .navlinks{top:58px;padding:16px}
  .navlinks a{display:block;padding:10px 0;text-align:center}
  .navlinks .cta{padding:11px 14px}

  .hero{min-height:0}
  .hero .half{min-height:auto;padding-block:96px 38px}
  .hero .night-half{padding-top:104px}
  .hero h1{margin-left:-.04em}
  .hero .sub{max-width:none;font-size:13.5px}
  .hero .hours{font-size:11.5px}
  .herosteam{top:18px;left:var(--page-pad);width:54px;height:auto}
  .heromoon{top:20px;right:var(--page-pad);width:68px}
  .herolockup{max-width:280px;margin-bottom:14px}
  .herolockup span{font-size:40px}
  .herolockup strong{font-size:66px}
  .herolockup small{font-size:8.5px;letter-spacing:.2em;margin-top:8px}
  .stripebar{height:10px}

  .tempo>div,.menucard,.findus .mapbox{padding:20px}
  .menucard table{font-size:12.5px;table-layout:fixed}
  .menucard td:first-child{padding-right:10px}
  .menucard td:last-child{width:74px;vertical-align:top}

  .evgrid{gap:16px}
  .evcard .evdate{align-items:flex-start;gap:10px;font-size:10.5px;letter-spacing:.08em}
  .evcard h3{font-size:22px}
  .evcard .evfoot{padding:0 16px 16px}
  .tempo-pill{font-size:9px;white-space:nowrap}

  .calhead{align-items:flex-end;gap:12px}
  .calnav button{width:46px;height:46px}
  .calendar{margin-inline:calc(var(--page-pad) * -1);border-left:none;border-right:none}
  .calrow{min-width:620px}
  .calcell{min-height:86px}
  .calev{font-size:10px;padding:3px 5px}
  .callegend{flex-direction:column;align-items:flex-start;gap:8px}

  .modalback{padding:10px}
  .modal{max-width:none}
  .modal .mhead{padding:18px 16px}
  .modal .mhead h3{font-size:24px}
  .modal .mbody{padding:18px 16px}
  .modal .x{width:42px;height:42px;margin-left:10px}
  .bform .row2{grid-template-columns:1fr}
  .bform input,.bform select,.bform textarea{font-size:16px}

  .pagehead{padding:48px 0 38px}
  footer .fgrid{gap:26px;padding:42px 0 30px}
}

@media(max-width:380px){
  :root{--page-pad:14px}
  .wrap{padding:0 var(--page-pad)}
  h1{font-size:clamp(36px,14vw,48px)}
  h2{font-size:clamp(28px,10vw,38px)}
  .brand{font-size:20px}
  .calendar{margin-inline:calc(var(--page-pad) * -1)}
  .calrow{min-width:580px}
}
