/* =====================================================================
   ATLAS SEMARANG — design system "Kartografi Modern"
   Palet: verdigris Kota Lama · merah lentera · kuningan peta · kertas sejuk
   Font: Bricolage Grotesque (display) · Plus Jakarta Sans (UI) · Space Mono (data)
   ===================================================================== */
:root{
  --ink:#13211F; --ink-2:#33433F; --muted:#5E6B68; --faint:#94A09C;
  --paper:#F1F3F2; --paper-2:#E7ECEA; --surface:#FFFFFF;
  --teal:#0E4F47; --teal-deep:#0A352F; --teal-soft:#DCE8E5;
  --coral:#E1533F; --coral-deep:#C53F2C; --coral-soft:#FBE6E1;
  --brass:#C09A43; --brass-soft:#EFE4C8;
  --line:#E0E5E3; --line-2:#CFD8D5;
  --r:18px; --r-sm:12px; --r-lg:28px; --r-xl:34px;
  --sh-sm:0 2px 10px rgba(19,33,31,.05);
  --sh:0 14px 34px rgba(19,33,31,.10);
  --sh-lg:0 28px 70px rgba(19,33,31,.18);
  --maxw:1240px; --tabh:64px;
  --display:"Bricolage Grotesque",system-ui,sans-serif;
  --body:"Plus Jakarta Sans",system-ui,sans-serif;
  --mono:"Space Mono",ui-monospace,monospace;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:84px;}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--body);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;overflow-wrap:break-word;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
