/* ===========================================================
   PATTAYA PULSE — Editorial / magazine design system
   Serif display + serif body + mono labels. Print-inspired.
   =========================================================== */

:root{
  --ink:#16140f;
  --ink-soft:#43403a;
  --paper:#f7f3ea;
  --paper-2:#efe9db;
  --card:#fffdf8;
  --rule:#d8d0bf;
  --rule-strong:#16140f;
  --accent:#c0432b;
  --accent-ink:#7d2a18;
  --teal:#1f5d63;
  --gold:#b8862f;

  --display:"Playfair Display",Georgia,"Times New Roman",serif;
  --serif:"Newsreader",Georgia,"Times New Roman",serif;
  --mono:"IBM Plex Mono",ui-monospace,Menlo,monospace;

  --wrap:1200px;
  --measure:680px;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--serif);
  font-size:clamp(17px,1.15vw,19px);line-height:1.62;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility}
img{max-width:100%;display:block}
a{color:var(--accent-ink);text-underline-offset:3px}
::selection{background:var(--accent);color:#fff}

h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.05;margin:0 0 .4em;letter-spacing:-.01em}
h1{font-size:clamp(2.6rem,6.5vw,5.2rem);font-weight:700}
h2{font-size:clamp(1.9rem,3.4vw,2.9rem)}
h3{font-size:clamp(1.3rem,2vw,1.7rem)}
p{margin:0 0 1.15em}

.wrap{width:min(100% - 2.6rem,var(--wrap));margin-inline:auto}
.measure{max-width:var(--measure)}

.kicker{font-family:var(--mono);text-transform:uppercase;letter-spacing:.22em;font-size:.7rem;
  font-weight:500;color:var(--accent);display:inline-block}
.kicker.muted{color:var(--ink-soft)}
.dek{font-family:var(--serif);font-style:italic;color:var(--ink-soft);font-size:1.2rem;line-height:1.5}

hr.thin{border:0;border-top:1px solid var(--rule);margin:2.4rem 0}

.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--mono);font-size:.8rem;
  text-transform:uppercase;letter-spacing:.12em;font-weight:500;padding:.85rem 1.4rem;
  border:1.5px solid var(--ink);background:var(--ink);color:var(--paper);cursor:pointer;
  text-decoration:none;transition:all .18s ease}
