/* Bali surf breaks guide — filterable spot cards. Uses balisurf vars (sun/teal/sand). */
.brk-wrap{max-width:1080px;margin:0 auto;padding:0 20px}
.brk-hero{max-width:760px;margin:44px auto 10px}
.brk-hero .eyebrow{font-family:var(--head);font-weight:700;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sun)}
.brk-hero h1{font-family:var(--head);font-weight:800;font-size:clamp(2rem,4.4vw,3rem);line-height:1.08;letter-spacing:-.02em;margin:10px 0 14px;color:var(--ink)}
.brk-hero .lead{font-size:1.22rem;line-height:1.5;color:var(--soft);margin:0 0 22px}
.brk-hero p{font-size:1.05rem;line-height:1.7;color:var(--ink);margin:0 0 14px}

/* filter */
.brk-filter{position:sticky;top:0;z-index:5;background:var(--bg);border-bottom:1px solid var(--line);padding:18px 0 14px;margin:24px 0 26px}
.brk-filter-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:9px}
.brk-filter-label{font-family:var(--head);font-weight:700;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-right:6px;min-width:78px}
.chip{font-family:var(--head);font-weight:600;font-size:.92rem;background:#fff;border:1.5px solid var(--line);color:var(--soft);padding:8px 15px;border-radius:999px;cursor:pointer;transition:all .14s}
.chip:hover{border-color:var(--sun);color:var(--ink)}
.chip.on{background:var(--sun);border-color:var(--sun);color:#fff}
.brk-count{margin:6px 0 0;font-size:.86rem;color:var(--faint);font-weight:600}

/* spot cards */
.brk-list{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:0 0 46px}
.brk{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff;box-shadow:0 2px 8px rgba(36,26,18,.06)}
.brk-img{aspect-ratio:16/10;background-size:cover;background-position:center;position:relative}
.brk-lvl{position:absolute;left:12px;top:12px;font-family:var(--head);font-weight:700;font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:#fff;padding:5px 11px;border-radius:999px}
.lvl-beginner{background:var(--teal)} .lvl-intermediate{background:var(--gold)} .lvl-advanced{background:var(--sun)}
.brk-body{padding:18px 20px 20px}
.brk-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin:0 0 10px}
.brk-head h3{font-family:var(--head);font-weight:800;font-size:1.4rem;margin:0;color:var(--ink)}
.brk-region{font-size:.8rem;color:var(--faint);font-weight:600;white-space:nowrap}
.brk-tags{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 14px}
.brk-tags span{font-size:.78rem;color:var(--soft);background:var(--bg);border:1px solid var(--line);padding:4px 9px;border-radius:8px}
.brk-body p{font-size:.98rem;line-height:1.62;color:var(--ink);margin:0 0 11px}
.brk-verdict{font-size:.95rem;line-height:1.5;color:var(--night);background:rgba(16,138,134,.07);border-left:3px solid var(--teal);padding:10px 14px;border-radius:0 8px 8px 0;margin-top:14px}
.brk-verdict span{font-family:var(--head);font-weight:700;color:var(--teal);text-transform:uppercase;font-size:.72rem;letter-spacing:.06em}

.brk-tips{max-width:760px;margin:0 auto;background:var(--night);color:#fff;border-radius:16px;padding:28px 30px}
.brk-tips h2{font-family:var(--head);font-weight:800;font-size:1.4rem;margin:0 0 14px}
.brk-tips ul{margin:0;padding-left:20px} .brk-tips li{font-size:1rem;line-height:1.6;margin:0 0 9px;color:#e9dcc9}
.brk-outro{max-width:760px;margin:30px auto 0;padding-top:22px;border-top:2px solid var(--ink)}
.brk-outro p{font-size:1.08rem;line-height:1.7}
.cta-row{margin-top:18px}
.brk-wrap .btn{display:inline-block;font-family:var(--head);font-weight:700;background:var(--sun);color:#fff;padding:13px 24px;border-radius:11px;text-decoration:none;transition:background .15s}
.brk-wrap .btn:hover{background:#d85c20}

@media(max-width:760px){ .brk-list{grid-template-columns:1fr} .brk-filter-label{min-width:100%;margin-bottom:2px} }