:focus-visible{outline:2.5px solid var(--coral);outline-offset:3px;border-radius:6px;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.coord{font-family:var(--mono);font-size:11px;letter-spacing:.02em;color:var(--faint);}

.rv{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.rv.in{opacity:1;transform:none;}

/* ============ HEADER ============ */
header.top{position:sticky;top:0;z-index:90;background:rgba(241,243,242,.78);backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid transparent;transition:border-color .3s,background .3s,box-shadow .3s;}
header.top.scrolled{background:rgba(247,248,247,.92);border-bottom-color:var(--line);box-shadow:0 6px 24px rgba(19,33,31,.05);}
.top-in{display:flex;align-items:center;gap:16px;height:72px;transition:height .3s var(--ease);}
header.top.scrolled .top-in{height:62px;}
.logo{display:flex;align-items:center;gap:11px;}
.logo .crest{width:40px;height:30px;object-fit:contain;flex:none;filter:drop-shadow(0 2px 4px rgba(0,0,0,.18));}
.logo .nm{font-family:var(--display);font-weight:700;font-size:20px;letter-spacing:-.01em;line-height:1;}
.logo .nm small{display:block;font-family:var(--mono);font-size:8.5px;letter-spacing:.16em;color:var(--muted);font-weight:400;margin-top:3px;text-transform:uppercase;}
.top-nav{display:none;gap:24px;margin-left:auto;}
.top-nav a{font-size:14px;font-weight:600;color:var(--muted);transition:color .15s;}
.top-nav a:hover{color:var(--ink);}
.top-search{display:none;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:9px 9px 9px 16px;width:260px;box-shadow:var(--sh-sm);transition:box-shadow .2s;}
.top-search:hover{box-shadow:var(--sh);}
.top-search svg{width:16px;height:16px;color:var(--muted);flex:none;}
.top-search input{border:none;outline:none;background:none;font-family:inherit;font-size:13.5px;width:100%;color:var(--ink);}
.top-search .go{width:30px;height:30px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;flex:none;}
.top-search .go svg{width:13px;height:13px;color:#fff;}
@media(min-width:1000px){.top-nav{display:flex;margin-left:auto;}.top-search{display:flex;}}

/* ============ HERO ============ */
.hero{position:relative;padding:54px 0 26px;overflow:hidden;}
.hero::before{content:"";position:absolute;inset:0;z-index:0;opacity:.6;background-image:radial-gradient(circle, rgba(14,79,71,.09) 1.1px, transparent 1.2px);background-size:26px 26px;-webkit-mask-image:linear-gradient(180deg,#000 30%,transparent 95%);mask-image:linear-gradient(180deg,#000 30%,transparent 95%);}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1fr;gap:34px;align-items:center;}
@media(min-width:920px){.hero-grid{gap:48px;}.hero-grid>div{max-width:760px;}}
.eyebrow{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);display:inline-flex;align-items:center;gap:9px;margin-bottom:20px;}
.eyebrow::before{content:"";width:24px;height:1.5px;background:var(--brass);}
.hero h1{font-family:var(--display);font-weight:700;font-size:clamp(40px,7vw,68px);line-height:1.02;letter-spacing:-.025em;margin:0;}
.hero h1 em{font-style:normal;color:var(--teal);position:relative;}
.hero h1 em::after{content:"";position:absolute;left:0;right:0;bottom:.07em;height:.13em;background:var(--brass-soft);z-index:-1;border-radius:3px;}
.hero .lede{font-size:clamp(15.5px,2.4vw,18px);color:var(--muted);max-width:42ch;margin:20px 0 28px;}
.search-xl{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:8px 8px 8px 20px;box-shadow:var(--sh);max-width:520px;transition:box-shadow .25s,transform .25s;}
.search-xl:focus-within{box-shadow:var(--sh-lg);transform:translateY(-1px);}
.search-xl .pin{width:19px;height:19px;color:var(--coral);flex:none;}
.search-xl input{border:none;outline:none;background:none;font-family:inherit;font-size:15.5px;width:100%;color:var(--ink);padding:8px 0;}
.search-xl input::placeholder{color:var(--faint);}
.search-xl .submit{display:inline-flex;align-items:center;gap:7px;background:var(--ink);color:#fff;border-radius:999px;padding:12px 20px;font-size:14px;font-weight:600;white-space:nowrap;flex:none;transition:background .2s,transform .15s;}
.search-xl .submit:hover{background:var(--teal);transform:scale(1.02);}
.search-xl .submit svg{width:15px;height:15px;}
.vibes{display:flex;gap:9px;flex-wrap:wrap;margin-top:18px;}
.vibe{font-size:13px;font-weight:500;color:var(--ink-2);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:8px 14px;transition:all .18s var(--ease);}
.vibe:hover{border-color:var(--teal);color:var(--teal);transform:translateY(-2px);box-shadow:var(--sh-sm);}
.hero-stats{display:flex;gap:26px;margin-top:34px;}
.hero-stats .s b{font-family:var(--display);font-size:30px;font-weight:700;line-height:1;display:block;color:var(--ink);}
.hero-stats .s span{font-size:12px;color:var(--muted);}

/* hero atlas-plate (pengganti foto sampai ada foto asli) */

/* ============ SECTION SHELL ============ */
section.blk{padding:64px 0;}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:30px;}
.sec-head h2{font-family:var(--display);font-weight:700;font-size:clamp(28px,4.6vw,40px);line-height:1.05;letter-spacing:-.02em;margin:8px 0 0;max-width:18ch;}
.sec-head p{margin:9px 0 0;color:var(--muted);font-size:14.5px;max-width:40ch;}

/* filter pills + search count */
.filterbar{display:flex;gap:9px;overflow-x:auto;padding-bottom:4px;margin-bottom:26px;scrollbar-width:none;-webkit-overflow-scrolling:touch;}
.filterbar::-webkit-scrollbar{display:none;}
.fpill{flex:none;display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);background:var(--surface);border-radius:999px;padding:9px 16px;font-size:13.5px;font-weight:600;color:var(--muted);white-space:nowrap;transition:all .2s var(--ease);}
.fpill svg{width:15px;height:15px;}
.fpill[aria-pressed="true"]{background:var(--ink);color:#fff;border-color:var(--ink);}
.fpill:hover:not([aria-pressed="true"]){border-color:var(--ink);color:var(--ink);}
.searchnote{font-family:var(--mono);font-size:11.5px;color:var(--muted);margin:-14px 0 20px;}
.grid-empty{text-align:center;padding:40px;color:var(--muted);font-size:14px;background:var(--surface);border:1px dashed var(--line);border-radius:var(--r-sm);}

/* ============ KARTU JELAJAH ============ */
.cards{display:grid;grid-template-columns:1fr;gap:22px;}
@media(min-width:560px){.cards{grid-template-columns:1fr 1fr;}}
@media(min-width:920px){.cards{grid-template-columns:1fr 1fr 1fr;}}
.card{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:3/4.1;box-shadow:var(--sh-lg);background:#16302B;transition:transform .4s var(--ease),box-shadow .4s var(--ease);}
.card:hover{transform:translateY(-6px);box-shadow:0 24px 50px rgba(8,28,25,.28);}
.card .ph{position:absolute;inset:0;z-index:1;display:grid;place-items:center;}
.card .ph img{width:100%;height:100%;object-fit:cover;filter:saturate(.85) contrast(1.02);transition:transform .8s var(--ease);}
.card:hover .ph img{transform:scale(1.07);}
.card .ph.plate{background:linear-gradient(165deg,color-mix(in srgb,var(--c,#0E4F47) 70%,#0A352F),#0A352F);}
.card .ph.plate::before{content:"";position:absolute;inset:0;opacity:.3;background-image:radial-gradient(circle, rgba(255,255,255,.18) 1px, transparent 1.2px);background-size:20px 20px;}
.card .ph .stamp{position:relative;font-size:60px;filter:drop-shadow(0 6px 16px rgba(0,0,0,.4));}
.card::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(180deg,rgba(10,40,36,.05) 0%,transparent 28%,rgba(8,28,25,.92) 100%);}
.card .cat{position:absolute;top:15px;left:16px;z-index:3;pointer-events:none;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff;display:inline-flex;align-items:center;gap:6px;text-shadow:0 1px 4px rgba(0,0,0,.55);}
.card .cat i{width:7px;height:7px;border-radius:2px;background:var(--c,#fff);box-shadow:0 0 0 2px rgba(255,255,255,.22);}
.card .save{position:absolute;top:12px;right:12px;z-index:4;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.16);backdrop-filter:blur(8px);display:grid;place-items:center;border:1px solid rgba(255,255,255,.22);transition:transform .2s,background .2s;cursor:pointer;}
.card .save svg{width:17px;height:17px;color:#fff;fill:none;stroke:currentColor;stroke-width:2;}
.card .save:hover{background:rgba(255,255,255,.3);transform:scale(1.1);}
.card .save.on svg{fill:var(--coral);stroke:var(--coral);}
.card .bd{position:absolute;left:0;right:0;bottom:0;z-index:3;pointer-events:none;padding:22px;}
.card .cd{font-family:var(--mono);font-size:10.5px;color:var(--brass);letter-spacing:.04em;margin-bottom:9px;display:flex;align-items:center;gap:7px;}
.card .cd i{width:5px;height:5px;border-radius:50%;background:var(--brass);flex:none;}
.card h3{font-family:var(--display);font-weight:700;font-size:22px;color:#fff;margin:0 0 7px;letter-spacing:-.01em;line-height:1.12;}
.card .why{font-size:13px;color:rgba(231,238,235,.82);margin:0 0 13px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.card .meta{display:flex;align-items:center;gap:9px;flex-wrap:wrap;}
.card .meta .pl{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11px;color:#fff;background:rgba(255,255,255,.14);backdrop-filter:blur(6px);padding:5px 11px;border-radius:999px;}
.card .meta .pl svg{width:12px;height:12px;flex:none;}
.card .meta .rate{display:inline-flex;align-items:center;gap:4px;font-family:var(--mono);font-size:11.5px;font-weight:700;color:#fff;}
.card .meta .rate svg{width:13px;height:13px;color:var(--brass);fill:var(--brass);stroke:none;}

/* ============ TERDEKAT ============ */
.blk.nearby{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.near-cta{display:inline-flex;align-items:center;gap:8px;background:var(--coral);color:#fff;border-radius:999px;padding:11px 18px;font-size:14px;font-weight:600;box-shadow:0 8px 22px rgba(225,83,63,.32);transition:transform .15s,background .2s;}
.near-cta:hover{background:var(--coral-deep);transform:translateY(-2px);}
.near-cta svg{width:16px;height:16px;}
.near-cta.loading{opacity:.7;cursor:progress;}
.near-status{font-family:var(--mono);font-size:11.5px;color:var(--muted);margin-left:14px;}
.radii{display:flex;gap:8px;flex-wrap:wrap;margin:18px 0 0;}
.radii.hidden{display:none;}
.radii .rd{border:1px solid var(--line);background:var(--surface);border-radius:999px;padding:6px 13px;font-size:12.5px;font-weight:700;color:var(--muted);transition:all .18s;}
.radii .rd[aria-pressed="true"]{background:var(--teal);color:#fff;border-color:var(--teal);}
.near-layout{margin-top:24px;}
.near-list{display:grid;grid-template-columns:1fr;gap:11px;}
@media(min-width:720px){.near-list{grid-template-columns:1fr 1fr;}}
.nrow{display:flex;align-items:stretch;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);transition:border-color .2s var(--ease),box-shadow .2s var(--ease),transform .2s var(--ease);overflow:hidden;}
.nrow:hover{border-color:var(--teal);box-shadow:var(--sh-sm);transform:translateY(-2px);}
.nrow-link{display:flex;gap:13px;align-items:center;padding:11px;flex:1;min-width:0;}
.nrow .th{width:60px;height:60px;border-radius:10px;object-fit:cover;flex:none;background:var(--paper-2);position:relative;overflow:hidden;}
.nrow .th.fb{display:grid;place-items:center;background:linear-gradient(150deg,var(--c,#0E4F47),color-mix(in srgb,var(--c,#0E4F47) 55%,#0A352F));font-size:25px;}
.nrow .ni{min-width:0;flex:1;display:block;}
.nrow .ni b{font-family:var(--display);font-weight:600;font-size:15.5px;display:block;line-height:1.16;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.nrow .ni .nm{display:block;font-family:var(--mono);font-size:10.5px;color:var(--muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.nrow .ni .rr{font-size:12px;font-weight:700;display:inline-flex;align-items:center;gap:4px;margin-top:4px;color:var(--ink);}
.nrow .ni .rr svg{width:12px;height:12px;color:var(--brass);fill:var(--brass);}
.nrow .nd{flex:none;display:flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:7px;padding:10px 12px;border-left:1px solid var(--line);background:var(--paper);}
.nrow .nd .km{font-family:var(--mono);font-weight:700;font-size:12px;color:var(--coral);}
.navto{display:inline-flex;align-items:center;gap:5px;background:var(--teal);color:#fff;font-size:11.5px;font-weight:700;padding:8px 12px;border-radius:999px;transition:background .2s,transform .15s;white-space:nowrap;}
.navto:hover{background:var(--teal-deep);transform:translateY(-1px);}
.navto svg{width:13px;height:13px;}
.leaflet-container{font-family:var(--body);background:#eef1f0;}
.pin{width:26px;height:26px;border-radius:50% 50% 50% 2px;transform:rotate(45deg);background:var(--teal);border:2.5px solid #fff;box-shadow:0 4px 10px rgba(0,0,0,.3);transition:transform .25s var(--ease),background .2s;}
.pin.coral{background:var(--coral);}
.pin.bounce{animation:pinbounce .6s var(--ease);}
@keyframes pinbounce{0%,100%{transform:rotate(45deg) translateY(0);}40%{transform:rotate(45deg) translateY(-12px) scale(1.12);}}
.pin-me{width:18px;height:18px;border-radius:50%;background:#2F7DF6;border:3px solid #fff;box-shadow:0 0 0 6px rgba(47,125,246,.22),0 3px 8px rgba(0,0,0,.3);}
.sk{display:flex;gap:13px;align-items:center;padding:10px;border:1px solid var(--line);border-radius:var(--r-sm);}
.sk .a{width:64px;height:64px;border-radius:10px;flex:none;}
.sk .b{flex:1;display:flex;flex-direction:column;gap:8px;}
.sk .l{height:11px;border-radius:6px;}
.shimmer{background:linear-gradient(100deg,var(--paper-2) 30%,#f4f6f5 50%,var(--paper-2) 70%);background-size:200% 100%;animation:sh 1.3s infinite;}
@keyframes sh{to{background-position:-200% 0;}}

/* ============ HIDDEN GEMS ============ */
.blk.gems{background:var(--teal-deep);color:#E7EEEB;position:relative;overflow:hidden;}
.blk.gems::before{content:"";position:absolute;inset:0;opacity:.5;background-image:radial-gradient(circle, rgba(192,154,67,.13) 1.1px, transparent 1.2px);background-size:28px 28px;}
.blk.gems .wrap{position:relative;z-index:1;}
.blk.gems .eyebrow{color:var(--brass);}
.blk.gems .eyebrow::before{background:var(--brass);}
.blk.gems h2{color:#FBFDFC;}
.blk.gems .sec-head p{color:#A9BDB8;}
.gem-rail{display:flex;gap:18px;overflow-x:auto;padding:6px 2px 14px;scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch;}
.gem-rail::-webkit-scrollbar{display:none;}
.gem{flex:none;width:300px;scroll-snap-align:start;border-radius:var(--r-lg);overflow:hidden;position:relative;aspect-ratio:3/4.1;box-shadow:var(--sh-lg);background:#16302B;display:block;}
@media(min-width:620px){.gem{width:330px;}}
.gem img{width:100%;height:100%;object-fit:cover;filter:saturate(.82) contrast(1.02);transition:transform .8s var(--ease);}
.gem:hover img{transform:scale(1.08);}
.gem .gem-fb{position:absolute;inset:0;background:linear-gradient(165deg,color-mix(in srgb,var(--c,#0E4F47) 70%,#0A352F),#0A352F);display:grid;place-items:center;font-size:60px;}
.gem .gem-fb::before{content:"";position:absolute;inset:0;opacity:.3;background-image:radial-gradient(circle, rgba(255,255,255,.18) 1px, transparent 1.2px);background-size:20px 20px;}
.gem::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,40,36,.1) 0%,transparent 32%,rgba(8,28,25,.9) 100%);}
.gem .gm{position:absolute;left:0;right:0;bottom:0;padding:22px;z-index:2;}
.gem .gco{font-family:var(--mono);font-size:10.5px;color:var(--brass);letter-spacing:.04em;margin-bottom:9px;display:flex;align-items:center;gap:7px;}
.gem .gco i{width:5px;height:5px;border-radius:50%;background:var(--brass);}
.gem h3{font-family:var(--display);font-weight:700;font-size:23px;color:#fff;margin:0 0 7px;letter-spacing:-.01em;line-height:1.1;}
.gem p{font-size:13px;color:rgba(231,238,235,.82);margin:0 0 12px;line-height:1.5;}
.gem .gd{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11px;color:#fff;background:rgba(255,255,255,.14);backdrop-filter:blur(6px);padding:5px 11px;border-radius:999px;}
.gem .gd svg{width:12px;height:12px;}

/* ============ TANYA ATLAS (AI) ============ */
.blk.ai{background:linear-gradient(180deg,var(--paper) 0%,var(--paper-2) 100%);}
.ai-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);padding:clamp(24px,4vw,44px);box-shadow:var(--sh);max-width:760px;margin:0 auto;position:relative;overflow:hidden;}
.ai-card::before{content:"";position:absolute;top:-40px;right:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,var(--teal-soft),transparent 70%);opacity:.7;}
.ai-badge{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);background:var(--teal-soft);padding:6px 13px;border-radius:999px;margin-bottom:18px;position:relative;}
.ai-badge svg{width:14px;height:14px;}
.ai-card h2{font-family:var(--display);font-weight:700;font-size:clamp(24px,4vw,34px);line-height:1.08;letter-spacing:-.02em;margin:0 0 10px;max-width:20ch;position:relative;}
.ai-card .sub{color:var(--muted);font-size:14.5px;margin:0 0 24px;position:relative;}
.ai-input{display:flex;align-items:center;gap:10px;background:var(--paper);border:1.5px solid var(--line);border-radius:999px;padding:7px 7px 7px 18px;transition:border-color .2s,box-shadow .2s;position:relative;}
.ai-input:focus-within{border-color:var(--teal);box-shadow:0 0 0 4px var(--teal-soft);}
.ai-input input{border:none;outline:none;background:none;font-family:inherit;font-size:15px;width:100%;padding:9px 0;color:var(--ink);}
.ai-input .ask{display:inline-flex;align-items:center;gap:7px;background:var(--teal);color:#fff;border-radius:999px;padding:11px 19px;font-size:14px;font-weight:600;white-space:nowrap;flex:none;transition:background .2s,transform .15s;}
.ai-input .ask:hover{background:var(--teal-deep);transform:scale(1.02);}
.ai-input .ask svg{width:15px;height:15px;}
.ai-chips{display:flex;gap:9px;flex-wrap:wrap;margin-top:16px;position:relative;}
.ai-chip{font-size:13px;font-weight:500;color:var(--teal);background:var(--surface);border:1px solid var(--teal-soft);border-radius:999px;padding:8px 14px;transition:all .18s;}
.ai-chip:hover{background:var(--teal-soft);transform:translateY(-2px);}
.ai-result{margin-top:24px;position:relative;}
.ai-thinking{display:none;align-items:center;gap:11px;color:var(--muted);font-size:14px;padding:8px 0;}
.ai-thinking.show{display:flex;}
.ai-thinking .dots{display:inline-flex;gap:5px;}
.ai-thinking .dots i{width:8px;height:8px;border-radius:50%;background:var(--teal);animation:bd 1.1s infinite;}
.ai-thinking .dots i:nth-child(2){animation-delay:.15s;}.ai-thinking .dots i:nth-child(3){animation-delay:.3s;}
@keyframes bd{0%,60%,100%{opacity:.25;transform:translateY(0);}30%{opacity:1;transform:translateY(-5px);}}
.itin{display:none;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:22px;animation:fadeup .5s var(--ease);}
.itin.show{display:block;}
@keyframes fadeup{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:none;}}
.itin .demo{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:14px;display:flex;align-items:center;gap:7px;}
.itin .demo i{width:5px;height:5px;border-radius:50%;background:var(--brass);}
.itin .summ{font-size:14.5px;color:var(--ink);margin:0 0 18px;font-weight:500;}
.steps{position:relative;padding-left:6px;}
.step{display:flex;gap:15px;position:relative;padding-bottom:18px;}
.step:last-child{padding-bottom:0;}
.step .num{width:30px;height:30px;border-radius:50%;background:var(--teal);color:#fff;font-family:var(--mono);font-weight:700;font-size:13px;display:grid;place-items:center;flex:none;z-index:2;}
.step:not(:last-child)::before{content:"";position:absolute;left:14.5px;top:32px;bottom:2px;width:2px;background:repeating-linear-gradient(var(--teal-soft) 0 5px,transparent 5px 10px);}
.step .si b{font-family:var(--display);font-weight:600;font-size:16px;display:block;line-height:1.2;}
.step .si span{font-family:var(--mono);font-size:11px;color:var(--muted);}
.step .si .tag{display:inline-block;font-size:11px;color:var(--teal);background:var(--teal-soft);padding:2px 9px;border-radius:999px;margin-top:5px;}

/* ============ KULINER HYPE ============ */
.hype-rail{display:flex;gap:18px;overflow-x:auto;padding:4px 2px 14px;scroll-snap-type:x mandatory;scrollbar-width:none;}
.hype-rail::-webkit-scrollbar{display:none;}
.hype{flex:none;width:300px;scroll-snap-align:start;background:var(--ink);border-radius:var(--r-lg);overflow:hidden;color:#fff;box-shadow:var(--sh);display:flex;flex-direction:column;}
.tt-embed{width:100%;background:#000;}
.tt-embed iframe{display:block;width:100%;height:560px;border:0;}
.hype .vp{aspect-ratio:9/13;position:relative;background:linear-gradient(165deg,#243d39,#0e1c1a);display:grid;place-items:center;overflow:hidden;}
.hype .vp .play{width:58px;height:58px;border-radius:50%;background:rgba(255,255,255,.16);backdrop-filter:blur(6px);display:grid;place-items:center;border:1.5px solid rgba(255,255,255,.4);position:relative;z-index:2;transition:transform .2s;}
.hype:hover .vp .play{transform:scale(1.1);}
.hype .vp .play svg{width:22px;height:22px;color:#fff;margin-left:3px;}
.hype .vp .tt{position:absolute;top:13px;left:13px;display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;background:rgba(0,0,0,.5);padding:4px 9px;border-radius:999px;z-index:2;}
.hype .vp .tt svg{width:12px;height:12px;}
.hype .vp .hint{position:absolute;bottom:16px;left:0;right:0;text-align:center;font-family:var(--mono);font-size:10px;color:rgba(255,255,255,.6);padding:0 18px;line-height:1.5;}
.hype .hb{padding:14px 16px 17px;}
.hype .hb b{font-family:var(--display);font-weight:600;font-size:17px;display:block;margin-bottom:3px;}
.hype .hb span{font-family:var(--mono);font-size:11px;color:#A9BDB8;}
.hype .hb .meta{font-size:12px;color:#C3D2CE;font-family:var(--body);margin-top:6px;}

/* ============ IKONIK ============ */
.ikonik{display:grid;grid-template-columns:1fr;gap:14px;}
@media(min-width:640px){.ikonik{grid-template-columns:1fr 1fr;}}
.dish{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);padding:16px 18px;display:flex;gap:15px;align-items:flex-start;transition:border-color .18s,transform .18s;}
.dish:hover{border-color:var(--brass);transform:translateY(-2px);}
.dish .em{font-size:30px;flex:none;line-height:1;margin-top:2px;}
.dish b{font-family:var(--display);font-size:19px;font-weight:600;display:block;margin-bottom:3px;}
.dish p{margin:0;font-size:13px;color:var(--muted);line-height:1.55;}
.dish .where{display:block;margin-top:8px;font-family:var(--mono);font-size:10px;color:var(--teal);letter-spacing:.02em;}

/* ============ FOOTER ============ */
footer{background:var(--ink);color:#A9BDB8;padding:54px 0 calc(var(--tabh) + 50px);}
@media(min-width:780px){footer{padding-bottom:56px;}}
.ft-grid{display:grid;grid-template-columns:1fr;gap:30px;}
@media(min-width:680px){.ft-grid{grid-template-columns:1.4fr 1fr 1fr;}}
.ft-brand{font-family:var(--display);font-weight:700;font-size:24px;color:#fff;display:flex;align-items:center;gap:11px;margin-bottom:14px;}
.ft-brand img{width:36px;height:28px;object-fit:contain;}
footer p{font-size:13px;line-height:1.7;margin:0 0 8px;max-width:36ch;}
.ft-col h4{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--brass);margin:0 0 14px;}
.ft-col a{display:block;font-size:13.5px;color:#C3D2CE;padding:5px 0;transition:color .15s;}
.ft-col a:hover{color:#fff;}
.ft-disc{margin-top:32px;padding-top:22px;border-top:1px solid rgba(255,255,255,.08);font-size:11.5px;color:#7C8C88;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.ft-disc b{color:#A9BDB8;}

/* ============ BOTTOM NAV (mobile) ============ */
.bottomnav{display:none;}
@media(max-width:779px){
  .bottomnav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:95;height:calc(var(--tabh) + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);background:rgba(255,255,255,.96);backdrop-filter:blur(14px);border-top:1px solid var(--line);box-shadow:0 -4px 20px rgba(19,33,31,.06);}
  .bn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--muted);font-size:10.5px;font-weight:600;position:relative;transition:color .2s;}
  .bn svg{width:22px;height:22px;}
  .bn.active{color:var(--coral);}
  .bn.active::before{content:"";position:absolute;top:0;width:26px;height:3px;border-radius:0 0 4px 4px;background:var(--coral);}
  body{padding-bottom:var(--tabh);}
}

/* =====================================================================
   HALAMAN DETAIL
   ===================================================================== */
.detail-hero{position:relative;background-size:cover;background-position:center;color:#fff;padding:34px 0 42px;min-height:320px;display:flex;align-items:flex-end;}
.detail-hero::after{content:"";position:absolute;inset:0;opacity:.4;background-image:radial-gradient(circle, rgba(255,255,255,.1) 1px, transparent 1.2px);background-size:26px 26px;pointer-events:none;}
.detail-hero.has-cover::after{display:none;}
.detail-hero-in{position:relative;z-index:2;width:100%;}
.crumb{display:inline-flex;align-items:center;gap:7px;color:rgba(255,255,255,.9);font-family:var(--mono);font-size:12px;letter-spacing:.03em;margin-bottom:20px;transition:color .15s;}
.crumb:hover{color:#fff;}
.hero-emoji{font-size:50px;margin-bottom:14px;filter:drop-shadow(0 3px 9px rgba(0,0,0,.4));}
.cat-pill{display:inline-block;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;background:var(--c);color:#fff;padding:5px 12px;border-radius:6px;margin-bottom:14px;}
.detail-hero h1{font-family:var(--display);font-weight:800;font-size:clamp(34px,7vw,60px);letter-spacing:-.02em;margin:0 0 14px;line-height:.98;text-shadow:0 2px 24px rgba(0,0,0,.4);}
.hero-meta{display:flex;gap:9px 22px;flex-wrap:wrap;align-items:center;font-size:14px;margin-bottom:24px;}
.hero-meta .loc{font-family:var(--mono);font-size:12.5px;}
.hero-meta .rate{display:inline-flex;align-items:center;gap:7px;background:rgba(0,0,0,.32);padding:6px 13px;border-radius:999px;backdrop-filter:blur(3px);font-size:13.5px;}
.hero-meta .rate.muted{color:rgba(255,255,255,.85);}
.rstars{color:var(--brass);letter-spacing:1px;}
.rstars.sm{font-size:13px;}
.hero-actions{display:flex;gap:11px;flex-wrap:wrap;}
.btn-solid{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--ink);border-radius:12px;padding:13px 19px;font-weight:700;font-size:14.5px;transition:transform .12s;}
.btn-solid svg{width:17px;height:17px;color:var(--coral);}
.btn-solid:hover{transform:translateY(-2px);}
.btn-ghost{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.14);color:#fff;border:1.5px solid rgba(255,255,255,.5);border-radius:12px;padding:13px 19px;font-weight:700;font-size:14.5px;}
.btn-ghost:hover{background:rgba(255,255,255,.24);}
.detail-body{display:grid;grid-template-columns:1fr;gap:26px;padding:36px 24px calc(var(--tabh) + 48px);max-width:var(--maxw);margin:0 auto;}
@media(min-width:780px){.detail-body{padding-bottom:60px;}}
@media(min-width:900px){.detail-body{grid-template-columns:1fr 340px;align-items:start;}}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:26px;margin-bottom:22px;box-shadow:var(--sh-sm);}
.panel:last-child{margin-bottom:0;}
.panel-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:20px;}
.panel-head h2{font-family:var(--display);font-weight:700;font-size:24px;margin:0;letter-spacing:-.01em;}
.counter{font-family:var(--mono);font-size:11.5px;color:var(--muted);}
.lead-desc{font-size:16.5px;color:var(--ink);margin:0 0 18px;line-height:1.75;}
.tags{display:flex;gap:7px;flex-wrap:wrap;}
.tags .t{font-family:var(--mono);font-size:10.5px;color:var(--teal);background:var(--teal-soft);padding:4px 11px;border-radius:999px;letter-spacing:.02em;}
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
@media(min-width:480px){.gallery{grid-template-columns:repeat(3,1fr);}}
@media(min-width:700px){.gallery{grid-template-columns:repeat(4,1fr);}}
.g-item{padding:0;border:none;background:var(--paper-2);overflow:hidden;aspect-ratio:1;cursor:zoom-in;border-radius:12px;}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease);}
.g-item:hover img{transform:scale(1.08);}
.reviews{display:flex;flex-direction:column;gap:18px;}
.review{border-bottom:1px solid var(--line);padding-bottom:18px;}
.review:last-child{border-bottom:none;padding-bottom:0;}
.rv-head{display:flex;align-items:center;gap:12px;margin-bottom:9px;}
.avatar{width:42px;height:42px;border-radius:50%;background:var(--c);color:#fff;display:grid;place-items:center;font-weight:700;font-size:18px;flex:none;font-family:var(--display);}
.rv-who{min-width:0;}
.rv-who b{font-family:var(--display);font-size:17px;font-weight:600;display:block;line-height:1.15;}
.rv-sub{font-family:var(--mono);font-size:11px;color:var(--muted);}
.rv-report{margin-left:auto;flex:none;display:inline-flex;align-items:center;gap:5px;border:1px solid var(--line);color:var(--faint);border-radius:999px;padding:5px 10px;font-size:11px;font-weight:600;transition:all .15s;}
.rv-report svg{width:12px;height:12px;}
.rv-report:hover{border-color:var(--coral);color:var(--coral);background:var(--coral-soft);}
.rv-report span{display:none;}
@media(min-width:520px){.rv-report span{display:inline;}}
.rv-body{font-size:14.5px;margin:0 0 11px;color:var(--ink);}
.rv-photos{display:flex;gap:9px;flex-wrap:wrap;}
.rv-photo{padding:0;border:1px solid var(--line);overflow:hidden;width:90px;height:90px;cursor:zoom-in;border-radius:10px;}
.rv-photo img{width:100%;height:100%;object-fit:cover;}
.empty{text-align:center;padding:54px 20px;}
.empty h2{font-family:var(--display);font-size:30px;margin:0 0 8px;}
.empty.mini{padding:34px 18px;color:var(--muted);background:var(--paper);border:1px dashed var(--line);border-radius:var(--r-sm);}
.empty .em{font-size:30px;margin-bottom:10px;}
.empty p{margin:0;font-size:14px;}
.flash{border-radius:12px;padding:13px 16px;font-size:14px;font-weight:600;margin-bottom:20px;}
.flash.ok{background:var(--teal-soft);color:var(--teal-deep);border:1px solid #BBD3CE;}
.flash.err{background:var(--coral-soft);color:var(--coral-deep);border:1px solid #E8C0BA;}
.form-note{font-size:13.5px;color:var(--muted);margin:0 0 20px;}
.field{margin-bottom:18px;}
.field label{display:block;font-family:var(--mono);font-size:11px;font-weight:700;margin-bottom:8px;color:var(--ink);letter-spacing:.05em;text-transform:uppercase;}
.field input[type=text],.field textarea{width:100%;border:1.5px solid var(--line);border-radius:11px;padding:12px 14px;font-family:inherit;font-size:15px;color:var(--ink);background:var(--paper);}
.field input[type=text]:focus,.field textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px var(--teal-soft);background:var(--surface);}
.field textarea{resize:vertical;}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}
.star-input{display:inline-flex;flex-direction:row-reverse;gap:5px;font-size:32px;line-height:1;}
.star-input input{display:none;}
.star-input label{color:var(--line-2);cursor:pointer;transition:color .12s;}
.star-input input:checked ~ label,.star-input label:hover,.star-input label:hover ~ label{color:var(--brass);}
.filedrop{position:relative;border:1.8px dashed var(--line);border-radius:12px;background:var(--paper);transition:border-color .15s;}
.filedrop:hover{border-color:var(--teal);}
.filedrop input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;}
.filedrop-cta{display:flex;align-items:center;gap:13px;padding:19px;color:var(--muted);}
.filedrop-cta svg{width:26px;height:26px;color:var(--teal);flex:none;}
.filedrop-cta small{color:var(--faint);}
.previews{display:flex;gap:10px;flex-wrap:wrap;margin-top:13px;}
.pv{position:relative;width:84px;height:84px;border-radius:10px;overflow:hidden;border:1px solid var(--line);}
.pv img{width:100%;height:100%;object-fit:cover;}
.pv button{position:absolute;top:3px;right:3px;width:21px;height:21px;border-radius:50%;border:none;background:rgba(0,0,0,.62);color:#fff;font-size:12px;line-height:1;display:grid;place-items:center;}
.btn-submit{background:var(--coral);color:#fff;border-radius:12px;padding:14px 24px;font-weight:700;font-size:15px;transition:background .15s,transform .12s;}
.btn-submit:hover{background:var(--coral-deep);transform:translateY(-2px);}
.detail-aside .aside-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:20px;box-shadow:var(--sh-sm);}
@media(min-width:900px){.detail-aside{position:sticky;top:84px;}}
.aside-card h3{font-family:var(--display);font-size:20px;font-weight:600;margin:0 0 13px;}
.aside-card #map{height:210px;margin-bottom:13px;box-shadow:none;border-radius:12px;}
.btn-line{display:inline-block;border:1.5px solid var(--teal);color:var(--teal);border-radius:11px;padding:11px 15px;font-weight:700;font-size:13.5px;text-align:center;transition:all .15s;background:none;}
.btn-line:hover{background:var(--teal);color:#fff;}
.btn-line.full{display:block;width:100%;}
.aside-note{font-size:11.5px;color:var(--faint);margin:13px 0 0;line-height:1.55;}
.dist-out{font-family:var(--mono);font-size:12px;color:var(--coral-deep);font-weight:700;margin:11px 0 0;}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(10,12,11,.95);display:none;align-items:center;justify-content:center;padding:30px;touch-action:none;}
.lightbox.open{display:flex;}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:10px;box-shadow:0 12px 56px rgba(0,0,0,.65);transition:transform .2s;cursor:zoom-in;touch-action:none;}
.lightbox img.zoomed{cursor:zoom-out;transition:none;}
.lb-close{position:absolute;top:18px;right:24px;color:#fff;font-size:30px;line-height:1;opacity:.85;z-index:2;}
.lb-close:hover{opacity:1;}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);width:50px;height:50px;border-radius:50%;color:#fff;font-size:30px;line-height:1;display:grid;place-items:center;opacity:.85;z-index:2;}
.lb-nav:hover{opacity:1;background:rgba(255,255,255,.22);}
.lb-nav.prev{left:18px;}.lb-nav.next{right:18px;}
.lb-count{position:absolute;bottom:22px;left:0;right:0;text-align:center;color:#fff;font-family:var(--mono);font-size:12.5px;opacity:.8;}

/* modal laporan */
.modal{position:fixed;inset:0;z-index:210;background:rgba(10,18,16,.62);display:none;align-items:flex-end;justify-content:center;}
@media(min-width:560px){.modal{align-items:center;padding:24px;}}
.modal.open{display:flex;}
.modal-card{background:var(--surface);width:100%;max-width:460px;border-radius:20px 20px 0 0;padding:24px 22px calc(24px + env(safe-area-inset-bottom));position:relative;box-shadow:0 -10px 40px rgba(0,0,0,.3);}
@media(min-width:560px){.modal-card{border-radius:20px;padding:26px;box-shadow:var(--sh-lg);}}
.modal-x{position:absolute;top:14px;right:16px;font-size:22px;color:var(--faint);line-height:1;}
.modal-card h3{font-family:var(--display);font-weight:700;font-size:23px;margin:0 0 4px;}
.modal-sub{font-size:13px;color:var(--muted);margin:0 0 18px;}
.rep-reasons{display:flex;flex-direction:column;gap:9px;margin-bottom:16px;}
.rep-reasons label{display:flex;align-items:center;gap:11px;border:1.5px solid var(--line);border-radius:11px;padding:12px 14px;cursor:pointer;font-size:14px;font-weight:600;color:var(--ink);transition:all .12s;}
.rep-reasons label:hover{border-color:var(--coral);}
.rep-reasons input{accent-color:var(--coral);width:17px;height:17px;flex:none;}
.rep-reasons input:checked + span{color:var(--coral);}
.modal-card textarea{width:100%;border:1.5px solid var(--line);border-radius:11px;padding:11px 13px;font-family:inherit;font-size:14px;background:var(--paper);resize:vertical;margin-bottom:16px;}
.modal-card textarea:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 4px var(--coral-soft);}
.modal-actions{display:flex;gap:10px;}
.modal-actions .btn-line,.modal-actions .btn-submit{flex:1;}

@media(max-width:520px){.wrap{padding:0 18px;}section.blk{padding:48px 0;}.detail-body{padding-left:18px;padding-right:18px;}.panel{padding:18px 16px;}}
@media (prefers-reduced-motion: reduce){*{animation:none!important;transition-duration:.01ms!important;scroll-behavior:auto!important;}.rv{opacity:1;transform:none;}}

/* ============ SARANKAN TEMPAT ============ */
.suggest{display:grid;grid-template-columns:1fr;gap:26px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);padding:clamp(24px,4vw,40px);box-shadow:var(--sh-sm);}
@media(min-width:820px){.suggest{grid-template-columns:1fr 1fr;align-items:center;gap:44px;}}
.suggest-copy h2{font-family:var(--display);font-weight:700;font-size:clamp(24px,4vw,32px);letter-spacing:-.02em;margin:8px 0 10px;line-height:1.08;}
.suggest-copy p{color:var(--muted);font-size:14.5px;margin:0;}
.suggest-form{display:flex;flex-direction:column;gap:11px;}
.sf-row{display:grid;grid-template-columns:1fr 1fr;gap:11px;}
@media(max-width:520px){.sf-row{grid-template-columns:1fr;}}
.sf{width:100%;border:1.5px solid var(--line);border-radius:11px;padding:12px 14px;font-family:inherit;font-size:14.5px;color:var(--ink);background:var(--paper);}
.sf:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px var(--teal-soft);background:var(--surface);}
select.sf{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%235E6B68' stroke-width='2.4'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;}
textarea.sf{resize:vertical;}
.sf-submit{background:var(--coral);color:#fff;border-radius:11px;padding:13px;font-weight:700;font-size:15px;transition:background .15s,transform .12s;}
.sf-submit:hover{background:var(--coral-deep);transform:translateY(-2px);}

/* ============================================================
   TAMBAHAN: rute Maps, Tersimpan, Peta lengkap, Info praktis
   ============================================================ */
.btn-route{display:inline-flex;align-items:center;gap:.5rem;background:var(--teal,#0E4F47);color:#fff;font-weight:700;font-size:.92rem;padding:.7rem 1.1rem;border-radius:12px;text-decoration:none;box-shadow:0 6px 18px rgba(14,79,71,.25)}
.btn-route:hover{background:var(--teal-deep,#0A352F)}

#tersimpan .saved-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.75rem;margin-top:1rem}
.saved-card{position:relative;display:flex;align-items:center;gap:.7rem;background:#fff;border:1px solid rgba(19,33,31,.10);border-radius:14px;padding:.7rem .85rem;text-decoration:none;color:var(--ink,#13211F);transition:transform .15s,box-shadow .15s}
.saved-card:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(19,33,31,.10)}
.saved-card .sc-dot{width:8px;height:8px;border-radius:50%;flex:none}
.saved-card .sc-ic{font-size:1.3rem;flex:none}
.saved-card .sc-tx{display:flex;flex-direction:column;min-width:0;line-height:1.25}
.saved-card .sc-tx b{font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.saved-card .sc-tx small{color:var(--muted,#6b7a77);font-size:.78rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.saved-card .sc-rm{position:absolute;top:.4rem;right:.5rem;width:22px;height:22px;border:none;background:rgba(19,33,31,.06);color:var(--muted,#6b7a77);border-radius:50%;font-size:1rem;line-height:1;cursor:pointer}
.saved-card .sc-rm:hover{background:var(--coral,#E1533F);color:#fff}

.all-map{height:70vh;min-height:440px;border-radius:18px;overflow:hidden;border:1px solid rgba(19,33,31,.12);margin-top:1rem}
.map-legend{display:flex;flex-wrap:wrap;gap:.5rem 1.1rem;margin-top:.9rem}
.map-legend .lg{display:inline-flex;align-items:center;gap:.45rem;font-size:.86rem;color:var(--ink,#13211F);font-weight:600}
.map-legend .lg i{width:11px;height:11px;border-radius:3px;display:inline-block}
.all-map .pin{position:relative;display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);background:var(--c,#0E4F47);box-shadow:0 3px 8px rgba(0,0,0,.3);border:2px solid #fff}
.all-map .pin i{transform:rotate(45deg);font-style:normal;font-size:14px;line-height:1}

.info-praktis{margin:1rem 0;padding:1rem 1.1rem;background:var(--paper,#F1F3F2);border-radius:14px;border:1px solid rgba(19,33,31,.08)}
.info-praktis h4{margin:0 0 .6rem;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted,#6b7a77)}
.info-praktis .ip-row{display:flex;justify-content:space-between;gap:1rem;padding:.4rem 0;border-bottom:1px dashed rgba(19,33,31,.10);font-size:.92rem}
.info-praktis .ip-row:last-of-type{border-bottom:none}
.info-praktis .ip-row span{color:var(--muted,#6b7a77);flex:none}
.info-praktis .ip-row b{text-align:right;color:var(--ink,#13211F)}
.info-praktis .ip-disc{margin:.6rem 0 0;font-size:.76rem;color:var(--muted,#6b7a77);font-style:italic}

/* ============ AKUN: menu header, halaman auth, CTA login ============ */
.user-menu{display:flex;align-items:center;gap:8px;margin-left:auto;}
.um-chip{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:4px 12px 4px 4px;box-shadow:var(--sh-sm);}
.um-chip .um-av{width:26px;height:26px;border-radius:50%;background:var(--teal);color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:13px;flex:none;}
.um-chip .um-nm{font-size:13px;font-weight:600;color:var(--ink);max-width:96px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.um-out{margin:0;}
.um-out button{background:none;border:none;cursor:pointer;font-family:var(--body);font-size:12.5px;font-weight:600;color:var(--muted);padding:6px 4px;}
.um-out button:hover{color:var(--coral);}
.um-login{font-size:13.5px;font-weight:600;color:var(--ink);}
.um-reg{font-size:13.5px;font-weight:700;color:#fff;background:var(--teal);padding:8px 15px;border-radius:999px;transition:background .2s;}
.um-reg:hover{background:var(--teal-deep);}
@media(min-width:1000px){.user-menu{margin-left:0;}}
@media(max-width:560px){.um-chip .um-nm{max-width:72px;}.um-login{font-size:13px;}.um-reg{font-size:13px;padding:7px 13px;}.user-menu{gap:6px;}}
@media(max-width:380px){.logo .nm small{display:none;}.top-in{gap:10px;}}

.auth-blk{background:linear-gradient(180deg,var(--paper) 0%,var(--paper-2) 100%);min-height:72vh;display:flex;align-items:center;}
.auth-wrap{width:100%;}
.auth-card{max-width:440px;margin:0 auto;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl,22px);box-shadow:var(--sh,0 20px 50px rgba(19,33,31,.1));padding:clamp(26px,4vw,40px);}
.auth-head{margin-bottom:22px;}
.auth-head h1{font-family:var(--display);font-weight:700;font-size:clamp(26px,5vw,32px);letter-spacing:-.02em;margin:6px 0 8px;line-height:1.1;}
.auth-head p{color:var(--muted);font-size:14px;margin:0;}
.auth-form{display:flex;flex-direction:column;gap:14px;}
.auth-form .fld{display:flex;flex-direction:column;gap:6px;}
.auth-form .fld span{font-size:12.5px;font-weight:600;color:var(--ink-2);}
.auth-form .fld input{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:12px 14px;font-family:inherit;font-size:15px;color:var(--ink);background:var(--paper);transition:border-color .18s,box-shadow .18s;}
.auth-form .fld input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px var(--teal-soft);background:var(--surface);}
.auth-submit{margin-top:6px;background:var(--teal);color:#fff;border:none;border-radius:12px;padding:14px;font-family:inherit;font-size:15px;font-weight:700;cursor:pointer;transition:background .2s,transform .15s;}
.auth-submit:hover{background:var(--teal-deep);transform:translateY(-1px);}
.auth-err{background:var(--coral-soft);color:var(--coral-deep);border:1px solid color-mix(in srgb,var(--coral) 30%,transparent);border-radius:12px;padding:11px 14px;font-size:13.5px;font-weight:500;margin-bottom:16px;}
.auth-alt{margin:18px 0 0;text-align:center;font-size:13.5px;color:var(--muted);}
.auth-alt a{color:var(--teal);font-weight:700;}

.login-cta{display:flex;align-items:center;gap:15px;background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:18px 20px;}
.login-cta .lc-ic{font-size:30px;flex:none;line-height:1;}
.login-cta .lc-tx{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px;}
.login-cta .lc-tx b{font-family:var(--display);font-weight:600;font-size:16px;color:var(--ink);}
.login-cta .lc-tx span{font-size:13px;color:var(--muted);line-height:1.45;}
.login-cta .lc-act{display:flex;align-items:center;gap:10px;flex:none;}
.login-cta .lc-btn{background:var(--teal);color:#fff;font-weight:700;font-size:13.5px;padding:10px 18px;border-radius:999px;transition:background .2s;}
.login-cta .lc-btn:hover{background:var(--teal-deep);}
.login-cta .lc-link{color:var(--teal);font-weight:700;font-size:13.5px;}
@media(max-width:520px){.login-cta{flex-direction:column;align-items:flex-start;}.login-cta .lc-act{width:100%;}}

/* kartu lebih ringkas di layar kecil */
@media(max-width:560px){.card{aspect-ratio:3/3.8;}.card h3{font-size:21px;}.card .bd{padding:18px;}}


/* toggle tampilan kartu (khusus mobile) */
.viewtoggle{display:none;}
@media(max-width:640px){
.viewtoggle{display:inline-flex;gap:4px;background:var(--paper-2);border:1px solid var(--line);border-radius:999px;padding:3px;margin:14px 0 0;}
.viewtoggle .vt{width:38px;height:30px;border-radius:999px;display:grid;place-items:center;background:transparent;border:none;cursor:pointer;color:var(--muted);transition:background .2s,color .2s;}
.viewtoggle .vt svg{width:17px;height:17px;}
.viewtoggle .vt.on{background:var(--surface);color:var(--teal);box-shadow:var(--sh-sm);}
.cards.cols2{grid-template-columns:1fr 1fr;gap:13px;}
.cards.cols2 .card{aspect-ratio:3/4;}
.cards.cols2 .card .bd{padding:13px;}
.cards.cols2 .card h3{font-size:15px;margin-bottom:5px;}
.cards.cols2 .card .why{display:none;}
.cards.cols2 .card .cd{font-size:8.5px;margin-bottom:6px;}
.cards.cols2 .card .cat{font-size:8.5px;top:11px;left:11px;}
.cards.cols2 .card .save{width:30px;height:30px;top:10px;right:10px;}
.cards.cols2 .card .meta .pl{font-size:9.5px;padding:4px 8px;}
.cards.cols2 .card .meta .rate{font-size:10px;}
}


/* dish (kuliner ikonik) jadi link */
.dish{cursor:pointer;text-decoration:none;}
.dish .dish-go{display:inline-block;margin-top:10px;font-family:var(--mono);font-size:11px;font-weight:700;color:var(--coral);letter-spacing:.02em;}
.dish:hover .dish-go{color:var(--coral-deep);}

/* ===== Halaman kuliner per hidangan ===== */
.kulpage{background:var(--paper);min-height:70vh;}
.kulpage .wrap.narrow{max-width:720px;}
.kulpage .back{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:12px;font-weight:700;color:var(--teal);margin-bottom:20px;}
.kulpage .back svg{width:15px;height:15px;}
.ksec-head{display:flex;gap:18px;align-items:flex-start;margin-bottom:6px;}
.ksec-head .kd-em.big{font-size:clamp(42px,9vw,56px);line-height:1;flex:none;}
.ksec-head h1{font-family:var(--display);font-weight:700;font-size:clamp(26px,5vw,36px);letter-spacing:-.02em;margin:6px 0 8px;line-height:1.08;}
.ksec-head p{color:var(--muted);font-size:14.5px;margin:0;max-width:60ch;}
.near-head{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin:22px 0 16px;}
.klist{display:grid;grid-template-columns:1fr;gap:12px;}
@media(min-width:680px){.klist{grid-template-columns:1fr 1fr;}}
.krow{display:flex;align-items:stretch;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);overflow:hidden;transition:border-color .2s,box-shadow .2s,transform .2s;}
.krow:hover{border-color:var(--teal);box-shadow:var(--sh-sm);transform:translateY(-2px);}
.krow-link{display:flex;gap:13px;align-items:flex-start;padding:14px;flex:1;min-width:0;}
.krow .kr-ic{font-size:30px;flex:none;line-height:1;margin-top:2px;}
.krow .kr-tx{min-width:0;display:flex;flex-direction:column;}
.krow .kr-tx b{font-family:var(--display);font-weight:600;font-size:16px;color:var(--ink);line-height:1.18;}
.krow .kr-area{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:10.5px;color:var(--muted);margin:4px 0 6px;}
.krow .kr-area svg{width:11px;height:11px;color:var(--faint);flex:none;}
.krow .kr-note{font-size:12.5px;color:var(--muted);line-height:1.5;}
.krow .kr-side{flex:none;display:flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:8px;padding:12px;border-left:1px solid var(--line);background:var(--paper);}
.krow .kr-km{font-family:var(--mono);font-weight:700;font-size:12px;color:var(--coral);min-height:14px;}
.kempty{grid-column:1/-1;padding:26px;text-align:center;color:var(--muted);font-size:14px;}
.kdisc{margin-top:18px;font-family:var(--mono);font-size:11px;color:var(--faint);line-height:1.6;}
.kdetail{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:clamp(22px,4vw,34px);box-shadow:var(--sh-sm);}
.kdetail .kd-em{font-size:46px;line-height:1;display:block;margin-bottom:10px;}
.kdetail .eyebrow{color:var(--coral);}
.kdetail .eyebrow::before{background:var(--coral);}
.kdetail h1{font-family:var(--display);font-weight:700;font-size:clamp(24px,4.5vw,32px);letter-spacing:-.02em;margin:6px 0 10px;line-height:1.1;}
.kdetail .kd-area{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:12.5px;color:var(--muted);margin-bottom:14px;}
.kdetail .kd-area svg{width:14px;height:14px;color:var(--coral);}
.kdetail .kd-note{font-size:15px;color:var(--ink-2);line-height:1.6;margin:0 0 14px;}
.kdetail .kd-coord{font-family:var(--mono);font-size:11.5px;color:var(--faint);margin-bottom:20px;}
.kd-act{display:flex;flex-wrap:wrap;gap:11px;}
.kbtn{display:inline-flex;align-items:center;gap:7px;border-radius:999px;padding:12px 20px;font-size:14px;font-weight:700;border:1.5px solid var(--line);color:var(--ink);background:var(--surface);transition:all .2s;}
.kbtn:hover{border-color:var(--teal);transform:translateY(-1px);}
.kbtn.primary{background:var(--teal);color:#fff;border-color:var(--teal);box-shadow:0 8px 22px rgba(14,79,71,.25);}
.kbtn.primary:hover{background:var(--teal-deep);}
.kbtn svg{width:16px;height:16px;}


/* ===== Smart search: petunjuk hero + panel hasil ===== */
.hero-ai-hint{display:inline-flex;align-items:center;gap:9px;flex-wrap:wrap;font-size:13px;color:var(--muted);margin-bottom:14px;}
.hero-ai-hint .ai-badge{margin-bottom:0;}
.hero-ai-hint em{font-style:normal;color:var(--ink-2);font-weight:600;}
.smart-head{display:flex;align-items:center;justify-content:space-between;gap:12px;position:relative;}
.smart-reset{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;color:var(--muted);background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:7px 13px;cursor:pointer;transition:all .18s;}
.smart-reset:hover{border-color:var(--coral);color:var(--coral);}
.smart-reset svg{width:12px;height:12px;}
.ai-card .smart-title{font-family:var(--display);font-weight:700;font-size:clamp(20px,3vw,26px);letter-spacing:-.015em;line-height:1.15;margin:14px 0 6px;max-width:none;position:relative;}
.smart-sub{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;color:var(--muted);text-transform:uppercase;margin:2px 0 12px;}
.smart-places:not(:empty){margin-bottom:18px;}
.smart-places .near-list{margin-top:0;}
.smart-places .nrow{background:var(--paper);border-color:var(--line-2);}
.smart-action:not(:empty){margin-bottom:8px;}
.smart-empty{color:var(--muted);font-size:14.5px;line-height:1.6;margin:6px 0 0;}
.smart-route-btn{display:inline-flex;align-items:center;gap:8px;background:var(--teal-soft);color:var(--teal-deep);border:1px solid var(--teal-soft);border-radius:999px;padding:11px 18px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;}
.smart-route-btn:hover{background:var(--teal);color:#fff;transform:translateY(-1px);}
.smart-route-btn svg{width:15px;height:15px;}