.btn:hover{background:transparent;color:var(--ink)}
.btn-out{background:transparent;color:var(--ink)}
.btn-out:hover{background:var(--ink);color:var(--paper)}
.btn-accent{background:var(--accent);border-color:var(--accent);color:#fff}
.btn-accent:hover{background:transparent;color:var(--accent)}

/* MASTHEAD */
.masthead{border-bottom:2px solid var(--ink);position:sticky;top:0;z-index:60;background:var(--paper)}
.masthead .top{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.5rem 0;border-bottom:1px solid var(--rule)}
.masthead .issue{font-family:var(--mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft)}
.brand{font-family:var(--display);font-weight:700;font-size:1.65rem;letter-spacing:-.01em;color:var(--ink);
  text-decoration:none;display:flex;align-items:center;gap:.55rem;line-height:1}
.brand .mk{width:30px;height:30px}
.masthead nav{display:flex;gap:1.4rem;align-items:center;padding:.55rem 0;flex-wrap:wrap}
.masthead nav a{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;
  color:var(--ink);text-decoration:none;opacity:.78}
.masthead nav a:hover{opacity:1;color:var(--accent)}
.menu-btn{display:none;background:none;border:0;cursor:pointer}
.menu-btn svg{width:26px;height:26px}

/* COVER */
.cover{padding:clamp(2.4rem,6vw,5rem) 0 clamp(1.6rem,3vw,2.6rem)}
.cover h1{margin:.3rem 0 .2rem}
.cover h1 em{font-style:italic;color:var(--accent)}
.cover .stand{font-size:clamp(1.15rem,1.7vw,1.4rem);color:var(--ink-soft);max-width:40ch;line-height:1.5}
.cover .meta{display:flex;flex-wrap:wrap;gap:1.8rem;margin-top:1.4rem;font-family:var(--mono);
  font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.cover-cta{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:1.7rem}

.band{position:relative;width:100vw;left:50%;transform:translateX(-50%);
  height:clamp(220px,38vw,440px);overflow:hidden;background:var(--teal)}
.band .duo{position:absolute;inset:0;background:linear-gradient(135deg,var(--teal),#0d3a3f 60%,#16140f)}
.band .duo::after{content:"";position:absolute;inset:0;mix-blend-mode:overlay;opacity:.5;
  background:radial-gradient(80% 120% at 70% 10%,rgba(192,67,43,.7),transparent 55%)}
.band .label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--display);
  font-style:italic;color:rgba(255,255,255,.92);font-size:clamp(1.6rem,4vw,3rem);text-align:center;width:90%}

/* SECTION HEAD */
section{padding:clamp(2.6rem,5vw,4.2rem) 0}
.sec-head{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:baseline;
  border-top:2px solid var(--ink);padding-top:1rem;margin-bottom:1.8rem}
.sec-head .no{font-family:var(--mono);font-size:.8rem;color:var(--accent);letter-spacing:.1em}
.sec-head h2{margin:0}
.sec-head .dek{grid-column:2;margin-top:.3rem}

/* FEATURE GRID */
.feature-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1.6rem 1.8rem}
.fcard{grid-column:span 4;border-top:1px solid var(--rule);padding-top:1rem;text-decoration:none;
  color:var(--ink);display:flex;flex-direction:column;gap:.5rem;transition:transform .2s ease}
.fcard:hover{transform:translateY(-3px)}
.fcard:hover h3{color:var(--accent)}
.fcard .no{font-family:var(--mono);font-size:.72rem;color:var(--accent);letter-spacing:.1em}
.fcard h3{margin:0;font-size:1.4rem;line-height:1.1}
.fcard p{margin:0;color:var(--ink-soft);font-size:.96rem}
.fcard.lead{grid-column:span 6}
.fcard.lead h3{font-size:2rem}
.fcard .thumb{height:160px;margin-bottom:.4rem;background:linear-gradient(135deg,var(--teal),#0d3a3f)}
.fcard .thumb.a{background:linear-gradient(135deg,#c0432b,#7d2a18)}
.fcard .thumb.b{background:linear-gradient(135deg,#1f5d63,#0d3a3f)}
.fcard .thumb.c{background:linear-gradient(135deg,#b8862f,#6e4d12)}
.fcard .thumb.d{background:linear-gradient(135deg,#2b6fb3,#173e74)}
.fcard .read{font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}

/* ARTICLE / PROSE */
.article{max-width:var(--measure);margin-inline:auto}
.prose p,.prose ul,.prose ol{font-size:1.08rem}
.prose h2{margin-top:2.2rem}
.prose h3{margin-top:1.7rem}
.prose ul,.prose ol{padding-left:1.3rem;margin:0 0 1.2rem}
.prose li{margin-bottom:.5rem}
.prose a{color:var(--accent-ink)}
.dropcap::first-letter{font-family:var(--display);font-weight:700;float:left;font-size:4.4rem;line-height:.78;
  padding:.05em .12em 0 0;color:var(--accent)}
.standfirst{font-style:italic;font-size:1.3rem;line-height:1.5;color:var(--ink-soft);
  border-left:3px solid var(--accent);padding-left:1.1rem;margin:0 0 1.8rem}
.byline{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:.7rem 0;margin:0 0 2rem;
  display:flex;gap:1.4rem;flex-wrap:wrap}

.keyfact{background:var(--card);border:1px solid var(--rule);border-left:4px solid var(--accent);
  padding:1.2rem 1.4rem;margin:0 0 1.9rem;font-size:1.06rem}
.keyfact .k{font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent);display:block;margin-bottom:.4rem}

.pull{font-family:var(--display);font-style:italic;font-size:clamp(1.5rem,3vw,2.1rem);line-height:1.18;
  color:var(--ink);margin:2rem 0;padding:0 0 0 1.2rem;border-left:3px solid var(--ink)}

figure{margin:2rem 0}
figure .img{height:clamp(200px,30vw,340px);background:linear-gradient(135deg,var(--teal),#0d3a3f)}
figure .img.a{background:linear-gradient(135deg,#c0432b,#7d2a18)}
figure .img.b{background:linear-gradient(135deg,#1f5d63,#0d3a3f)}
figure figcaption{font-family:var(--mono);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink-soft);padding-top:.5rem;border-top:1px solid var(--rule);margin-top:.5rem}

/* TABLES */
.table-wrap{margin:1.6rem 0;border-top:2px solid var(--ink);border-bottom:2px solid var(--ink)}
table{border-collapse:collapse;width:100%;font-size:.98rem}
caption{caption-side:top;text-align:left;font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--accent);padding:.6rem 0}
th,td{padding:.72rem .4rem;text-align:left;border-bottom:1px solid var(--rule);vertical-align:top}
thead th{font-family:var(--mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:500;border-bottom:1px solid var(--ink)}
tbody tr:last-child td{border-bottom:0}
td.num,th.num{text-align:right;font-family:var(--mono);font-variant-numeric:tabular-nums;white-space:nowrap}
.asof{font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin-top:.5rem}

/* FAQ */
.faq{border-top:2px solid var(--ink);margin-top:1rem}
.faq details{border-bottom:1px solid var(--rule)}
.faq summary{cursor:pointer;list-style:none;padding:1.05rem 0;font-family:var(--display);font-size:1.2rem;
  display:flex;justify-content:space-between;gap:1rem;align-items:baseline}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--mono);color:var(--accent);font-size:1.2rem}
.faq details[open] summary::after{content:"\2212"}
.faq details p{margin:0 0 1.1rem;color:var(--ink-soft)}

.aside{background:var(--paper-2);border:1px solid var(--rule);padding:1.3rem 1.5rem;margin:1.9rem 0}
.aside .k{font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent);display:block;margin-bottom:.4rem}
.aside p{margin:0}

.related{border-top:2px solid var(--ink);padding-top:1.2rem;margin-top:2.6rem}
.related a{display:flex;justify-content:space-between;gap:1rem;padding:.8rem 0;border-bottom:1px solid var(--rule);
  text-decoration:none;color:var(--ink);font-family:var(--display);font-size:1.25rem}
.related a:hover{color:var(--accent)}
.related a .arr{font-family:var(--mono);color:var(--accent)}

.news{background:var(--ink);color:var(--paper);padding:clamp(2rem,4vw,3.4rem) 0;margin-top:2rem}
.news h2{color:var(--paper)}
.news .kicker{color:var(--gold)}
.news form{display:flex;gap:.6rem;flex-wrap:wrap;max-width:460px;margin-top:1.2rem}
.news input{flex:1;min-width:220px;padding:.85rem 1rem;border:1px solid #4a463d;background:#211e18;
  color:var(--paper);font-family:var(--serif);font-size:1rem}
.news input::placeholder{color:#9a958a}
.news small{display:block;margin-top:.8rem;font-family:var(--mono);font-size:.68rem;letter-spacing:.06em;color:#9a958a}

.crumb{font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);padding:1.1rem 0 0}
.crumb a{color:var(--ink-soft);text-decoration:none}
.crumb a:hover{color:var(--accent)}

.colophon{border-top:2px solid var(--ink);margin-top:3rem;padding:2.4rem 0 2rem}
.colo-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:1.8rem}
.colophon h5{font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin:0 0 .9rem}
.colophon a{display:block;color:var(--ink);text-decoration:none;margin-bottom:.5rem;font-size:.98rem}
.colophon a:hover{color:var(--accent)}
.colophon .brand{font-size:1.5rem;margin-bottom:.6rem}
.colophon .blurb{color:var(--ink-soft);font-size:.95rem;max-width:34ch}
.colo-bottom{border-top:1px solid var(--rule);margin-top:2rem;padding-top:1.2rem;font-family:var(--mono);
  font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:.8rem}

.js .reveal{opacity:0;transform:translateY(16px);transition:opacity .6s,transform .6s}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none}}

@media (max-width:860px){
  .feature-grid{grid-template-columns:repeat(6,1fr)}
  .fcard,.fcard.lead{grid-column:span 6}
  .colo-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:600px){
  .masthead nav{display:none}
  .masthead nav.open{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem;
    position:absolute;top:100%;left:0;right:0;background:var(--paper);border-bottom:2px solid var(--ink);padding:1rem 1.3rem}
  .menu-btn{display:block}
  .colo-grid{grid-template-columns:1fr}
  .sec-head{grid-template-columns:1fr}
  .sec-head .dek{grid-column:1}
}
