/* ===========================================================
   PinPattaya — "Sunset Luxe" design system  v2
   Warm, premium, editorial. Keyless. Light + dark.
   Every colour/size is a token so the whole look re-skins here.
   =========================================================== */

:root {
  --accent:   #ff5b79;   /* coral        */
  --accent-2: #ffb155;   /* gold         */
  --accent-3: #9d4edd;   /* plum         */
  --grad-sunset: linear-gradient(110deg,#ff5b79 0%,#ff7a5f 46%,#ffb155 100%);
  --grad-sunset-soft: linear-gradient(110deg,#ff5b7926,#ffb15526);

  --cat-rooftop-bar:#ff5b79;
  --cat-beach-club:#16b8c9;

  --bg:#fbf6ef;
  --bg-2:#f4ece1;
  --surface:#ffffff;
  --surface-2:#f7f0e7;
  --glass:rgba(255,255,255,.72);
  --ink:#211a26;
  --ink-soft:#4b4350;
  --muted:#7a7280;
  --line:rgba(33,26,38,.10);
  --line-2:rgba(33,26,38,.16);
  --shadow-sm:0 2px 10px rgba(60,30,50,.07);
  --shadow:0 14px 36px rgba(60,28,55,.12);
  --shadow-lg:0 28px 70px rgba(40,18,45,.22);
  --pin-stroke:#fff;
  --sky-1:#fff;

  --display:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;

  --r:16px; --r-lg:22px; --r-sm:12px; --pill:999px;
  --topbar-h:62px;
}

html.dark{
  --bg:#100b1a;
  --bg-2:#0a0713;
  --surface:#1a1430;
  --surface-2:#221a3b;
  --glass:rgba(26,20,48,.66);
  --ink:#f4eefb;
  --ink-soft:#cdc4dd;
  --muted:#a59cb7;
  --line:rgba(255,255,255,.10);
  --line-2:rgba(255,255,255,.16);
  --shadow-sm:0 2px 12px rgba(0,0,0,.4);
  --shadow:0 16px 40px rgba(0,0,0,.5);
  --shadow-lg:0 30px 80px rgba(0,0,0,.65);
  --pin-stroke:#1a1430;
}

*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:var(--bg); color:var(--ink); font-family:var(--sans);
  -webkit-font-smoothing:antialiased; display:flex; flex-direction:column;
  height:100dvh; overflow:hidden;
}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
::selection{background:var(--accent);color:#fff}

/* scrollbars */
*{scrollbar-width:thin;scrollbar-color:var(--line-2) transparent}
*::-webkit-scrollbar{width:9px;height:9px}
*::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:9px;border:2px solid transparent;background-clip:content-box}

/* ===================== TOP BAR ===================== */
.topbar{
  height:var(--topbar-h); flex:0 0 auto; display:flex; align-items:center; gap:16px;
  padding:0 18px; background:var(--glass); backdrop-filter:saturate(1.4) blur(14px);
  -webkit-backdrop-filter:saturate(1.4) blur(14px);
  border-bottom:1px solid var(--line); z-index:1200; position:relative;
}
.brand{display:flex;align-items:center;gap:10px;cursor:pointer;user-select:none}
.brand-pin{width:34px;height:34px;border-radius:11px;display:grid;place-items:center;background:var(--grad-sunset);color:#fff;box-shadow:var(--shadow-sm)}
.brand-pin svg{width:20px;height:20px}
.brand-tt{display:flex;flex-direction:column;line-height:1}
.brand-name{font-family:var(--display);font-weight:600;font-size:21px;letter-spacing:-.01em}
.brand-accent{background:var(--grad-sunset);-webkit-background-clip:text;background-clip:text;color:transparent}
.brand-tag{font-size:10.5px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-top:2px}

.search-wrap{position:relative;flex:1 1 auto;max-width:440px;display:flex;align-items:center}
.search-ico{position:absolute;left:14px;color:var(--muted);pointer-events:none}
#search{
  width:100%;height:42px;padding:0 16px 0 40px;border:1px solid var(--line);
  border-radius:var(--pill);background:var(--surface-2);color:var(--ink);font:500 14px var(--sans);
  transition:box-shadow .2s,border-color .2s,background .2s;
}
#search:focus{outline:none;border-color:transparent;box-shadow:0 0 0 2px var(--accent);background:var(--surface)}
.topbar-actions{display:flex;align-items:center;gap:9px;margin-left:auto}
.icon-btn{width:42px;height:42px;display:grid;place-items:center;border:1px solid var(--line);border-radius:13px;background:var(--surface);color:var(--ink);cursor:pointer;transition:transform .08s,background .2s,box-shadow .2s}
.icon-btn:hover{background:var(--surface-2);box-shadow:var(--shadow-sm)}
.icon-btn:active{transform:scale(.93)}
.trip-btn{display:flex;align-items:center;gap:8px;height:42px;padding:0 16px;border:1px solid var(--line);border-radius:13px;background:var(--surface);color:var(--ink);font:600 14px var(--sans);cursor:pointer;transition:transform .08s,background .2s,box-shadow .2s}
.trip-btn:hover{background:var(--surface-2);box-shadow:var(--shadow-sm)}
.trip-btn:active{transform:scale(.97)}
.trip-count{min-width:21px;height:21px;padding:0 6px;border-radius:var(--pill);background:var(--grad-sunset);color:#fff;font-size:12px;font-weight:700;display:grid;place-items:center}

/* ===================== FILTER BAR ===================== */
.filterbar{flex:0 0 auto;background:var(--surface);border-bottom:1px solid var(--line);z-index:1100}
.filter-scroll{display:flex;align-items:center;gap:8px;padding:11px 18px;overflow-x:auto;scrollbar-width:none}
.filter-scroll::-webkit-scrollbar{display:none}
.filter-group{display:flex;gap:7px;flex:0 0 auto}
.filter-div{width:1px;height:26px;background:var(--line);flex:0 0 auto;margin:0 2px}

.chip{flex:0 0 auto;height:36px;padding:0 15px;border-radius:var(--pill);border:1px solid var(--line);background:var(--surface);color:var(--ink-soft);font:600 13px var(--sans);cursor:pointer;display:inline-flex;align-items:center;gap:7px;white-space:nowrap;transition:transform .08s,background .18s,color .18s,border-color .18s,box-shadow .18s}
.chip:hover{background:var(--surface-2);color:var(--ink)}
.chip:active{transform:scale(.95)}
.chip i.tic{font-style:normal;font-size:14px;line-height:1}
.chip[aria-pressed="true"],.chip.active{background:var(--ink);color:var(--bg);border-color:var(--ink);box-shadow:var(--shadow-sm)}
.chip .dot{width:9px;height:9px;border-radius:50%}
.cat-chip[aria-pressed="true"]{color:#fff;border-color:transparent}
.cat-chip.rooftop-bar[aria-pressed="true"]{background:var(--cat-rooftop-bar)}
.cat-chip.beach-club[aria-pressed="true"]{background:var(--cat-beach-club)}
.reset-chip{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 35%,var(--line))}
.mini-count{background:var(--accent);color:#fff;border-radius:var(--pill);padding:0 6px;height:18px;display:none;align-items:center;font-size:11px}
.mini-count.show{display:inline-flex}

.vibe-popover{position:absolute;top:calc(var(--topbar-h) + 54px);right:18px;width:min(360px,92vw);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:16px;z-index:1300}
.vibe-popover-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-family:var(--display)}
.link-btn{background:none;border:none;color:var(--accent);font-weight:600;cursor:pointer;font-size:13px}
.vibe-tags{display:flex;flex-wrap:wrap;gap:8px}

/* ===================== LAYOUT ===================== */
.layout{flex:1 1 auto;display:grid;grid-template-columns:436px 1fr;min-height:0}
.list-pane{display:flex;flex-direction:column;min-height:0;border-right:1px solid var(--line);background:var(--bg)}

/* spotlight rail */
.spotlight{flex:0 0 auto;padding:16px 0 6px}
.spot-head{display:flex;align-items:center;gap:8px;padding:0 18px 10px}
.spot-head h3{font-family:var(--display);font-size:16px;margin:0;font-weight:600}
.spot-head .spk{font-size:11px;color:var(--muted)}
.spot-scroll{display:flex;gap:12px;overflow-x:auto;padding:0 18px 6px;scrollbar-width:none}
.spot-scroll::-webkit-scrollbar{display:none}
.spot-card{flex:0 0 232px;border-radius:var(--r);overflow:hidden;cursor:pointer;position:relative;box-shadow:var(--shadow-sm);border:1px solid var(--line);background:var(--surface);transition:transform .16s,box-shadow .16s}
.spot-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.spot-art{height:120px;position:relative}
.spot-art .badge-fav{position:absolute;top:8px;left:8px}
.spot-body{padding:9px 12px 11px}
.spot-name{font-family:var(--display);font-weight:600;font-size:14.5px;line-height:1.15}
.spot-meta{font-size:11.5px;color:var(--muted);margin-top:3px;display:flex;gap:6px;align-items:center}

.list-head{display:flex;align-items:center;justify-content:space-between;padding:12px 18px 6px;flex:0 0 auto}
.result-count{font:700 14px var(--sans)}
.result-count b{font-family:var(--display)}
.sort-sel{height:34px;border:1px solid var(--line);border-radius:10px;background:var(--surface);color:var(--ink);font:500 13px var(--sans);padding:0 10px}
.card-list{flex:1 1 auto;overflow-y:auto;padding:6px 18px 18px}
.list-foot{flex:0 0 auto;padding:10px 18px;border-top:1px solid var(--line)}
.list-foot p{margin:0;font-size:11.5px;color:var(--muted)}
.list-foot a{color:var(--accent);text-decoration:none}

.map-pane{position:relative;min-height:0}
#map{position:absolute;inset:0;background:var(--surface-2)}

/* ===================== MAGAZINE CARD ===================== */
.card{position:relative;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface);overflow:hidden;cursor:pointer;margin-bottom:14px;box-shadow:var(--shadow-sm);transition:transform .16s,box-shadow .16s,border-color .16s;opacity:0;transform:translateY(10px);animation:cardIn .5s forwards}
@keyframes cardIn{to{opacity:1;transform:none}}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line-2)}
.card.selected{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 40%,transparent),var(--shadow)}
.card-art{height:150px;position:relative}
.card-art .save-btn{position:absolute;top:10px;right:10px}
.card-badges{position:absolute;top:10px;left:10px;display:flex;gap:6px}
.card-open{position:absolute;bottom:10px;left:12px}
.card-body{padding:12px 14px 14px}
.card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.card-name{font-family:var(--display);font-weight:600;font-size:17px;line-height:1.15;margin:0 0 3px}
.card-price{font-weight:700;letter-spacing:1px;font-size:13.5px;flex:0 0 auto;white-space:nowrap}
.card-meta{font-size:12px;color:var(--muted);display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.card-snip{font-size:13px;line-height:1.5;color:var(--ink-soft);margin:8px 0 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-tags{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}
.tag{font-size:10.5px;font-weight:600;padding:3px 9px;border-radius:var(--pill);background:var(--surface-2);color:var(--muted);white-space:nowrap}
.tag.cat{color:#fff}
.save-btn{border:none;background:rgba(20,12,24,.42);backdrop-filter:blur(4px);cursor:pointer;color:#fff;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;transition:transform .12s,background .2s}
.save-btn:hover{background:rgba(20,12,24,.6)}
.save-btn:active{transform:scale(.88)}
.save-btn.saved{background:var(--grad-sunset)}
.save-btn svg{width:18px;height:18px}

.badge{font-size:10px;font-weight:700;letter-spacing:.03em;padding:4px 9px;border-radius:var(--pill);display:inline-flex;gap:4px;align-items:center;backdrop-filter:blur(4px)}
.badge.featured{background:rgba(255,177,85,.92);color:#5a3300}
.badge.approx{background:rgba(20,12,24,.5);color:#ffd9a8}
.badge.open{background:rgba(28,170,120,.95);color:#fff}
.badge.closed{background:rgba(20,12,24,.5);color:#fff}

.empty-state{padding:46px 20px;text-align:center;color:var(--muted)}

/* skeleton */
.skel{border-radius:var(--r-lg);height:280px;margin-bottom:14px;background:linear-gradient(100deg,var(--surface-2) 30%,var(--line) 50%,var(--surface-2) 70%);background-size:200% 100%;animation:shimmer 1.3s infinite}
@keyframes shimmer{to{background-position:-200% 0}}

/* ===================== MAP PINS ===================== */
.pp-pin{width:40px;height:48px;position:relative}
.pp-pin .pin-drop{position:absolute;left:50%;top:0;transform:translateX(-50%);width:34px;height:34px;border-radius:50% 50% 50% 2px;rotate:45deg;border:2.5px solid var(--pin-stroke);box-shadow:var(--shadow);}
.pp-pin .pin-glyph{position:absolute;left:50%;top:17px;transform:translate(-50%,-50%);color:#fff;display:grid;place-items:center}
.pp-pin .pin-glyph svg{width:17px;height:17px}
.pp-pin.featured .pin-drop{box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-2) 80%,transparent),var(--shadow)}
.pp-pin.featured::before{content:"";position:absolute;left:50%;top:17px;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:var(--accent-2);opacity:.35;animation:pulse 2.2s ease-out infinite}
@keyframes pulse{0%{transform:translate(-50%,-50%) scale(.5);opacity:.5}100%{transform:translate(-50%,-50%) scale(1.5);opacity:0}}
.pp-pin.approx .pin-drop{border-style:dashed}
.pp-pin.selected{z-index:1000!important}
.pp-pin.selected .pin-drop{scale:1.22}
.marker-cluster-pp{background:var(--grad-sunset);color:#fff;border-radius:50%;display:grid;place-items:center;font:700 14px var(--sans);box-shadow:var(--shadow);border:3px solid var(--pin-stroke)}
.leaflet-popup-content-wrapper{border-radius:14px}

/* ===================== DETAIL PANEL ===================== */
.detail{position:fixed;top:0;right:0;height:100dvh;width:min(460px,100vw);background:var(--surface);box-shadow:var(--shadow-lg);z-index:1500;transform:translateX(102%);transition:transform .34s cubic-bezier(.32,.72,0,1);display:flex;flex-direction:column}
.detail.open{transform:translateX(0)}
.detail-close{position:absolute;top:14px;right:14px;z-index:3;width:38px;height:38px;border-radius:50%;border:none;background:rgba(20,12,24,.46);backdrop-filter:blur(6px);color:#fff;font-size:16px;cursor:pointer;transition:transform .12s,background .2s}
.detail-close:hover{background:rgba(20,12,24,.66)}
.detail-close:active{transform:scale(.9)}
.detail-scroll{overflow-y:auto}
.detail-hero{height:230px;position:relative;display:flex;align-items:flex-end}
.detail-hero .hero-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,6,16,.62),transparent 55%)}
.detail-hero .hero-tt{position:relative;padding:18px;color:#fff;z-index:2}
.detail-hero .hero-name{font-family:var(--display);font-weight:700;font-size:25px;line-height:1.1;text-shadow:0 2px 14px rgba(0,0,0,.4)}
.detail-hero .hero-sub{font-size:13px;opacity:.92;margin-top:4px;text-shadow:0 1px 8px rgba(0,0,0,.4)}
.detail-hero .hero-badges{position:absolute;top:16px;left:16px;display:flex;gap:6px;z-index:2}
.detail-body{padding:18px}
.detail-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:16px}
.pill{font:600 12px var(--sans);padding:6px 12px;border-radius:var(--pill);background:var(--surface-2);color:var(--ink-soft);display:inline-flex;gap:6px;align-items:center}
.pill.live-open{background:color-mix(in srgb,#1caa78 18%,transparent);color:#0f7a52}
html.dark .pill.live-open{color:#52e0a8}
.pill.live-closed{background:var(--surface-2);color:var(--muted)}
.detail-summary{font-size:15px;line-height:1.62;margin:0 0 18px;color:var(--ink-soft)}
.detail-summary::first-letter{}
.proscons{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px}
@media (max-width:400px){.proscons{grid-template-columns:1fr}}
.pc-col h4{margin:0 0 8px;font:700 11px var(--sans);text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.pc-col ul{margin:0;padding:0;list-style:none;display:grid;gap:8px}
.pc-col li{font-size:13.5px;line-height:1.4;padding-left:23px;position:relative}
.pc-col.pros li::before{content:"";position:absolute;left:0;top:2px;width:16px;height:16px;border-radius:50%;background:color-mix(in srgb,#1caa78 20%,transparent);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M5 12l5 5 9-10' fill='none' stroke='%231caa78' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E');background-size:13px;background-repeat:no-repeat;background-position:center}
.pc-col.cons li::before{content:"";position:absolute;left:0;top:2px;width:16px;height:16px;border-radius:50%;background:color-mix(in srgb,#e0566f 20%,transparent);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M6 6l12 12M18 6L6 18' fill='none' stroke='%23e0566f' stroke-width='3' stroke-linecap='round'/%3E%3C/svg%3E');background-size:12px;background-repeat:no-repeat;background-position:center}
.bestfor{background:var(--grad-sunset-soft);border:1px solid color-mix(in srgb,var(--accent) 22%,transparent);border-radius:var(--r);padding:13px 15px;margin-bottom:18px;font-size:14px;line-height:1.5}
.bestfor b{font-family:var(--display)}
.infogrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px}
.infocell{background:var(--surface-2);border-radius:var(--r-sm);padding:12px 14px}
.infocell .k{font:700 11px var(--sans);text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:4px}
.infocell .v{font-size:14px;font-weight:600}
.infocell .v small{font-weight:500;color:var(--muted)}
.detail-tags{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:20px}
.detail-cta{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.verify-note{font-size:11.5px;color:var(--muted);border-top:1px solid var(--line);padding-top:14px;line-height:1.55}
.verify-note a{color:var(--accent)}

/* ===================== BUTTONS ===================== */
.btn-primary,.btn-soft,.btn-ghost{height:46px;border-radius:14px;font:700 14px var(--sans);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;text-decoration:none;width:100%;transition:transform .1s,filter .2s,background .2s}
.btn-primary{background:var(--grad-sunset);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{filter:brightness(1.06)}
.btn-primary:active,.btn-soft:active,.btn-ghost:active{transform:scale(.98)}
.btn-soft{background:var(--surface-2);color:var(--ink);border-color:var(--line)}
.btn-soft:hover{background:var(--line)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn-ghost.saved{color:#fff;background:var(--grad-sunset);border-color:transparent}

/* ===================== MY TRIP ===================== */
.trip{position:fixed;top:0;right:0;height:100dvh;width:min(400px,100vw);background:var(--surface);box-shadow:var(--shadow-lg);z-index:1500;transform:translateX(102%);transition:transform .34s cubic-
/* list hero (stats) */
.listhero{padding:16px 18px 2px;flex:0 0 auto}
.lh-title{font-family:var(--display);font-size:23px;font-weight:600;line-height:1.1}
.lh-accent{background:var(--grad-sunset);-webkit-background-clip:text;background-clip:text;color:transparent}
.lh-sub{font-size:12.5px;color:var(--muted);margin-top:4px}

/* trip planner */
.trip-actions{grid-template-columns:1fr 1fr}
.trip-summary{padding:6px 16px 0;font-size:12.5px;color:var(--muted);text-align:center}
.ti-num{width:22px;height:22px;border-radius:50%;background:var(--surface-2);color:var(--ink-soft);font-size:11px;font-weight:700;display:grid;place-items:center;flex:0 0 auto}
.ti-ctrl{display:flex;align-items:center;gap:2px;flex:0 0 auto}
.ti-ctrl button{border:none;background:none;color:var(--muted);cursor:pointer;font-size:11px;width:22px;height:22px;border-radius:6px}
.ti-ctrl button:hover:not(:disabled){background:var(--surface-2);color:var(--ink)}
.ti-ctrl button:disabled{opacity:.3;cursor:default}
.trip-item .ti-name{cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
