/* Bali Surf Express — warm volcanic-sunset palette, asymmetric editorial layout.
   Deliberately distinct from the other network sites (own colours, own structure). */
:root{
  --bg:#fffaf4; --bg-2:#fdeede; --ink:#241a12; --soft:#6b5847; --faint:#a08a73; --line:#ecdcc7;
  --sun:#ef6c2e; --sun-d:#c8521b; --teal:#108a86; --teal-d:#0c6f6b; --gold:#e0a23a; --night:#1c2a33;
  --maxw:1180px;
  --head:"Bricolage Grotesque","Archivo",ui-sans-serif,system-ui,sans-serif;
  --body:ui-sans-serif,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font:17px/1.7 var(--body);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}
a{color:var(--teal-d);text-decoration:none}
a:hover{color:var(--sun-d)}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
h1,h2,h3{font-family:var(--head);font-weight:800;letter-spacing:-.02em}

/* top bar */
header.site{background:var(--night);color:#fff;position:sticky;top:0;z-index:20}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:9px;font-family:var(--head);font-weight:800;font-size:1.3rem;color:#fff}
.brand .logo{font-size:1.25rem}
.brand b{color:var(--sun)}
.nav nav a{color:#cfe0e0;font-weight:600;font-size:.82rem;letter-spacing:.04em;margin-left:22px;text-transform:uppercase}
.nav nav a:hover{color:var(--sun)}

/* asymmetric hero: text left, stacked images right */
.hero{background:linear-gradient(120deg,var(--bg-2),var(--bg));border-bottom:1px solid var(--line)}
.hero .grid{display:grid;grid-template-columns:1.1fr .9fr;gap:38px;align-items:center;padding:54px 0 50px}
.hero .eyebrow{display:inline-block;background:var(--sun);color:#fff;font-weight:700;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;padding:5px 12px;border-radius:999px}
.hero h1{font-size:clamp(2.3rem,5.4vw,3.7rem);line-height:1.03;margin:18px 0 16px;color:var(--night)}
.hero h1 em{font-style:normal;color:var(--sun-d)}
.hero p{font-size:1.18rem;color:var(--soft);max-width:46ch;margin:0 0 24px}
.btn{display:inline-block;background:var(--teal);color:#fff;font-weight:700;font-size:.92rem;padding:13px 26px;border-radius:10px;box-shadow:0 6px 18px rgba(16,138,134,.28);transition:transform .15s}
.btn:hover{color:#fff;transform:translateY(-2px)}
.hero .stack{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:10px;height:340px}
.hero .stack img{width:100%;height:100%;object-fit:cover;border-radius:14px}
.hero .stack img:first-child{grid-row:span 2;height:100%}

/* live forecast widget */
.forecast{background:var(--night);color:#eaf6f6;border-radius:16px;padding:20px 22px;margin:0}
.forecast h3{color:#fff;margin:0 0 4px;font-size:1.05rem;display:flex;align-items:center;gap:8px}
.forecast .sub{color:#8fb4b4;font-size:.82rem;margin:0 0 14px}
.fc-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(64px,1fr));gap:10px}
.fc-cell{background:rgba(255,255,255,.06);border-radius:10px;padding:10px 8px;text-align:center}
.fc-cell .t{font-size:.72rem;color:#8fb4b4}
.fc-cell .v{font-family:var(--head);font-weight:800;font-size:1.15rem;color:#fff;margin-top:3px}
.fc-cell .u{font-size:.66rem;color:#8fb4b4}
.fc-flag{display:inline-block;font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:999px;margin-top:10px}
.fc-good{background:#15803d;color:#dcfce7}.fc-ok{background:#a16207;color:#fef9c3}.fc-small{background:#475569;color:#e2e8f0}

/* section heading */
.sec-head{display:flex;align-items:baseline;gap:14px;margin:52px 0 22px}
.sec-head h2{font-size:1.7rem;margin:0;color:var(--night)}
.sec-head .line{flex:1;height:2px;background:var(--line)}
.sec-head .count{color:var(--faint);font-size:.85rem;font-weight:600}

/* magazine feed: 1 big + list */
.mag{display:grid;grid-template-columns:1.25fr 1fr;gap:30px}
.feature{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden}
.feature img{height:300px;width:100%;object-fit:cover}
.feature .pad{padding:22px 24px 26px}
.feature .tag{color:var(--sun-d);font-weight:700;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase}
.feature h3{font-size:1.7rem;line-height:1.12;margin:8px 0 10px;color:var(--night)}
.feature p{color:var(--soft);margin:0 0 14px}
.mlist{display:flex;flex-direction:column;gap:16px}
.mitem{display:grid;grid-template-columns:96px 1fr;gap:14px;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:transform .15s,box-shadow .15s}
.mitem:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(36,26,18,.08)}
.mitem img{width:96px;height:100%;object-fit:cover}
.mitem .pad{padding:12px 14px 12px 0}
.mitem .tag{color:var(--teal-d);font-weight:700;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase}
.mitem h4{font-family:var(--head);font-size:1.05rem;line-height:1.2;margin:4px 0 4px;color:var(--night)}
.mitem p{color:var(--soft);font-size:.86rem;margin:0}

/* cost calculator */
.calc{background:var(--bg-2);border:1px solid var(--line);border-radius:18px;padding:26px 28px}
.calc h3{margin:0 0 4px;font-size:1.4rem;color:var(--night)}
.calc .sub{color:var(--soft);margin:0 0 18px;font-size:.95rem}
.calc .field{margin:14px 0}
.calc label{display:block;font-weight:600;font-size:.9rem;margin-bottom:6px}
.calc label .val{color:var(--sun-d);font-weight:800;float:right}
.calc input[type=range]{width:100%;accent-color:var(--sun)}
.calc select{width:100%;padding:10px;border:1px solid var(--line);border-radius:9px;background:#fff;font:inherit}
.calc .out{display:flex;justify-content:space-between;align-items:baseline;margin-top:20px;padding-top:18px;border-top:2px dashed var(--line)}
.calc .out .lbl{font-weight:700;color:var(--night)}
.calc .out .num{font-family:var(--head);font-weight:800;font-size:2.1rem;color:var(--teal-d)}
.calc .note{font-size:.8rem;color:var(--faint);margin-top:8px}

/* article */
article.post{max-width:720px;margin:0 auto;padding:44px 0 10px}
article.post .meta{color:var(--sun-d);font-weight:700;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px}
article.post h1{font-size:clamp(1.9rem,4.4vw,2.7rem);line-height:1.12;margin:6px 0 20px;color:var(--night)}
article.post h2{font-size:1.5rem;margin:38px 0 12px;color:var(--night)}
article.post p,article.post li{font-size:1.07rem}
article.post .lead{font-size:1.24rem;line-height:1.6;color:#3a2c1f}
article.post figure{margin:26px 0}
article.post figure img{border-radius:14px}
article.post figcaption{font-size:.84rem;color:var(--faint);text-align:center;margin-top:8px}
.callout{background:var(--bg-2);border-left:4px solid var(--teal);border-radius:10px;padding:15px 20px;margin:24px 0}
.related{border-top:1px solid var(--line);margin-top:42px;padding-top:18px}
.related h3{font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin:0 0 8px}
.related a{display:block;padding:7px 0;font-family:var(--head);font-weight:700;color:var(--night)}
.related a:hover{color:var(--sun-d)}

footer.site{background:var(--night);color:#9fb6b6;margin-top:64px;padding:40px 0;font-size:.9rem}
footer.site .wrap{display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;align-items:center}
footer.site a{color:#cfe0e0}footer.site a:hover{color:var(--sun)}
.disc{font-size:.8rem;color:#6f8a8a;max-width:640px;margin:14px auto 0;text-align:center}

@media(max-width:820px){.hero .grid,.mag{grid-template-columns:1fr}.hero .stack{height:260px}.nav nav a{margin-left:14px}}

/* ===== ENHANCEMENT PASS (echo the surf-travel roots + fix header width) ===== */
header.site .nav{padding-left:0;padding-right:0}
header.site .nav.wrap,header.site .wrap.nav{padding:14px 24px}
/* a sun-bleached "conditions ticker" band under the nav, surf-report vibe */
.surfline{font-weight:700;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;
  text-align:center;padding:7px 16px;color:#fff;
  background:linear-gradient(90deg,var(--teal,#108a86),var(--sun,#ef6c2e))}
/* tactile, sun-and-sea touches */
.feature{overflow:hidden}
.feature img{transition:transform .4s ease}
.feature:hover img{transform:scale(1.04)}
.forecast{box-shadow:0 14px 34px rgba(10,126,164,.14)}
article.post h2{position:relative;padding-left:15px}
article.post h2::before{content:"";position:absolute;left:0;top:.2em;bottom:.2em;width:4px;border-radius:3px;
  background:linear-gradient(var(--teal,#108a86),var(--sun,#ef6c2e))}
