/* ── Design tokens ──────────────────────────────────────────────────────── */
:root {
  --brand:       #F7B239;
  --brand-dark:  #C97A00;
  --brand-dim:   rgba(247,178,57,0.12);
  --brand-glow:  rgba(247,178,57,0.26);
  --bg:          #f5f7fb;
  --panel:       #ffffff;
  --card:        #ffffff;
  --border:      rgba(18,35,61,0.12);
  --ink:         #1d2738;
  --muted:       #61708a;
  --ok:          #22C55E;
  --err:         #c13515;
  --gold:        #F7B239;
  --shadow-card: 0 1px 2px rgba(23,37,84,.06), 0 8px 24px rgba(18,35,61,.08);
  --shadow-hover:0 12px 32px rgba(18,35,61,.15);
  --r:  22px;
  --rb: 14px;
  --rs: 10px;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{height:100%;background:var(--bg)}
body{min-height:100vh;background:var(--bg);color:var(--ink);font-family:'Sarabun',sans-serif;font-size:15px;overflow-x:hidden}
body.gg-app-locked{
  position:fixed;
  inset:0;
  width:100%;
  height:100dvh;
  overflow:hidden;
  overscroll-behavior:none;
}
button{font-family:'Sarabun',sans-serif;cursor:pointer}
a{text-decoration:none;color:inherit}

/* ── Loading ────────────────────────────────────────────────────────────── */
.gg-loading{position:fixed;inset:0;background:#fff;display:flex;align-items:center;justify-content:center;z-index:999}
.gg-loading-inner{display:flex;flex-direction:column;align-items:center;gap:16px}
.gg-loading-logo{font-family:'Nunito Sans','Prompt',sans-serif;font-weight:800;font-size:2.2rem;color:var(--brand);letter-spacing:-.5px}
.gg-loading-logo span{color:var(--ink)}
.gg-loading-spin{width:32px;height:32px;border:3px solid rgba(245,166,35,0.2);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite}
.gg-loading-sub{font-size:.82rem;color:var(--muted)}
.gg-create-blocking-overlay{position:absolute;inset:0;z-index:65;background:rgba(255,255,255,0.68);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:24px;pointer-events:auto}
.gg-create-blocking-card{width:min(100%,320px);background:rgba(255,255,255,0.94);border:1px solid rgba(219,223,233,0.95);border-radius:24px;box-shadow:0 24px 80px rgba(31,42,68,0.16);padding:24px 22px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}
.gg-create-blocking-spin{width:34px;height:34px;border:3px solid rgba(245,166,35,0.18);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite}
.gg-create-blocking-title{font-size:1rem;font-weight:800;color:var(--ink)}
.gg-create-blocking-sub{font-size:.86rem;line-height:1.5;color:var(--muted)}
#pgCreate{position:relative}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Page system ─────────────────────────────────────────────────────────── */
.gg-page{min-height:100dvh;background:var(--bg)}

/* ── LOGIN PAGE ──────────────────────────────────────────────────────────── */
.gg-login-page{min-height:100dvh;display:flex;flex-direction:column}
.gg-login-wrap{flex:1;display:flex;flex-direction:column;min-height:100dvh}
.gg-login-left{display:none}
.gg-login-right{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:calc(env(safe-area-inset-top)+40px) 24px calc(40px + env(safe-area-inset-bottom));
  background:#fff;min-height:100dvh;
}
.gg-login-card{width:100%;max-width:400px}
.gg-lc-logo{font-family:'Nunito Sans','Prompt',sans-serif;font-weight:800;font-size:2rem;color:var(--brand);text-align:center;margin-bottom:4px}
.gg-lc-logo span{color:var(--ink)}
.gg-lc-title{font-family:'Nunito Sans','Prompt',sans-serif;font-weight:700;font-size:1.3rem;color:var(--ink);text-align:center;margin-bottom:6px}
.gg-lc-sub{font-size:.85rem;color:var(--muted);text-align:center;line-height:1.6;margin-bottom:28px}
.gg-lc-cats{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:28px}
.gg-lc-cat{display:flex;align-items:center;gap:6px;background:var(--bg);border:1px solid var(--border);border-radius:100px;padding:7px 14px;font-size:.78rem;color:var(--muted)}

@media(min-width:768px){
  .gg-login-wrap{flex-direction:row}
  .gg-login-left{
    display:flex;flex:1;flex-direction:column;align-items:center;justify-content:center;
    padding:48px 40px;
    background:linear-gradient(145deg,#1C1200 0%,#2D1F00 50%,#1C1200 100%);
    position:relative;overflow:hidden;
  }
  .gg-login-left::before{
    content:'';position:absolute;width:500px;height:500px;border-radius:50%;
    background:radial-gradient(circle,rgba(245,166,35,.18) 0%,transparent 70%);
    top:-120px;right:-120px;pointer-events:none;
  }
  .gg-login-left-inner{position:relative;z-index:1;max-width:360px;width:100%}
  .gg-ll-logo{font-family:'Nunito Sans','Prompt',sans-serif;font-weight:800;font-size:2.6rem;color:var(--brand);margin-bottom:10px}
  .gg-ll-logo span{color:#fff}
  .gg-ll-title{font-family:'Nunito Sans','Prompt',sans-serif;font-weight:800;font-size:2.1rem;color:#fff;line-height:1.2;margin-bottom:14px}
  .gg-ll-sub{font-size:.9rem;color:rgba(255,255,255,.6);line-height:1.7;margin-bottom:32px}
  .gg-ll-cats{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .gg-ll-cat{display:flex;align-items:center;gap:10px;background:rgba(245,166,35,.08);border:1px solid rgba(245,166,35,.2);border-radius:12px;padding:12px 16px;font-size:.85rem;color:rgba(255,255,255,.75)}
  .gg-ll-cat span:first-child{font-size:1.3rem}
  .gg-login-right{flex:1;min-height:100dvh;background:#fff;padding:48px 40px}
}

/* Add-friend */
.gg-add-friend-section{margin-bottom:16px}
.gg-add-friend-card{background:#fff;border:1px solid rgba(245,166,35,.3);border-radius:var(--r);padding:20px;text-align:center;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow-card)}
.gg-add-friend-title{font-family:'Nunito Sans','Prompt',sans-serif;font-weight:700;font-size:.9rem;color:var(--ink)}
.gg-add-friend-desc{font-size:.8rem;color:var(--muted);line-height:1.6}

/* CTA / PDPA */
.gg-cta-section{display:flex;flex-direction:column;gap:0}
.gg-pdpa-wrap{display:flex;align-items:flex-start;gap:10px;margin-bottom:16px;cursor:pointer}
.gg-pdpa-cb{width:18px;height:18px;min-width:18px;margin-top:2px;accent-color:var(--brand);cursor:pointer}
.gg-pdpa-label{font-size:.78rem;color:var(--muted);line-height:1.7;cursor:pointer}
.gg-pdpa-link{color:var(--brand-dark);text-decoration:underline}
.gg-line-login-btn{
  width:100%;background:#06C755;border:none;border-radius:var(--rs);
  padding:16px;display:flex;align-items:center;justify-content:center;gap:10px;
  font-family:'Nunito Sans','Prompt',sans-serif;font-weight:700;font-size:1rem;color:#fff;
  box-shadow:0 4px 16px rgba(6,199,85,.28);transition:all .2s;
}
.gg-line-login-btn:hover{background:#05b04b;transform:translateY(-1px)}
.gg-line-login-btn:disabled{opacity:.4;pointer-events:none}
.gg-line-add-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:#06C755;color:#fff;border-radius:var(--rs);padding:12px 20px;font-weight:700;font-size:.88rem}
.gg-login-note{text-align:center;font-size:.72rem;color:var(--muted);margin-top:10px;line-height:1.7}

/* ── APP SHELL ───────────────────────────────────────────────────────────── */
.gg-app-shell{display:flex;flex-direction:column;height:100dvh;overflow:hidden}

/* ── TOPBAR ──────────────────────────────────────────────────────────────── */
.gg-topbar{
  flex-shrink:0;display:flex;align-items:center;gap:8px;
  padding:0 10px;padding-top:env(safe-area-inset-top);
  height:calc(54px + env(safe-area-inset-top));
  background:#fff;border-bottom:1px solid var(--border);z-index:50;
  box-shadow:0 1px 0 rgba(0,0,0,0.06);
}
.gg-topbar-logo{
  font-family:'Nunito Sans','Prompt',sans-serif;font-weight:800;font-size:1.15rem;
  color:var(--brand);letter-spacing:-.3px;white-space:nowrap;flex-shrink:0;
}
.gg-topbar-logo span{color:var(--ink)}
.gg-topbar-right{display:flex;align-items:center;gap:6px;flex-shrink:0;margin-left:auto}
.gg-points-pill{
  display:flex;align-items:center;gap:2px;
  background:var(--brand-dim);border:1px solid var(--brand-glow);
  border-radius:100px;padding:4px 10px;font-size:.76rem;font-weight:700;
  color:var(--brand-dark);cursor:pointer;white-space:nowrap;
}
.gg-lang-toggle{display:flex;background:rgba(0,0,0,0.06);border-radius:100px;padding:2px;flex-shrink:0}
.gg-lbtn{padding:4px 10px;border-radius:100px;border:none;font-size:.7rem;font-weight:700;cursor:pointer;color:var(--muted);background:transparent;transition:all .15s}
.gg-lbtn.on{background:var(--brand);color:#1a1a1a}

/* Search row inline in topbar */
.gg-search-row{flex:1;display:flex;align-items:center;gap:6px;padding:0}
.gg-search-input-wrap{
  flex:1;display:flex;align-items:center;gap:8px;
  background:var(--bg);border:1.5px solid var(--border);border-radius:100px;
  padding:8px 14px;transition:border-color .2s;
}
.gg-search-input-wrap:focus-within{border-color:var(--brand)}
.gg-search-input-wrap svg{flex-shrink:0;color:var(--muted)}
.gg-search-input{flex:1;border:none;background:none;color:var(--ink);font-family:'Sarabun',sans-serif;font-size:.82rem;outline:none}
.gg-search-input::placeholder{color:var(--muted)}
.gg-search-input::-webkit-search-cancel-button{cursor:pointer}
.gg-filter-btn{
  position:relative;flex-shrink:0;
  width:38px;height:38px;border-radius:50%;background:#fff;
  border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;
  color:var(--muted);transition:all .2s;
}
.gg-filter-btn:hover{border-color:var(--ink);color:var(--ink)}
.gg-filter-dot{
  position:absolute;top:0;right:0;width:9px;height:9px;
  background:var(--brand);border-radius:50%;border:2px solid #fff;
}

/* Filter chip row in sheet */
.gg-filter-chip-row{display:flex;gap:8px;flex-wrap:wrap}
.gg-filter-chip{
  background:#fff;border:1.5px solid var(--border);border-radius:100px;
  color:var(--muted);font-size:.84rem;padding:8px 18px;cursor:pointer;transition:all .2s;
}
.gg-filter-chip.on{background:var(--brand-dim);border-color:var(--brand);color:var(--brand-dark);font-weight:600}
.gg-btn-link{background:none;border:none;color:var(--brand-dark);font-size:.85rem;font-weight:600;padding:4px 0;cursor:pointer}

/* Content area */
.gg-content{flex:1;overflow-y:auto;overscroll-behavior:contain;padding-bottom:0;background:var(--bg)}

/* Views */
.gg-view{min-height:100%}
.gg-view-header{
  font-family:'Nunito Sans','Prompt',sans-serif;font-weight:700;font-size:1.1rem;
  color:var(--ink);padding:20px 16px 12px;
}

/* Category grid */
.gg-cat-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;
  padding:14px 12px;background:#fff;border-bottom:1px solid var(--border);
}
.gg-cat-item,.gg-cat-chip{
  display:flex;flex-direction:column;align-items:center;gap:7px;
  background:none;border:none;padding:0;cursor:pointer;
}
.gg-cat-item.on .gg-cat-item-ico,.gg-cat-chip.on .gg-cat-item-ico{
  border-color:var(--brand);background:var(--brand-dim);
  box-shadow:0 2px 8px rgba(245,166,35,.22);
}
.gg-cat-item.on .gg-cat-item-lbl,.gg-cat-chip.on .gg-cat-item-lbl{color:var(--brand-dark);font-weight:700}
.gg-cat-item-ico{
  width:54px;height:54px;border-radius:16px;
  border:1.5px solid var(--border);background:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;transition:all .2s;
  box-shadow:0 1px 3px rgba(0,0,0,0.06);
}
.gg-cat-item-lbl{font-size:.68rem;color:var(--muted);transition:color .2s;line-height:1.3;text-align:center}

/* Gender filter */
.gg-gender-row{display:flex;gap:8px;padding:12px 14px 8px;overflow-x:auto;scrollbar-width:none;background:var(--bg)}
.gg-gender-row::-webkit-scrollbar{display:none}
.gg-gender-chip{
  flex-shrink:0;background:#fff;border:1px solid var(--border);
  border-radius:100px;color:var(--muted);font-size:.8rem;padding:7px 16px;
  white-space:nowrap;transition:all .2s;cursor:pointer;
  box-shadow:0 1px 3px rgba(0,0,0,0.05);
}
.gg-gender-chip.on{
  background:var(--brand-dim);border-color:var(--brand);color:var(--brand-dark);font-weight:600;
}

/* Section header */
.gg-section-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 8px}
.gg-section-title{font-family:'Nunito Sans','Prompt',sans-serif;font-weight:700;font-size:.92rem;color:var(--ink)}

/* ── BOTTOM NAV ──────────────────────────────────────────────────────────── */
.gg-bottom-nav{
  flex-shrink:0;display:flex;align-items:stretch;background:#fff;
  border-top:1px solid var(--border);
  padding-bottom:env(safe-area-inset-bottom);
  z-index:50;box-shadow:0 -1px 0 rgba(0,0,0,0.06);
  overflow:visible;height:60px;
}
.gg-nav-item{
  flex:1;background:none;border:none;color:var(--muted);
  padding:8px 4px 6px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:3px;font-size:.65rem;transition:color .2s;min-width:0;
}
.gg-nav-item.on{color:var(--brand)}
.gg-nav-svg{width:22px;height:22px;flex-shrink:0}
.gg-nav-notif-wrap{position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.gg-nav-notif-dot{
  position:absolute;top:-2px;right:-4px;width:8px;height:8px;
  background:var(--err);border-radius:50%;border:2px solid #fff;
}
.gg-nav-profile-wrap{display:flex;align-items:center;justify-content:center;flex-shrink:0}
.gg-nav-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;border:2px solid var(--brand)}

/* Center create slot — fixed width, raises button above bar */
.gg-nav-create-slot{
  flex-shrink:0;width:64px;display:flex;align-items:center;justify-content:center;
  position:relative;
}
.gg-nav-create{
  width:60px;height:60px;border-radius:50%;
  background:var(--brand);color:#1a1a1a;border:none;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 4px #fff, 0 6px 20px rgba(245,166,35,.55);
  position:absolute;top:-18px;
  transition:transform .2s,box-shadow .2s;
}
.gg-nav-create:hover{transform:scale(1.07);box-shadow:0 0 0 4px #fff, 0 8px 28px rgba(245,166,35,.7)}
.gg-nav-create:active{transform:scale(.94)}

/* ── FEED SECTION HEADER ─────────────────────────────────────────────────── */
.gg-feed-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px 4px;
}
.gg-feed-title{
  font-family:'Nunito Sans','Prompt',sans-serif;font-weight:700;font-size:.92rem;color:var(--ink);
}
.gg-feed-count{font-size:.78rem;color:var(--muted)}
.gg-feed-cat{color:var(--brand)}
.gg-feed-cat-all{color:var(--brand)}

/* ── ROOM CARDS ──────────────────────────────────────────────────────────── */
.gg-rooms-list{display:flex;flex-direction:column;gap:12px;padding:4px 14px 12px}

.gg-room-card{
  background:#fff;border-radius:var(--r);cursor:pointer;
  box-shadow:var(--shadow-card);position:relative;
  transition:box-shadow .22s,transform .15s;
  overflow:hidden;
}
.gg-room-card:hover{box-shadow:var(--shadow-hover)}
.gg-room-card:active{transform:scale(.995)}
.gg-card-share-btn{position:absolute;top:10px;right:10px;background:rgba(0,0,0,0.05);border:none;border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:background .15s}
.gg-card-share-btn:active{background:var(--brand-dim);color:var(--brand-dark)}

/* Card head: service tag + status */
.gg-card-head{
  display:flex;align-items:center;gap:6px;
  padding:10px 14px 0;
}

/* Card body: avatar left + content right */
.gg-card-inner{display:flex;align-items:flex-start;gap:16px;padding:14px 14px 14px}

/* Creator avatar (focal point) */
.gg-card-av-wrap{position:relative;flex-shrink:0}
.gg-card-av-lg{
  width:56px;height:56px;border-radius:50%;
  object-fit:cover;display:block;border:2px solid rgba(0,0,0,0.06);
}
.gg-card-av-fb{
  background:var(--brand-dim);display:flex;align-items:center;justify-content:center;
  font-family:'Nunito Sans','Prompt',sans-serif;font-weight:700;font-size:1.3rem;color:var(--brand-dark);
}
.gg-card-pax-pill{
  position:absolute;bottom:-4px;right:-6px;
  background:#333;color:#fff;font-size:.62rem;font-weight:700;
  padding:2px 6px;border-radius:100px;border:2px solid #fff;white-space:nowrap;line-height:1.4;
}
.gg-card-pax-pill.pax-full{background:var(--err)}

/* Card content */
.gg-card-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px}
/* Main loc row: location (flex:1) + status badge (right) */
.gg-card-loc-main{align-items:center}
.gg-card-loc-main .gg-status-badge{margin-left:auto;flex-shrink:0}
/* Bottom tag row */
.gg-card-meta-row{display:flex;align-items:center;gap:6px;margin-top:4px}
/* Icon + location rows */
.gg-card-loc-row{display:flex;align-items:baseline;gap:5px}
.gg-loc-ico{font-size:.82rem;flex-shrink:0;line-height:1}
.gg-loc-val{
  font-family:'Nunito Sans','Prompt',sans-serif;font-weight:700;font-size:.9rem;
  color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.gg-loc-sub{font-size:.8rem;font-weight:600;color:var(--muted)}
.gg-loc-time{font-size:.78rem;font-weight:500;color:var(--muted)}
/* Meta rows: label + value */
.gg-card-meta{display:flex;flex-direction:column;gap:3px}
.gg-meta-row{
  display:grid;grid-template-columns:46px 1fr;
  gap:4px;align-items:baseline;
}
.gg-meta-label{
  font-size:.68rem;color:var(--muted);
  white-space:nowrap;
}
.gg-meta-val{
  font-size:.8rem;color:var(--ink);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}

/* Card footer: ::before spacer mirrors avatar width so content aligns with title */
.gg-card-foot{padding:0 14px 10px;display:flex;align-items:center;gap:8px}
.gg-card-foot::before{content:'';width:56px;margin-right:5px;flex-shrink:0}
.gg-card-foot-left{flex:1;display:flex;align-items:center;gap:6px;min-width:0;flex-wrap:wrap}
.gg-card-foot-time{font-size:.72rem;color:var(--muted);white-space:nowrap}

/* Service tag (used in card head) */
.gg-card-svc-tag{
  font-size:.7rem;
  background:var(--brand-dim);border:1px solid var(--brand-glow);
  border-radius:100px;padding:3px 10px;color:var(--brand-dark);font-weight:600;
}

/* ── LOAD MORE ───────────────────────────────────────────────────────────── */
.gg-load-more-wrap{padding:4px 14px 90px;display:flex;justify-content:center}
.gg-load-more-btn{
  background:#fff;border:1.5px solid var(--border);border-radius:var(--rs);
  color:var(--muted);font-size:.85rem;padding:10px 32px;cursor:pointer;
  transition:all .2s;box-shadow:0 1px 3px rgba(0,0,0,.06);
}
.gg-load-more-btn:hover{border-color:var(--brand);color:var(--brand-dark)}

/* Status badges */
.gg-status-badge{display:inline-flex;align-items:center;font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:var(--rb)}
.status-open{background:rgba(34,197,94,.12);color:#15803D}
.status-full{background:rgba(245,166,35,.15);color:#A16207}
.status-closed,.status-cancelled{background:rgba(0,0,0,0.07);color:var(--muted)}
.status-pending{background:rgba(245,166,35,.12);color:var(--brand-dark)}

/* Tags */
.gg-tag,.gg-tag-gender,.gg-tag-age{
  font-size:.7rem;background:rgba(0,0,0,0.04);border:1px solid var(--border);
  border-radius:var(--rb);padding:3px 9px;color:var(--muted);
}

/* Empty state */
.gg-empty{text-align:center;padding:48px 24px;color:var(--muted)}
.gg-empty-ico{font-size:2.8rem;margin-bottom:12px}
.gg-empty-title{font-family:'Nunito Sans','Prompt',sans-serif;font-weight:700;font-size:.95rem;color:var(--ink);margin-bottom:6px}
.gg-empty-sub{font-size:.82rem;line-height:1.6}
.gg-empty-small{font-size:.8rem;color:var(--muted);text-align:center;padding:16px}

/* ── CREATE PAGE ─────────────────────────────────────────────────────────── */
.gg-create-page{display:flex;flex-direction:column;height:100%;min-height:100dvh;background:var(--bg)}
.gg-create-page.gg-create-single{overflow-y:auto}
.gg-create-page.gg-create-embedded{
  display:block;
  height:auto;
  min-height:0;
  background:transparent;
}
.gg-create-page.gg-create-embedded .gg-create-header{display:none}
.gg-create-header{
  flex-shrink:0;display:grid;grid-template-columns:44px minmax(0,1fr) auto;align-items:center;column-gap:10px;
  padding:10px 16px;background:#fff;border-bottom:1px solid var(--border);
}
.gg-create-title{font-family:'Nunito Sans','Prompt',sans-serif;font-weight:700;font-size:1rem;color:var(--ink)}
.gg-create-progress{flex-shrink:0;padding:12px 16px 8px;background:#fff;border-bottom:1px solid var(--border)}
.gg-create-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:0}
.gg-create-footer{
  flex-shrink:0;padding:12px 16px;background:#fff;border-top:1px solid var(--border);
  display:flex;gap:10px;padding-bottom:calc(12px + env(safe-area-inset-bottom));
}

/* ── DETAIL PAGE ─────────────────────────────────────────────────────────── */
.gg-detail-page{display:flex;flex-direction:column;height:100dvh;background:var(--bg)}
.gg-detail-header{
  flex-shrink:0;display:flex;align-items:center;gap:10px;
  padding:0 12px;padding-top:env(safe-area-inset-top);
  height:calc(54px + env(safe-area-inset-top));
  background:#fff;border-bottom:1px solid var(--border);
  box-shadow:0 1px 0 rgba(0,0,0,0.06);
}
.gg-back-btn{background:none;border:none;color:var(--ink);padding:6px;flex-shrink:0;display:flex;align-items:center}
.gg-detail-header-center{flex:1;min-width:0;text-align:center}
.gg-detail-header-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}
.gg-hdr-icon-btn{background:none;border:none;color:var(--muted);padding:6px;display:flex;align-items:center;border-radius:8px;transition:background .15s}
.gg-hdr-icon-btn:active{background:var(--brand-dim)}
.gg-hdr-icon-btn-warn:active{background:rgba(193,53,21,.08);color:var(--err)}
.gg-detail-title{font-family:'Nunito Sans','Prompt',sans-serif;font-weight:700;font-size:.95rem;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gg-detail-tab-bar{flex-shrink:0;display:flex;border-bottom:1px solid var(--border);background:#fff}
.gg-detail-tab{
  flex:1;padding:13px 0;background:none;border:none;
  border-bottom:2px solid transparent;color:var(--muted);
  font-size:.85rem;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px;
}
.gg-detail-tab.on{color:var(--brand-dark);border-bottom-color:var(--brand);font-weight:600}
.gg-chat-lock-ico{font-size:.8rem}
.gg-detail-info-panel{flex:1;overflow-y:auto;padding:16px 14px;padding-bottom:80px}
.gg-detail-section{
  background:#fff;border-radius:var(--r);padding:16px;margin-bottom:12px;
  box-shadow:var(--shadow-card);
}
.gg-detail-section-title{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px;font-weight:600}
.gg-detail-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px}
.gg-detail-row:last-child{margin-bottom:0}
.gg-detail-ico{font-size:1rem;flex-shrink:0;width:22px;text-align:center;margin-top:1px}
.gg-detail-label{font-size:.7rem;color:var(--muted);margin-bottom:2px}
.gg-detail-val{font-size:.9rem;color:var(--ink);line-height:1.4}
.gg-detail-sub{font-size:.75rem;color:var(--muted);margin-top:2px}
.gg-maps-link{display:inline-flex;align-items:center;gap:4px;color:var(--brand-dark);font-size:.78rem;margin-top:3px;font-weight:500}

/* Members */
.gg-member-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.gg-member-row:last-child{border-bottom:none}
.gg-member-info{flex:1;min-width:0}
.gg-member-name{font-size:.88rem;font-weight:600;color:var(--ink)}
.gg-member-sub{font-size:.72rem;color:var(--muted)}
.gg-creator-badge{font-size:.9rem;flex-shrink:0}
.gg-avatar-md{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0}
.gg-avatar-sm{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}
.gg-avatar-fallback{background:var(--brand-dim);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;color:var(--brand-dark)}

/* Pending/approve/reject */
.gg-pending-row{background:rgba(245,166,35,.05);border:1px solid rgba(245,166,35,.2);border-radius:var(--rs);padding:10px;display:flex;align-items:center;gap:8px}
.gg-pending-label{color:var(--brand-dark);font-size:.75rem;font-weight:600}
.gg-pending-count{background:var(--brand);color:#fff;border-radius:10px;font-size:.68rem;font-weight:700;padding:1px 7px;margin-left:4px}
.gg-pending-actions{display:flex;gap:7px;flex-shrink:0}
.gg-approve-btn{background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.35);color:#15803D;border-radius:var(--rs);padding:6px 12px;font-size:.78rem;font-weight:600}
.gg-reject-btn{background:rgba(193,53,21,.08);border:1px solid rgba(193,53,21,.25);color:var(--err);border-radius:var(--rs);padding:6px 12px;font-size:.78rem;font-weight:600}
.gg-kick-btn{background:rgba(193,53,21,.07);border:1px solid rgba(193,53,21,.2);color:var(--err);border-radius:var(--rs);padding:5px 10px;font-size:.74rem;margin-left:auto}

/* Detail footer */
.gg-detail-footer{
  flex-shrink:0;padding:12px 14px;padding-bottom:calc(12px + env(safe-area-inset-bottom));
  border-top:1px solid var(--border);background:#fff;display:flex;gap:10px;
  box-shadow:0 -1px 0 rgba(0,0,0,0.06);
}
.gg-footer-note{text-align:center;font-size:.8rem;color:var(--muted);width:100%;padding:4px 0}
.gg-footer-note-warn{color:var(--err);font-weight:600}

/* ── CHAT PANEL ──────────────────────────────────────────────────────────── */
.gg-chat-panel{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;position:relative}
.gg-new-msg-pill{position:absolute;bottom:68px;left:50%;transform:translateX(-50%);background:var(--brand);color:#222;padding:7px 20px;border-radius:20px;font-size:.8rem;font-weight:700;cursor:pointer;box-shadow:0 2px 10px rgba(0,0,0,.2);z-index:10;white-space:nowrap;border:none}
.gg-chat-disclaimer{flex-shrink:0;background:rgba(245,166,35,.07);border-bottom:1px solid rgba(245,166,35,.15);padding:8px 14px;font-size:.72rem;color:var(--brand-dark);line-height:1.5}
.gg-chat-messages{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px;overscroll-behavior:contain;background:var(--bg)}
.gg-chat-row{display:flex;gap:8px;align-items:flex-end}
.gg-chat-row-mine{flex-direction:row-reverse}
.gg-chat-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0}
.gg-chat-bubble-wrap{display:flex;flex-direction:column;max-width:72%;gap:2px}
.gg-chat-row-mine .gg-chat-bubble-wrap{align-items:flex-end}
.gg-chat-sender{font-size:.68rem;color:var(--muted);padding:0 6px}
.gg-chat-bubble{background:#fff;border-radius:16px;padding:9px 13px;font-size:.85rem;line-height:1.5;word-break:break-word;color:var(--ink);box-shadow:0 1px 3px rgba(0,0,0,0.08)}
.gg-bubble-mine{background:var(--brand);color:#222222;box-shadow:0 2px 8px rgba(245,166,35,.3)}
.gg-bubble-other{background:#fff}
.gg-chat-time{font-size:.64rem;color:var(--muted);padding:0 6px}
.gg-chat-time-out{font-size:.64rem;color:var(--muted);align-self:flex-end;white-space:nowrap;padding-bottom:2px;flex-shrink:0}
.gg-chat-bubble-row{display:flex;align-items:flex-end;gap:4px}
.gg-chat-day-sep{text-align:center;font-size:.7rem;color:var(--muted);padding:8px 0;position:relative}
.gg-chat-day-sep::before{content:'';position:absolute;left:0;right:0;top:50%;height:1px;background:var(--border)}
.gg-chat-day-sep span{background:var(--bg);padding:0 10px;position:relative}
.gg-chat-sys-msg{text-align:center;font-size:.74rem;color:var(--muted);padding:6px 16px;margin:2px 0}
.gg-chat-locked{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--muted);text-align:center;padding:32px}
.gg-chat-locked-ico{font-size:2.4rem}
.gg-chat-locked-title{font-family:'Nunito Sans','Prompt',sans-serif;font-weight:700;font-size:.9rem;color:var(--ink)}
.gg-chat-locked-sub{font-size:.78rem;line-height:1.6}
.gg-chat-input-row{flex-shrink:0;display:flex;align-items:flex-end;gap:8px;padding:10px 12px;padding-bottom:calc(10px + env(safe-area-inset-bottom));border-top:1px solid var(--border);background:#fff}
.gg-chat-closed-bar{flex:1;text-align:center;font-size:.82rem;color:var(--muted);padding:10px 0;font-weight:600}
.gg-chat-input{flex:1;background:var(--bg);border:1.5px solid var(--border);border-radius:20px;color:var(--ink);padding:9px 16px;font-size:.88rem;font-family:'Sarabun',sans-serif;outline:none;transition:border-color .2s;resize:none;overflow-y:auto;min-height:38px;max-height:120px;line-height:1.4;display:block}
.gg-chat-input:focus{border-color:var(--brand)}
.gg-chat-input::placeholder{color:var(--muted)}
.gg-chat-send-btn{background:var(--brand);border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;transition:background .2s}
.gg-chat-send-btn:hover{background:var(--brand-dark)}

/* ── BUTTONS ─────────────────────────────────────────────────────────────── */
.gg-btn-primary{
  flex:1;background:var(--brand);color:#222222;border:none;
  padding:13px;border-radius:var(--rs);
  font-family:'Nunito Sans','Prompt',sans-serif;font-weight:700;font-size:.92rem;
  box-shadow:0 2px 10px rgba(245,166,35,.3);transition:all .2s;
}
.gg-btn-primary:hover{background:var(--brand-dark);color:#fff}
.gg-btn-primary:disabled{opacity:.45;pointer-events:none}
.gg-btn-ghost{
  background:#fff;border:1.5px solid var(--border);color:var(--ink);
  padding:12px 18px;border-radius:var(--rs);font-size:.88rem;transition:all .2s;
}
.gg-btn-ghost:hover{border-color:var(--ink);background:var(--bg)}
.gg-btn-danger{background:rgba(193,53,21,.08);border:1px solid rgba(193,53,21,.25);color:var(--err);padding:12px;border-radius:var(--rs);font-size:.9rem;font-weight:700;width:100%}
.gg-btn-danger-solid{background:var(--err);color:#fff;border:none;padding:12px 20px;border-radius:var(--rs);font-weight:700;font-size:.9rem}
.gg-btn-pending{flex:1;background:var(--brand-dim);border:1px solid var(--brand-glow);color:var(--brand-dark);padding:13px;border-radius:var(--rs);font-size:.9rem;font-weight:700}

/* ── SERVICE TYPE PICKER ─────────────────────────────────────────────────── */
.gg-svc-pick{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.gg-svc-pick-btn{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  background:#fff;border:1.5px solid var(--border);
  border-radius:var(--rb);padding:12px 6px;cursor:pointer;transition:all .2s;
  box-shadow:0 1px 4px rgba(0,0,0,0.06);
}
.gg-svc-pick-btn.on{border-color:var(--brand);background:var(--brand-dim);box-shadow:0 2px 8px rgba(245,166,35,.22)}
.gg-svc-pick-btn.on .gg-svc-pick-lbl{color:var(--brand-dark);font-weight:700}
.gg-svc-pick-ico{font-size:1.6rem;line-height:1}
.gg-svc-pick-lbl{font-size:.72rem;color:var(--muted);text-align:center;line-height:1.3}

/* ── PAX STEPPER ─────────────────────────────────────────────────────────── */
.gg-pax-row{display:flex;align-items:center;gap:0;background:#f7f7f7;border:1.5px solid var(--border);border-radius:var(--rs);overflow:hidden;width:fit-content}
.gg-pax-btn{width:48px;height:48px;background:none;border:none;font-size:1.4rem;color:var(--ink);font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}
.gg-pax-btn:active{background:var(--brand-dim)}
.gg-pax-display{min-width:72px;text-align:center;font-size:1.15rem;font-weight:700;color:var(--ink)}
.gg-pax-unit{font-size:.8rem;font-weight:400;color:var(--muted)}

/* ── LOCATION SEARCH ──────────────────────────────────────────────────────── */
.gg-loc-input-row{display:flex;gap:8px;align-items:center}
.gg-loc-input{flex:1;min-width:0}
.gg-loc-gps-btn{
  flex-shrink:0;width:44px;height:44px;border-radius:var(--rs);
  background:#fff;border:1.5px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);cursor:pointer;transition:all .15s;
}
.gg-loc-gps-btn:hover{border-color:var(--brand);color:var(--brand)}
.gg-loc-gps-loading{opacity:.5;pointer-events:none;animation:spin .8s linear infinite}
.gg-loc-hint{font-size:.72rem;color:var(--muted);margin-top:5px}
.gg-loc-results{
  border:1.5px solid var(--border);border-radius:var(--rs);
  background:#fff;margin-top:6px;overflow:hidden;
  box-shadow:0 4px 16px rgba(0,0,0,.10);
}
.gg-loc-result-item{
  display:flex;align-items:center;gap:10px;
  padding:11px 12px;cursor:pointer;transition:background .12s;
  border-bottom:1px solid var(--border);
}
.gg-loc-result-item:last-child{border-bottom:none}
.gg-loc-result-item:active{background:var(--brand-dim)}
.gg-loc-result-ico{font-size:1.1rem;flex-shrink:0}
.gg-loc-result-name{font-size:.88rem;font-weight:600;color:var(--ink);line-height:1.3}
.gg-loc-result-sub{font-size:.74rem;color:var(--muted);margin-top:2px;line-height:1.3}
.gg-loc-status{padding:14px 12px;font-size:.82rem;color:var(--muted);text-align:center}
.gg-loc-selected{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  background:var(--brand-dim);border:1.5px solid var(--brand);
  border-radius:var(--rs);padding:12px 14px;margin-bottom:2px;
}
.gg-loc-sel-inner{display:flex;align-items:center;gap:10px;flex:1;min-width:0}
.gg-loc-sel-ico{font-size:1.3rem;flex-shrink:0}
.gg-loc-sel-name{font-size:.9rem;font-weight:700;color:var(--brand-dark);line-height:1.3}
.gg-loc-sel-sub{font-size:.74rem;color:var(--muted);margin-top:2px}
.gg-loc-clear{
  flex-shrink:0;background:none;border:1px solid var(--border);
  border-radius:20px;padding:4px 10px;font-size:.72rem;color:var(--muted);
  white-space:nowrap;cursor:pointer;
}
.gg-loc-clear:active{background:rgba(0,0,0,.06)}

/* ── JOIN MODE TOGGLE ────────────────────────────────────────────────────── */
.gg-join-mode-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.gg-join-mode-btn{
  display:flex;flex-direction:column;align-items:center;gap:5px;padding:12px 8px;
  background:#fff;border:1.5px solid var(--border);border-radius:var(--rb);
  transition:border-color .15s,background .15s;
}
.gg-join-mode-btn.on{border-color:var(--brand);background:var(--brand-dim)}
.gg-join-mode-btn.on .gg-join-mode-lbl{color:var(--brand-dark);font-weight:700}
.gg-join-mode-ico{font-size:1.5rem;line-height:1}
.gg-join-mode-lbl{font-size:.78rem;color:var(--muted)}

/* ── MODALS ──────────────────────────────────────────────────────────────── */
.gg-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:90;display:flex;align-items:flex-end;justify-content:center;backdrop-filter:blur(2px)}
.gg-modal-sheet{background:#fff;border-radius:24px 24px 0 0;width:100%;max-width:520px;max-height:92dvh;display:flex;flex-direction:column;overflow:hidden;padding-bottom:env(safe-area-inset-bottom)}
.gg-modal-handle{width:40px;height:4px;background:rgba(0,0,0,0.12);border-radius:2px;margin:12px auto;flex-shrink:0}
.gg-modal-header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 16px 14px;border-bottom:1px solid var(--border)}
.gg-modal-title{font-family:'Nunito Sans','Prompt',sans-serif;font-weight:700;font-size:1rem;color:var(--ink)}
.gg-modal-close{background:none;border:none;color:var(--muted);font-size:1.2rem;padding:4px;line-height:1}
.gg-modal-scroll-body{flex:1;overflow-y:auto;padding:16px}
.gg-modal-footer{flex-shrink:0;padding:12px 16px;border-top:1px solid var(--border);display:flex;gap:10px}
.gg-modal-step{padding:16px;flex:1;overflow-y:auto}

/* Step progress */
.gg-step-indicator{font-size:.75rem;color:var(--muted);font-weight:500}
.gg-step-progress{padding:12px 16px;flex-shrink:0}
.gg-sp-track{display:flex;align-items:center;margin-bottom:5px}
.gg-sp-dot{width:10px;height:10px;border-radius:50%;background:#e0e0e0;flex-shrink:0;transition:background .3s}
.gg-sp-dot.active{background:var(--brand)}
.gg-sp-dot.done{background:var(--brand-dark)}
.gg-sp-line{flex:1;height:2px;background:#e0e0e0}
.gg-sp-labels{display:flex;justify-content:space-between;font-size:.64rem;color:var(--muted)}
.gg-step-title{font-family:'Nunito Sans','Prompt',sans-serif;font-weight:700;font-size:1rem;color:var(--ink);margin-bottom:16px}

/* Forms */
.gg-form-group{margin-bottom:14px}
.gg-form-label{font-size:.8rem;color:var(--ink);font-weight:600;display:block;margin-bottom:7px}
.gg-form-optional{font-size:.72rem;color:var(--muted);font-weight:400}
.gg-form-input{
  width:100%;background:#fff;border:1.5px solid var(--border);
  border-radius:var(--rs);color:var(--ink);padding:11px 13px;
  font-family:'Sarabun',sans-serif;font-size:.9rem;outline:none;
  transition:border-color .2s,box-shadow .2s;
}
.gg-form-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(245,166,35,.12)}
.gg-form-input::placeholder{color:rgba(0,0,0,0.28)}
.gg-form-textarea{resize:none;min-height:80px}
.gg-form-hint{font-size:.72rem;color:var(--muted);margin-top:5px}
.gg-form-err{color:var(--err);font-size:.78rem;min-height:18px;margin-top:4px}
.gg-radio-row{display:flex;gap:14px;flex-wrap:wrap}
.gg-radio-opt{display:flex;align-items:center;gap:7px;font-size:.85rem;cursor:pointer;color:var(--ink)}
.gg-radio-opt input{accent-color:var(--brand)}

/* ── POINTS MODAL ────────────────────────────────────────────────────────── */
.gg-points-balance-card{text-align:center;background:var(--brand-dim);border:1px solid var(--brand-glow);border-radius:var(--r);padding:24px;margin-bottom:16px}
.gg-points-balance-label{font-size:.78rem;color:var(--muted);margin-bottom:8px}
.gg-points-balance-val{font-family:'Nunito Sans','Prompt',sans-serif;font-weight:800;font-size:2.5rem;color:var(--brand-dark)}
.gg-points-balance-sub{font-size:.74rem;color:var(--muted);margin-top:4px}
.gg-points-tx-title{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px;font-weight:600}
.gg-points-tx-list{display:flex;flex-direction:column;gap:0}
.gg-tx-row{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--border)}
.gg-tx-left{flex:1;min-width:0}
.gg-tx-desc{font-size:.85rem;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gg-tx-date{font-size:.7rem;color:var(--muted);margin-top:2px}
.gg-tx-amount{font-size:.88rem;font-weight:700;flex-shrink:0;margin-left:12px}
.tx-positive{color:#15803D}
.tx-negative{color:var(--err)}

/* ── NOTIFICATIONS ───────────────────────────────────────────────────────── */
.gg-notifs-list{display:flex;flex-direction:column;gap:10px;padding:8px 14px 80px}
.gg-notif-card{
  background:#fff;border-radius:var(--r);padding:14px;
  display:flex;align-items:flex-start;gap:10px;cursor:pointer;position:relative;
  box-shadow:var(--shadow-card);transition:box-shadow .2s;
}
.gg-notif-card:hover{box-shadow:var(--shadow-hover)}
.gg-notif-unread{border-left:3px solid var(--brand)}
.gg-notif-ico{font-size:1.3rem;flex-shrink:0;width:28px;text-align:center}
.gg-notif-body{flex:1;min-width:0}
.gg-notif-msg{font-size:.85rem;color:var(--ink);line-height:1.5}
.gg-notif-time{font-size:.7rem;color:var(--muted);margin-top:3px}
.gg-notif-dot{position:absolute;top:14px;right:14px;width:8px;height:8px;background:var(--brand);border-radius:50%}

/* ── PROFILE ─────────────────────────────────────────────────────────────── */
.gg-profile-content{padding:20px 14px 80px}
.gg-profile-hero{text-align:center;padding:28px 0 20px;border-bottom:1px solid var(--border);margin-bottom:20px}
.gg-profile-avatar{width:76px;height:76px;border-radius:50%;object-fit:cover;border:3px solid var(--brand);margin-bottom:12px}
.gg-profile-name{font-family:'Nunito Sans','Prompt',sans-serif;font-weight:700;font-size:1.1rem;color:var(--ink);margin-bottom:4px}
.gg-profile-points{font-size:.85rem;color:var(--brand-dark);font-weight:600}
.gg-profile-actions{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.gg-profile-settings{margin-bottom:16px}
.gg-setting-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}
.gg-setting-label{font-size:.88rem;color:var(--ink)}
.gg-profile-footer{text-align:center;padding-top:16px;border-top:1px solid var(--border)}
.gg-profile-footer-note{font-size:.74rem;color:var(--muted);margin-bottom:12px}
.gg-btn-logout{background:none;border:1px solid var(--err);color:var(--err);border-radius:var(--rb);padding:8px 24px;font-size:.85rem;cursor:pointer;font-family:'Sarabun',sans-serif}
.gg-btn-logout:active{opacity:.7}

/* ── CHAT TERMS MODAL ────────────────────────────────────────────────────── */
.gg-terms-icon{text-align:center;font-size:2.6rem;margin-bottom:12px}
.gg-terms-intro{font-size:.85rem;color:var(--muted);line-height:1.7;margin-bottom:16px}
.gg-terms-list{list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:20px}
.gg-terms-list li{font-size:.82rem;line-height:1.6;padding-left:20px;position:relative;color:var(--ink)}
.gg-terms-list li::before{content:'•';color:var(--brand-dark);position:absolute;left:4px;font-weight:700}
.gg-terms-cb-wrap{display:flex;align-items:flex-start;gap:10px;cursor:pointer;background:var(--brand-dim);border:1px solid var(--brand-glow);border-radius:var(--rs);padding:12px}
.gg-terms-cb-label{font-size:.82rem;color:var(--ink);line-height:1.6;cursor:pointer}

/* ── REPORT MODAL ────────────────────────────────────────────────────────── */
.gg-report-intro{font-size:.85rem;color:var(--muted);margin-bottom:14px;line-height:1.6}
.gg-report-reasons{display:flex;flex-direction:column;gap:8px}
.gg-report-reason{display:flex;align-items:center;gap:10px;background:#fff;border:1.5px solid var(--border);border-radius:var(--rs);padding:12px;cursor:pointer;font-size:.85rem;color:var(--ink);transition:border-color .2s}
.gg-report-reason:has(input:checked){border-color:var(--brand);background:var(--brand-dim)}
.gg-report-reason input[type=radio]{accent-color:var(--brand)}

/* ── TOAST ───────────────────────────────────────────────────────────────── */
.gg-toast{
  position:fixed;bottom:calc(84px + env(safe-area-inset-bottom));
  left:50%;transform:translateX(-50%) translateY(10px);
  background:#222222;color:#fff;
  padding:11px 20px;border-radius:var(--rb);font-size:.85rem;
  opacity:0;pointer-events:none;transition:all .25s;z-index:200;
  white-space:nowrap;box-shadow:0 4px 20px rgba(0,0,0,.25);
  max-width:calc(100vw - 40px);font-family:'Sarabun',sans-serif;
}
.gg-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.gg-toast-ok{background:#15803D}
.gg-toast-err{background:var(--err)}
.gg-toast-warn{background:var(--brand-dark);color:#fff}

/* inline button inside error messages */
.gg-err-link{background:none;border:1px solid currentColor;border-radius:6px;padding:2px 8px;font-size:.8rem;cursor:pointer;color:inherit;vertical-align:middle;margin-left:4px}
.gg-err-link:hover{background:rgba(0,0,0,.05)}

/* ── PREVIEW PAGE ────────────────────────────────────────────────────────── */
.gg-preview-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:#f7f8fa;padding:24px 16px}
.gg-preview-wrap{width:100%;max-width:400px;display:flex;flex-direction:column;gap:18px}
.gg-preview-logo{font-family:'Prompt',sans-serif;font-size:1.4rem;font-weight:800;color:#222;letter-spacing:-.5px}
.gg-preview-logo span{color:var(--brand)}
.gg-preview-invite{font-size:.9rem;color:var(--muted);font-weight:500}
.gg-preview-card{background:#fff;border-radius:18px;padding:20px;display:flex;flex-direction:column;gap:12px;box-shadow:0 2px 16px rgba(0,0,0,.08)}
.gg-prev-svc{font-size:1rem;font-weight:700;color:#222}
.gg-prev-row{display:flex;align-items:flex-start;gap:8px;font-size:.9rem;color:#333}
.gg-prev-ico{width:20px;flex-shrink:0;text-align:center}
.gg-prev-note{font-size:.82rem;color:var(--muted);background:var(--brand-dim);border-radius:8px;padding:8px 10px;line-height:1.5}
.gg-prev-creator{display:flex;align-items:center;gap:8px;padding-top:4px;border-top:1px solid #f0f0f0;font-size:.82rem;color:var(--muted)}
.gg-prev-av{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0}
.gg-prev-av-fb{background:var(--brand-dim);color:var(--brand);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}
.gg-preview-cta{display:flex;flex-direction:column;gap:8px}

/* ── ANIMATIONS ──────────────────────────────────────────────────────────── */
.slide-in{animation:slideIn .25s ease}
@keyframes slideIn{from{transform:translateX(100%)}to{transform:translateX(0)}}

/* ── GOGANG INDEX REFRESH (mobile + desktop) ───────────────────────────── */
body::before{
  content:'';
  position:fixed;
  inset:0;
  z-index:-1;
  background:
    radial-gradient(circle at 10% -20%, rgba(247,178,57,.23), transparent 42%),
    radial-gradient(circle at 100% 0%, rgba(89,117,255,.16), transparent 38%),
    linear-gradient(180deg, #f9fbff 0%, #f4f7ff 52%, #eef3ff 100%);
}

.gg-login-right{
  background:transparent;
}

.gg-login-card,
.gg-preview-card{
  border:1px solid rgba(18,35,61,.08);
  background:rgba(255,255,255,.92);
  box-shadow:0 22px 60px rgba(18,35,61,.14);
  backdrop-filter:blur(8px);
}

.gg-login-card{
  border-radius:30px;
  padding:26px 22px;
}

.gg-topbar{
  height:calc(62px + env(safe-area-inset-top));
  padding:0 12px;
  padding-top:env(safe-area-inset-top);
  background:rgba(255,255,255,.88);
  border-bottom:1px solid rgba(18,35,61,.08);
  backdrop-filter:blur(12px);
}

.gg-topbar-logo{
  font-size:1.2rem;
}

.gg-search-input-wrap{
  background:#fff;
  border:1px solid rgba(18,35,61,.12);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}

.gg-filter-btn{
  background:#fff;
  border:1px solid rgba(18,35,61,.14);
  box-shadow:0 4px 12px rgba(18,35,61,.08);
}

.gg-points-pill{
  padding:7px 12px;
  font-size:.8rem;
  border:1px solid rgba(247,178,57,.35);
  background:linear-gradient(180deg, rgba(247,178,57,.18), rgba(247,178,57,.1));
}

.gg-content{
  padding-bottom:12px;
}

.gg-cat-grid{
  margin:12px 12px 0;
  border:1px solid rgba(18,35,61,.08);
  border-radius:20px;
  padding:14px 10px;
  background:rgba(255,255,255,.94);
  box-shadow:0 10px 24px rgba(18,35,61,.08);
}

.gg-feed-header{
  padding:16px 18px 8px;
}

.gg-feed-title{
  font-size:1rem;
}

.gg-rooms-list{
  gap:14px;
  padding:6px 12px 12px;
}

.gg-room-card{
  border:1px solid rgba(18,35,61,.08);
  border-radius:22px;
}

.gg-card-inner{
  gap:12px;
}

.gg-card-av-lg{
  width:52px;
  height:52px;
}

.gg-bottom-nav{
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(12px);
  border-top:1px solid rgba(18,35,61,.08);
  height:66px;
}

.gg-nav-item{
  font-size:.67rem;
}

.gg-nav-create{
  width:62px;
  height:62px;
  top:-20px;
}

@media (min-width:768px){
  .gg-app-shell{
    display:grid;
    grid-template-columns:280px minmax(0,1fr);
    grid-template-areas:
      "nav topbar"
      "nav content";
  }

  .gg-topbar{
    grid-area:topbar;
    padding:0 24px;
    padding-top:0;
    height:74px;
    position:sticky;
    top:0;
  }

  .gg-content{
    grid-area:content;
    padding:20px 22px 26px;
    overflow-y:auto;
  }

  .gg-view{
    max-width:1120px;
    width:100%;
    margin:0 auto;
  }

  .gg-bottom-nav{
    grid-area:nav;
    height:100dvh;
    padding:18px 12px 20px;
    padding-bottom:20px;
    border-top:none;
    border-right:1px solid rgba(18,35,61,.08);
    display:grid;
    grid-template-columns:1fr;
    grid-template-rows:auto auto auto auto auto;
    gap:8px;
    align-content:start;
    background:linear-gradient(180deg, #fff 0%, #f7faff 100%);
    box-shadow:8px 0 30px rgba(18,35,61,.08);
  }

  .gg-nav-item{
    flex:none;
    border:1px solid transparent;
    border-radius:14px;
    min-height:58px;
    flex-direction:row;
    justify-content:flex-start;
    padding:10px 12px;
    gap:10px;
    font-size:.82rem;
    background:transparent;
  }

  .gg-nav-item.on{
    background:rgba(247,178,57,.12);
    border-color:rgba(247,178,57,.42);
    color:var(--brand-dark);
  }

  .gg-nav-label{
    font-size:.84rem;
    font-weight:700;
  }

  .gg-nav-create-slot{
    width:100%;
    min-height:66px;
    order:3;
  }

  .gg-nav-create{
    position:static;
    width:100%;
    height:52px;
    border-radius:14px;
    box-shadow:0 8px 18px rgba(247,178,57,.34);
  }

  .gg-nav-create:hover{
    transform:translateY(-1px);
  }

  .gg-cat-grid{
    margin:0 0 4px;
    grid-template-columns:repeat(8, minmax(0,1fr));
    padding:16px;
  }

  .gg-card-grid,
  .gg-rooms-list{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:14px;
    padding:6px 0 12px;
  }

  .gg-load-more-wrap{
    padding-bottom:10px;
  }
}

@media (min-width:1200px){
  .gg-card-grid,
  .gg-rooms-list{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}

/* ── GOGANG V3 FULL EXPERIENCE REFRESH ──────────────────────────────────── */
:root{
  --gg-grad-a:#fff9ee;
  --gg-grad-b:#eef4ff;
  --gg-surface:#ffffff;
  --gg-surface-soft:#f8faff;
  --gg-line:rgba(25,48,88,.11);
  --gg-primary:#f7b239;
  --gg-primary-ink:#9b5c00;
  --gg-title:#152033;
  --gg-body:#455269;
}

body{
  color:var(--gg-body);
}

.gg-page{
  background:transparent;
}

.gg-loading{
  background:linear-gradient(145deg,var(--gg-grad-a),var(--gg-grad-b));
}

.gg-loading-logo{
  color:var(--gg-primary);
}

.gg-login-page{
  background:linear-gradient(180deg,var(--gg-grad-a),var(--gg-grad-b));
}

.gg-login-left{
  background:
    radial-gradient(circle at 10% 10%, rgba(247,178,57,.28), transparent 45%),
    radial-gradient(circle at 100% 100%, rgba(122,162,255,.24), transparent 40%),
    linear-gradient(160deg,#111a2a,#1f2b40 55%,#1b2538);
}

.gg-ll-sub{
  color:rgba(255,255,255,.78);
}

.gg-login-card{
  background:rgba(255,255,255,.95);
  border:1px solid var(--gg-line);
  border-radius:28px;
  box-shadow:0 24px 60px rgba(17,31,57,.16);
}

.gg-lc-title,
.gg-view-header,
.gg-empty-title,
.gg-create-title,
.gg-detail-title,
.gg-modal-title,
.gg-profile-name{
  color:var(--gg-title);
}

.gg-lc-sub,
.gg-login-note,
.gg-feed-count,
.gg-empty-sub,
.gg-empty-small,
.gg-notif-time,
.gg-profile-footer-note,
.gg-form-hint,
.gg-detail-sub{
  color:var(--gg-body);
}

.gg-line-login-btn{
  border-radius:14px;
}

.gg-app-shell{
  background:transparent;
}

.gg-topbar{
  border-bottom:1px solid var(--gg-line);
  box-shadow:0 4px 18px rgba(20,35,62,.08);
}

.gg-topbar-logo{
  color:var(--gg-primary);
}

.gg-topbar-logo span{
  color:var(--gg-title);
}

.gg-search-input{
  color:var(--gg-title);
}

.gg-search-input::placeholder{
  color:#7a869c;
}

.gg-filter-btn,
.gg-points-pill,
.gg-card-share-btn{
  border:1px solid var(--gg-line);
}

.gg-content{
  background:transparent;
}

.gg-cat-grid,
.gg-room-card,
.gg-notif-card,
.gg-detail-section,
.gg-modal-sheet,
.gg-preview-card{
  background:var(--gg-surface);
  border:1px solid var(--gg-line);
  box-shadow:0 12px 28px rgba(22,37,64,.1);
}

.gg-cat-item-ico{
  background:var(--gg-surface-soft);
  border:1px solid var(--gg-line);
}

.gg-cat-item-lbl{
  color:#57647b;
}

.gg-feed-title{
  color:var(--gg-title);
}

.gg-card-head{
  padding-top:12px;
}

.gg-card-inner{
  padding-top:12px;
  padding-bottom:12px;
}

.gg-loc-val,
.gg-meta-val,
.gg-notif-msg,
.gg-setting-label,
.gg-form-label,
.gg-detail-val{
  color:var(--gg-title);
}

.gg-meta-label,
.gg-detail-label{
  color:#7a869c;
}

.gg-bottom-nav{
  border-top:1px solid var(--gg-line);
}

.gg-nav-item{
  color:#6c7890;
}

.gg-nav-item.on{
  color:var(--gg-primary-ink);
}

.gg-nav-create{
  background:linear-gradient(145deg,#f7b239,#f5a827);
  color:#1f1f1f;
}

.gg-create-page,
.gg-detail-page{
  background:transparent;
}

.gg-create-header,
.gg-create-progress,
.gg-create-footer,
.gg-detail-header,
.gg-detail-tab-bar,
.gg-detail-footer,
.gg-chat-input-row{
  background:rgba(255,255,255,.92);
  border-color:var(--gg-line);
  backdrop-filter:blur(10px);
}

.gg-create-body,
.gg-detail-info-panel,
.gg-chat-messages{
  background:transparent;
}

.gg-form-input,
.gg-join-mode-btn,
.gg-svc-pick-btn,
.gg-loc-results,
.gg-loc-result-item,
.gg-loc-sel-inner{
  border-color:var(--gg-line);
}

.gg-form-input,
.gg-loc-result-item,
.gg-chat-input{
  color:var(--gg-title);
}

.gg-btn-primary{
  background:linear-gradient(145deg,#f7b239,#f3a623);
  color:#1f1f1f;
  box-shadow:0 10px 20px rgba(247,178,57,.34);
}

.gg-btn-primary:hover{
  background:linear-gradient(145deg,#f0a72f,#ec9d18);
  color:#111;
}

.gg-btn-ghost{
  background:#fff;
  border-color:var(--gg-line);
}

.gg-modal-overlay{
  background:rgba(17,28,47,.45);
  backdrop-filter:blur(5px);
}

.gg-modal-sheet{
  border-radius:26px 26px 0 0;
}

.gg-chat-bubble{
  border:1px solid var(--gg-line);
}

.gg-bubble-mine{
  background:linear-gradient(145deg,#ffd171,#f7b239);
  color:#1d1d1d;
  border-color:rgba(247,178,57,.4);
}

.gg-bubble-other{
  background:#fff;
}

.gg-notif-unread{
  border-left:4px solid var(--gg-primary);
}

.gg-profile-content{
  max-width:980px;
  margin:0 auto;
}

.gg-profile-hero{
  background:rgba(255,255,255,.8);
  border:1px solid var(--gg-line);
  border-radius:24px;
  padding:30px 20px;
  margin-bottom:14px;
}

.gg-profile-settings,
.gg-profile-footer{
  background:#fff;
  border:1px solid var(--gg-line);
  border-radius:20px;
  padding:0 16px;
}

.gg-profile-footer{
  padding:16px;
}

.gg-btn-logout{
  border-color:#d9493f;
}

@media (max-width:767px){
  .gg-topbar{
    position:sticky;
    top:0;
  }

  .gg-view-header{
    padding:18px 16px 10px;
  }

  .gg-detail-info-panel{
    padding-bottom:96px;
  }
}

@media (min-width:768px){
  .gg-login-card{
    max-width:440px;
    padding:30px 28px;
  }

  .gg-feed-header{
    padding-left:4px;
    padding-right:4px;
  }

  #ggViewFeed .gg-cat-grid{
    margin-bottom:8px;
  }

  .gg-notifs-list,
  .gg-profile-content{
    padding-left:0;
    padding-right:0;
  }

  .gg-detail-page,
  .gg-create-page{
    max-width:1100px;
    margin:0 auto;
    border-left:1px solid var(--gg-line);
    border-right:1px solid var(--gg-line);
    box-shadow:0 10px 30px rgba(20,36,62,.08);
  }

  .gg-detail-header,
  .gg-create-header{
    padding-left:20px;
    padding-right:20px;
  }

  .gg-create-body{
    padding:20px;
  }

  .gg-detail-info-panel{
    padding:20px;
  }

  .gg-chat-messages{
    padding:16px;
  }
}

/* ── V4 DETAIL / CHAT / CREATE / ACTIVITY PROFILE POLISH ───────────────── */
.gg-detail-page,
.gg-create-page{
  position:relative;
}

.gg-detail-header,
.gg-create-header{
  min-height:58px;
}

.gg-detail-title{
  font-size:1rem;
  letter-spacing:.1px;
}

.gg-detail-tab-bar{
  padding:0 8px;
  gap:4px;
}

.gg-detail-tab{
  border-radius:12px 12px 0 0;
  font-size:.84rem;
  font-weight:600;
}

.gg-detail-tab.on{
  background:rgba(247,178,57,.12);
}

.gg-detail-info-panel{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}

.gg-detail-section{
  border-radius:20px;
  padding:18px;
}

.gg-detail-section-title{
  font-size:.72rem;
  letter-spacing:1px;
}

.gg-member-row{
  padding:12px 2px;
}

.gg-member-name{
  font-size:.92rem;
}

.gg-member-sub{
  font-size:.76rem;
}

.gg-pending-row{
  border-radius:12px;
  padding:12px;
}

.gg-chat-panel{
  border:1px solid rgba(25,48,88,.1);
  border-radius:20px;
  overflow:hidden;
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(5px);
}

.gg-chat-disclaimer{
  padding:10px 14px;
}

.gg-chat-messages{
  background:
    radial-gradient(circle at top right, rgba(247,178,57,.12), transparent 40%),
    radial-gradient(circle at bottom left, rgba(122,162,255,.12), transparent 38%),
    #f8fbff;
}

.gg-chat-bubble-wrap{
  max-width:min(78%, 460px);
}

.gg-chat-bubble{
  border-radius:18px;
  padding:10px 14px;
  line-height:1.55;
}

.gg-chat-row-mine .gg-chat-bubble{
  border-bottom-right-radius:8px;
}

.gg-chat-row:not(.gg-chat-row-mine) .gg-chat-bubble{
  border-bottom-left-radius:8px;
}

.gg-chat-input-row{
  gap:10px;
  padding:10px 12px;
}

.gg-chat-input{
  min-height:42px;
  border-radius:16px;
  background:#fff;
}

.gg-chat-send-btn{
  width:42px;
  height:42px;
}

.gg-create-progress{
  padding-top:14px;
  padding-bottom:10px;
}

.gg-create-body{
  gap:10px;
}

.gg-form-group{
  background:#fff;
  border:1px solid rgba(25,48,88,.1);
  border-radius:16px;
  padding:14px;
  margin-bottom:0;
  box-shadow:0 8px 20px rgba(20,35,62,.06);
}

.gg-form-input,
.gg-loc-results,
.gg-loc-selected{
  border-radius:12px;
}

.gg-svc-pick{
  grid-template-columns:repeat(3,minmax(0,1fr));
}

.gg-svc-pick-btn{
  border-radius:14px;
}

.gg-join-mode-row{
  gap:12px;
}

.gg-join-mode-btn{
  border-radius:14px;
  min-height:90px;
  justify-content:center;
}

.gg-create-footer{
  box-shadow:0 -8px 24px rgba(20,35,62,.08);
}

.gg-profile-content{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}

.gg-profile-actions{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  margin-bottom:0;
}

.gg-profile-settings{
  margin-bottom:0;
}

@media (min-width:768px){
  .gg-detail-page,
  .gg-create-page{
    border-radius:22px;
    overflow:hidden;
    margin-top:12px;
    margin-bottom:12px;
  }

  .gg-detail-info-panel{
    grid-template-columns:repeat(2,minmax(0,1fr));
    align-content:start;
  }

  .gg-detail-section:first-child,
  .gg-detail-section:last-child{
    grid-column:1 / -1;
  }

  .gg-chat-panel{
    grid-column:1 / -1;
    min-height:520px;
  }

  .gg-chat-bubble-wrap{
    max-width:min(68%, 640px);
  }

  .gg-create-body{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
    align-content:start;
  }

  .gg-form-group.gg-span-2{
    grid-column:1 / -1;
  }

  .gg-create-footer{
    padding-left:20px;
    padding-right:20px;
  }

  .gg-profile-content{
    grid-template-columns:minmax(300px,380px) minmax(0,1fr);
    align-items:start;
  }

  .gg-profile-hero{
    position:sticky;
    top:92px;
  }

  .gg-profile-actions,
  .gg-profile-settings,
  .gg-profile-footer{
    grid-column:2;
  }
}

@media (max-width:767px){
  .gg-chat-panel{
    border-radius:16px;
  }

  .gg-detail-info-panel{
    padding:14px;
  }

  .gg-create-body{
    padding:14px;
  }
}

/* ── 2026-04 UI Refresh: filters/create/detail/chat/points/profile ─────── */
.gg-filter-panel{
  margin:8px 14px 10px;padding:14px;border:1px solid var(--border);border-radius:16px;
  background:#fff;box-shadow:var(--shadow-card);
}
.gg-filter-panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.gg-filter-panel-title{font-weight:700;color:var(--ink)}
.gg-filter-panel-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:12px}

.gg-create-page,.gg-detail-page,.gg-points-page{background:linear-gradient(180deg,#f8fbff 0%,#f5f7fb 55%,#f2f5fa 100%)}
.gg-sub-header,.gg-create-header,.gg-detail-header{
  position:sticky;top:0;z-index:20;backdrop-filter:blur(10px);
  background:rgba(255,255,255,.86);border-bottom:1px solid var(--border);
}
.gg-sub-header{display:grid;grid-template-columns:44px 1fr 44px;align-items:center;padding:10px 14px 8px;height:58px}
.gg-sub-header-title{font-weight:800;text-align:center}

.gg-create-progress{margin:12px 14px 0;background:#fff;border-radius:14px;padding:12px;border:1px solid var(--border)}
.gg-create-body{padding:14px}
#ggCreateStep1,#ggCreateStep2,#ggCreateStep3{background:#fff;border:1px solid var(--border);border-radius:18px;padding:14px}
.gg-form-input{background:#f8fafc;border:1px solid #d9e0ea;border-radius:12px}
.gg-create-footer{position:sticky;bottom:0;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-top:1px solid var(--border)}

.gg-detail-tab-bar{position:sticky;top:58px;z-index:15;background:transparent;padding:8px 12px;display:grid;grid-template-columns:1fr 1fr;gap:8px}
.gg-detail-tab{border-radius:12px;border:1px solid var(--border);background:#fff;padding:10px;font-weight:700}
.gg-detail-tab.on{background:var(--brand-dim);border-color:var(--brand);color:var(--brand-dark)}
.gg-detail-info-panel{padding:0 12px 90px}
.gg-detail-section{background:#fff;border:1px solid var(--border);border-radius:16px;padding:12px;margin-top:10px;box-shadow:0 2px 8px rgba(16,24,40,.05)}
.gg-detail-footer{backdrop-filter:blur(10px);background:rgba(255,255,255,.92);border-top:1px solid var(--border)}

.gg-chat-panel{padding:0 10px 14px}
.gg-chat-disclaimer{margin:10px 2px;border-radius:12px;background:#fff8e5;border:1px solid #f0d8a0}
.gg-chat-messages{background:#fff;border:1px solid var(--border);border-radius:16px;padding:12px}
.gg-chat-input-row{margin-top:10px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:6px}
.gg-chat-input{background:#f8fafc;border:none}
.gg-chat-send-btn{border-radius:10px;background:var(--brand);color:#1f2937}

.gg-points-page-body{padding:14px}
.gg-points-balance-card{background:linear-gradient(135deg,#1f2937,#334155);color:#fff;border:none}
.gg-points-tip{margin-top:10px;font-size:.82rem;color:var(--muted)}
.gg-points-tx-title{margin-top:16px;font-weight:800}
.gg-points-tx-list{margin-top:8px;background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden}

.gg-profile-content{padding:14px;display:flex;flex-direction:column;gap:12px}
.gg-profile-card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:16px;box-shadow:0 2px 12px rgba(15,23,42,.05)}
.gg-profile-hero{text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px;background:linear-gradient(180deg,#fffdf7 0%,#ffffff 100%)}
.gg-profile-avatar{width:82px;height:82px;border-radius:50%;border:3px solid rgba(247,178,57,.45)}
.gg-profile-sec-title{font-weight:800;margin-bottom:6px}
.gg-setting-row{padding:10px 0;border-bottom:1px dashed #e6eaf0}
.gg-setting-row:last-child{border-bottom:none;padding-bottom:0}
.gg-setting-value{font-size:.82rem;color:var(--muted)}
.gg-profile-muted{text-align:center}

/* ── 2026-04-16 hotfix: login/session/layout stability ─────────────────── */
.gg-login-right{
  padding:calc(env(safe-area-inset-top) + 20px) 18px calc(env(safe-area-inset-bottom) + 26px);
}
.gg-login-card{
  background:#fff;border:1px solid var(--border);border-radius:22px;
  box-shadow:0 14px 34px rgba(15,23,42,.08);padding:22px 18px;
}
.gg-login-note{margin-top:12px}
@media (min-width:768px){
  .gg-login-right{padding:40px}
  .gg-login-card{max-width:440px;padding:28px 26px}
}

.gg-app-shell{position:relative}
.gg-topbar{
  position:fixed;top:0;left:0;right:0;z-index:80;
}
.gg-content{
  padding-top:calc(54px + env(safe-area-inset-top));
  padding-bottom:calc(84px + env(safe-area-inset-bottom));
}
.gg-bottom-nav{
  position:fixed;left:50%;transform:translateX(-50%);
  bottom:0;z-index:85;width:min(100%,520px);
  border-top-left-radius:18px;border-top-right-radius:18px;
  box-shadow:0 -8px 24px rgba(15,23,42,.12);
  padding-left:8px;padding-right:8px;
}
.gg-nav-item{padding:8px 2px 6px}

.gg-sub-header,.gg-create-header,.gg-detail-header{
  position:fixed;top:0;left:0;right:0;z-index:70;
}
.gg-detail-tab-bar{
  position:fixed;top:58px;left:0;right:0;z-index:65;background:var(--bg);
}
.gg-detail-info-panel{padding-top:68px}
.gg-chat-panel{margin-top:66px}
.gg-create-body,.gg-points-page-body{padding-top:72px}

.gg-create-page.gg-create-single .gg-create-progress,
.gg-create-page.gg-create-single #ggStepIndicator{display:none}
.gg-create-page.gg-create-single .gg-create-body{
  display:flex;flex-direction:column;gap:12px;
}
.gg-create-page.gg-create-single #ggCreateStep1,
.gg-create-page.gg-create-single #ggCreateStep2,
.gg-create-page.gg-create-single #ggCreateStep3{
  display:block !important;
}

.gg-profile-content{
  width:min(100%,760px);margin:0 auto;padding:14px;
  display:flex;flex-direction:column;gap:12px;
}
.gg-profile-head{display:block}
.gg-profile-hero{
  text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:22px 18px;background:linear-gradient(180deg,#fffdf7 0%,#ffffff 100%);
}
.gg-profile-menu-card{padding:6px}
.gg-profile-menu-item{
  width:100%;background:#fff;border:none;border-radius:14px;
  display:flex;align-items:center;gap:12px;padding:10px 12px;
  text-align:left;transition:background .15s;
}
.gg-profile-menu-item:active{background:#f7fafc}
.gg-profile-menu-icon{
  width:34px;height:34px;border-radius:10px;background:var(--brand-dim);
  color:var(--brand-dark);display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.gg-profile-menu-icon svg{width:18px;height:18px}
.gg-profile-menu-main{display:flex;flex-direction:column;min-width:0;flex:1}
.gg-profile-menu-label{font-size:.88rem;color:var(--ink);font-weight:700}
.gg-profile-menu-sub{font-size:.75rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gg-profile-menu-chevron{font-size:1.3rem;color:#9ba7bb;line-height:1}
.gg-profile-footer{display:flex;flex-direction:column;gap:10px}
.gg-profile-footer-note{margin:0}

/* ── 2026-04-16 UX polish: login/profile/points/notifs/nav ─────────────── */
.gg-login-page{
  position:relative;
  inset:auto;
  overflow:auto;
}
.gg-login-wrap,
.gg-login-right{
  height:100%;
  min-height:100%;
}
.gg-pdpa-wrap{
  align-items:center;
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:12px;
  background:#fafcff;
}
@media (min-width:768px){
  .gg-login-page,
  .gg-login-wrap{
    min-height:100dvh;
  }
  .gg-login-left,
  .gg-login-right{
    height:auto;
    min-height:100dvh;
  }
}
.gg-pdpa-cb{
  width:20px;
  height:20px;
  min-width:20px;
}

.gg-profile-menu-card .gg-lang-toggle{
  background:#f4f7fb;
  border:1px solid #dce4ef;
  border-radius:12px;
  padding:3px;
}
.gg-profile-menu-card .gg-lbtn{
  min-width:44px;
  height:32px;
  border-radius:9px;
  font-size:.76rem;
}
.gg-profile-menu-card .gg-lbtn.on{
  box-shadow:0 4px 10px rgba(247,178,57,.35);
}
.gg-btn-logout{
  min-height:42px;
  font-weight:700;
}
.gg-btn-logout:disabled{
  opacity:.6;
  cursor:not-allowed;
}

.gg-points-balance-card{
  background:linear-gradient(140deg,#111827 0%,#1f2937 55%,#334155 100%);
  color:#fff;
}
.gg-points-balance-val{
  color:#fff;
}
.gg-points-stats{
  margin-top:14px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.gg-points-stat{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  border-radius:12px;
  padding:8px 10px;
  display:flex;
  flex-direction:column;
  gap:2px;
}
.gg-points-stat span{
  font-size:.72rem;
  opacity:.8;
}
.gg-points-stat b{
  font-size:1rem;
}

.gg-notifs-list{
  gap:12px;
}
.gg-notif-card{
  border-radius:16px;
  padding:13px 14px;
  border:1px solid #e4eaf4;
  box-shadow:0 4px 16px rgba(15,23,42,.06);
}
.gg-notif-ico-wrap{
  width:38px;
  height:38px;
  border-radius:12px;
  background:#fff3dc;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.gg-notif-ico{
  font-size:1.05rem;
  width:auto;
}
.gg-notif-dot{
  position:static;
  margin-left:auto;
  font-size:.64rem;
  font-weight:700;
  padding:3px 8px;
  border-radius:999px;
  background:#fff1cf;
  color:#8a5a00;
}
.gg-notif-unread{
  border-left:1px solid #e4eaf4;
  border-color:#e2bc6f;
  background:#fffdfa;
}

.gg-bottom-nav{
  width:min(calc(100% - 14px), 520px);
  bottom:max(6px, env(safe-area-inset-bottom));
  border-radius:22px;
}

.gg-profile-content{
  width:min(100%, 760px);
  margin:0 auto;
  padding:14px;
}

.gg-profile-sheet{
  display:grid;
  gap:16px;
}

.gg-profile-hero{
  background:linear-gradient(180deg,#fffaf0 0%,#ffffff 100%);
  color:var(--ink);
  border-radius:28px;
  padding:22px 18px 20px;
  border:1px solid rgba(247,178,57,.18);
  box-shadow:0 18px 40px rgba(15,23,42,.08);
  display:grid;
  justify-items:center;
  gap:10px;
}

.gg-profile-kicker{
  font-size:.82rem;
  letter-spacing:.04em;
  color:var(--brand-dark);
  margin-bottom:2px;
  font-weight:800;
}

.gg-profile-name{
  font-family:'Nunito Sans','Prompt',sans-serif;
  font-size:1.7rem;
  line-height:1.08;
  font-weight:800;
  color:var(--ink);
  margin:0;
  text-align:center;
}

.gg-profile-subid{
  margin-top:0;
  font-size:.88rem;
  color:var(--muted);
  text-align:center;
}

.gg-profile-avatar-wrap{
  display:flex;
  justify-content:center;
}

.gg-profile-avatar{
  width:96px;
  height:96px;
  border-radius:50%;
  object-fit:cover;
  border:3px solid rgba(247,178,57,.3);
  background:#a7aa82;
  box-shadow:0 10px 28px rgba(15,23,42,.12);
}

.gg-avatar-fallback{
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-size:2rem;
  font-weight:700;
}

.gg-profile-tag-btn{
  min-height:36px;
  padding:0 15px;
  border-radius:999px;
  border:1px solid rgba(18,35,61,.12);
  background:#fff;
  color:var(--ink);
  font-family:'Sarabun',sans-serif;
  font-size:.82rem;
  font-weight:700;
  cursor:default;
  box-shadow:0 4px 12px rgba(15,23,42,.05);
}

.gg-profile-panel{
  background:#fff;
  color:var(--ink);
  border-radius:22px;
  border:1px solid rgba(18,35,61,.08);
  box-shadow:0 14px 28px rgba(15,23,42,.06);
  overflow:hidden;
}

.gg-profile-panel-title{
  padding:15px 18px 8px;
  font-size:1.02rem;
  font-weight:800;
  color:var(--ink);
}

.gg-profile-panel-body{
  padding:0 18px 6px;
}

.gg-profile-row{
  width:100%;
  min-height:62px;
  display:flex;
  align-items:center;
  gap:14px;
  padding:12px 0;
  background:none;
  border:none;
  color:var(--ink);
  text-align:left;
}

.gg-profile-row.is-action{
  cursor:pointer;
}

.gg-profile-row-icon{
  width:40px;
  height:40px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  color:var(--brand-dark);
  background:var(--brand-dim);
}

.gg-profile-row-icon svg{
  width:20px;
  height:20px;
}

.gg-profile-row-main{
  min-width:0;
  flex:1;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}

.gg-profile-row-label{
  font-size:.93rem;
  font-weight:700;
  color:var(--ink);
}

.gg-profile-row-value{
  max-width:52%;
  font-size:.88rem;
  color:#495468;
  text-align:right;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.gg-profile-row-value.is-muted{
  color:#7c8698;
}

.gg-profile-row-divider{
  height:1px;
  background:#e8edf4;
  margin-left:54px;
}

.gg-profile-row-chevron{
  color:#a5afbf;
  font-size:1.5rem;
  line-height:1;
}

.gg-profile-action-panel{
  background:#fff;
  border:1px solid rgba(18,35,61,.08);
  border-radius:22px;
  box-shadow:0 14px 28px rgba(15,23,42,.06);
  padding:4px 8px;
}

.gg-btn-logout{
  width:100%;
  min-height:48px;
  border:none;
  border-radius:16px;
  background:transparent;
  color:#c53f36;
  font-size:.92rem;
  font-weight:800;
  cursor:pointer;
  line-height:1;
  padding:0 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}

.gg-btn-logout-icon{
  width:18px;
  height:18px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.gg-btn-logout-icon svg{
  width:16px;
  height:16px;
}

.gg-btn-logout:active{
  opacity:.86;
}

.gg-btn-logout:disabled{
  opacity:.6;
  cursor:not-allowed;
}

.gg-profile-footer-note{
  display:none;
}

@media (min-width:768px){
  .gg-app-shell{
    display:grid;
    grid-template-columns:280px minmax(0,1fr);
    grid-template-areas:
      "nav topbar"
      "nav content";
    height:100dvh;
    overflow:hidden;
  }

  .gg-topbar{
    grid-area:topbar;
    position:sticky;
    top:0;
    left:auto;
    right:auto;
    z-index:50;
    height:74px;
    padding:0 24px;
  }

  .gg-content{
    grid-area:content;
    padding:20px 22px 26px;
    overflow-y:auto;
  }

  .gg-bottom-nav{
    grid-area:nav;
    position:static;
    left:auto;
    transform:none;
    bottom:auto;
    z-index:auto;
    width:auto;
    height:100dvh;
    padding:18px 12px 20px;
    border-radius:0;
    border-top:none;
    border-right:1px solid rgba(18,35,61,.08);
    box-shadow:none;
    display:grid;
    grid-template-columns:1fr;
    grid-template-rows:auto auto auto auto auto;
    gap:8px;
    align-content:start;
  }

  .gg-nav-item{
    padding:10px 12px;
  }

  .gg-profile-content{
    width:min(100%, 900px);
    padding:22px 18px;
  }

  .gg-profile-sheet{
    grid-template-columns:minmax(280px,330px) minmax(0,540px);
    align-items:start;
    justify-content:center;
  }

  .gg-profile-hero{
    position:sticky;
    top:98px;
    min-height:0;
    align-content:start;
  }

  .gg-profile-panel,
  .gg-profile-action-panel{
    grid-column:2;
  }

  .gg-profile-panel-title{
    padding-top:20px;
  }
}

@media (max-width:767px){
  .gg-profile-content{
    width:min(calc(100% - 28px), 388px);
    padding:18px 0 calc(12px + env(safe-area-inset-bottom));
  }

  .gg-profile-hero{
    border-radius:22px;
    padding:18px 16px 20px;
  }

  .gg-profile-name{
    font-size:1.42rem;
  }

  .gg-profile-subid{
    font-size:.84rem;
  }

  .gg-profile-panel{
    border-radius:22px;
  }

  .gg-profile-action-panel{
    border-radius:22px;
    padding:4px 8px;
  }

  .gg-profile-panel-title{
    padding-left:16px;
    padding-right:16px;
  }

  .gg-profile-panel-body{
    padding-left:16px;
    padding-right:16px;
  }

  .gg-profile-row{
    min-height:56px;
    gap:12px;
    padding:10px 0;
  }

  .gg-profile-row-icon{
    width:40px;
    height:40px;
    border-radius:12px;
  }

  .gg-profile-row-main{
    flex-direction:column;
    align-items:flex-start;
    justify-content:center;
    gap:2px;
  }

  .gg-profile-row-value{
    max-width:100%;
    text-align:left;
  }

  .gg-profile-row-divider{
    margin-left:52px;
  }
}

/* 2026-04-17 create page redesign */
.gg-create-page.gg-create-single .gg-create-body{
  display:flex;
  flex-direction:column;
  gap:18px;
  width:min(100%, 760px);
  margin:0 auto;
  padding:86px 14px 132px;
  flex:0 0 auto;
  overflow:visible;
}

.gg-create-title{
  width:100%;
  text-align:left;
}

.gg-create-header-spacer{
  width:22px;
  height:22px;
}

.gg-create-group{
  display:flex;
  flex-direction:column;
  gap:0;
}

.gg-create-group-title{
  padding:15px 18px 8px;
  font-size:1.02rem;
  font-weight:800;
  color:var(--ink);
}

.gg-create-card{
  background:transparent;
  border:none;
  border-radius:0;
  padding:0;
  box-shadow:none;
}

.gg-create-card .gg-form-group + .gg-form-group{
  margin-top:10px;
  padding-top:14px;
  border-top:1px solid #eef2f7;
}

#ggCreateStep1 .gg-form-group,
#ggCreateStep2 .gg-form-group,
#ggCreateStep3 .gg-form-group{
  margin-top:0;
  background:transparent;
  border:none;
  border-radius:0;
  padding:0;
  box-shadow:none;
}

#ggCreateStep1 .gg-form-group + .gg-form-group,
#ggCreateStep2 .gg-form-group + .gg-form-group,
#ggCreateStep3 .gg-form-group + .gg-form-group{
  margin-top:10px;
  padding-top:12px;
  border-top:1px solid #eef2f7;
}

#ggCreateStep1 .gg-form-group + .gg-form-group{
  margin-top:0;
  padding-top:8px;
}

#ggCreateStep1 .gg-form-group:first-child .gg-form-label{
  margin-bottom:4px;
}

#ggCreateStep1 .gg-svc-pick{
  gap:10px;
  padding-top:2px;
  margin-bottom:-6px;
}

#ggCreateStep1 .gg-svc-pick-btn{
  box-shadow:none;
  flex-direction:row;
  align-items:center;
  justify-content:flex-start;
}

.gg-create-datetime-shell,
.gg-create-field-shell{
  display:flex;
  align-items:center;
  gap:12px;
  min-height:70px;
  padding:12px 14px;
  border:1px solid #e3eaf3;
  border-radius:18px;
  background:#fff;
}

.gg-create-field-shell-wide{
  width:100%;
}

.gg-create-datetime-shell{
  position:relative;
  cursor:pointer;
}

#ggCreateStep1 .gg-create-datetime-shell{
  min-height:0;
  padding:6px 0 2px;
  border:none;
  border-radius:0;
  background:transparent;
  gap:12px;
}

.gg-create-datetime-native{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  opacity:0;
  cursor:pointer;
  z-index:2;
}

.gg-create-datetime-display{
  font-size:.96rem;
  font-weight:700;
  color:var(--ink);
  line-height:1.35;
}

.gg-create-datetime-display.is-empty{
  color:#7a8597;
  font-weight:600;
}

.gg-create-field-icon{
  width:38px;
  height:38px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  color:var(--brand-dark);
  background:#fff2d9;
}

.gg-create-field-icon svg{
  width:18px;
  height:18px;
}

.gg-create-field-main{
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width:0;
  flex:1;
}

.gg-create-field-label{
  font-size:.74rem;
  font-weight:700;
  color:#7a8597;
}

#ggCreateStep1 .gg-create-field-icon{
  width:34px;
  height:34px;
  border-radius:10px;
  background:#fff3df;
}

#ggCreateStep1 .gg-create-field-main{
  gap:0;
}

.gg-create-row-arrow{
  width:18px;
  height:18px;
  color:#9aa4b2;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}

.gg-create-row-arrow svg{
  width:16px;
  height:16px;
}

.gg-create-field-input{
  padding:0;
  min-height:24px;
  border:none;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  font-size:.96rem;
  font-weight:700;
  color:var(--ink);
}

.gg-create-field-input:focus{
  box-shadow:none;
}

.gg-svc-pick{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.gg-svc-pick-btn{
  min-height:0;
  padding:10px 14px;
  justify-content:center;
  align-items:center;
  gap:8px;
  width:auto;
  box-shadow:none;
}

.gg-svc-pick-ico{
  width:20px;
  height:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--brand-dark);
  font-size:1rem;
  line-height:1;
}

.gg-svc-pick-ico svg{
  width:18px;
  height:18px;
}

.gg-svc-pick-lbl{
  margin-top:0;
  text-align:center;
  font-size:.84rem;
  color:var(--ink);
  font-weight:700;
}

.gg-svc-pick-btn.on .gg-svc-pick-ico{
  color:var(--brand-dark);
}

.gg-svc-pick-lbl{
  font-size:.84rem;
  color:inherit;
  line-height:1.2;
  font-weight:700;
  text-align:left;
  white-space:nowrap;
}

.gg-pax-row{
  width:100%;
  min-width:0;
  justify-content:space-between;
  padding:6px;
  border-radius:12px;
  background:#fbfcfe;
  border:1px solid #e3eaf3;
}

.gg-pax-btn{
  width:46px;
  height:46px;
  border-radius:14px;
}

.gg-pax-display{
  flex:1;
  min-width:0;
  text-align:center;
  font-size:1.05rem;
  font-weight:800;
  color:var(--ink);
}

.gg-join-mode-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.gg-choice-tag-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.gg-choice-tag{
  min-height:0;
  border-radius:999px;
  border:1px solid #e3eaf3;
  background:#fbfcfe;
  padding:10px 14px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  width:auto;
  font-size:.84rem;
  color:var(--ink);
  font-weight:700;
}

.gg-choice-tag.on{
  border-color:var(--brand);
  background:var(--brand-dim);
  color:var(--brand-dark);
}

.gg-join-mode-btn{
  min-height:0;
  display:inline-flex;
  align-items:center;
  flex-direction:row;
  gap:8px;
  width:auto;
  padding:10px 14px;
}

.gg-join-mode-ico{
  width:18px;
  height:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:0;
  color:var(--brand-dark);
}

.gg-join-mode-ico svg{
  width:18px;
  height:18px;
}

.gg-join-mode-lbl{
  font-size:.84rem;
  color:var(--ink);
  font-weight:700;
}

.gg-loc-selected,
.gg-loc-results{
  border-radius:18px;
  border:1px solid #e3eaf3;
  background:#fff;
}

.gg-loc-result-item{
  padding:14px 12px;
}

.gg-loc-result-ico{
  width:18px;
  height:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--brand-dark);
  line-height:0;
  flex-shrink:0;
}

.gg-loc-result-ico svg{
  width:18px;
  height:18px;
}

.gg-form-label-inline{
  display:flex;
  align-items:center;
  gap:8px;
}

.gg-form-label-icon,
.gg-loc-sel-ico-svg{
  width:18px;
  height:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--brand-dark);
  line-height:0;
}

.gg-form-label-icon svg,
.gg-loc-sel-ico-svg svg{
  width:18px;
  height:18px;
}

.gg-loc-sel-name,
.gg-loc-result-name{
  font-weight:700;
  color:var(--ink);
}

.gg-create-actions{
  margin-top:14px;
  background:#fff;
  border:none;
  box-shadow:none;
  padding:4px 8px;
}

.gg-create-group.gg-profile-panel{
  gap:0;
  overflow:hidden;
}

.gg-create-group.gg-profile-panel > .gg-profile-panel-title{
  padding:15px 16px 14px;
  font-size:1.02rem;
  font-weight:800;
  color:var(--ink);
}

.gg-create-group.gg-profile-panel > .gg-profile-panel-body{
  padding:0 16px 8px;
  background:transparent;
  border:none;
  box-shadow:none;
}

.gg-route-stack{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:12px;
  padding:2px 0;
}

.gg-route-stack::before{
  display:none;
}

.gg-route-stop{
  position:relative;
  display:grid;
  grid-template-columns:26px minmax(0,1fr);
  align-items:center;
  gap:10px;
  min-height:64px;
}

.gg-route-stop:first-child::after{
  content:"";
  position:absolute;
  left:12px;
  top:20px;
  height:calc(100% + 10px);
  width:2px;
  background:
    repeating-linear-gradient(
      to bottom,
      rgba(201,122,0,.38) 0 7px,
      transparent 7px 14px
    );
  z-index:0;
}

.gg-route-marker{
  width:12px;
  height:12px;
  margin-left:7px;
  border-radius:999px;
  position:relative;
  z-index:1;
}

.gg-route-marker-meet{
  background:#fff;
  border:3px solid var(--brand-dark);
}

.gg-route-marker-dest{
  background:var(--brand-dark);
  box-shadow:0 0 0 4px rgba(247,178,57,.12);
}

.gg-route-stop-main{
  min-width:0;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:2px;
  background:none;
  border:none;
  text-align:left;
  color:var(--ink);
}

.gg-route-stop-label{
  font-size:.84rem;
  font-weight:800;
  color:var(--ink);
}

.gg-route-stop-value{
  font-size:1rem;
  font-weight:700;
  color:var(--ink);
  line-height:1.3;
}

.gg-route-stop-value.is-placeholder{
  color:#8c97a8;
}

.gg-route-stop-sub{
  font-size:.8rem;
  color:var(--muted);
  line-height:1.35;
}

.gg-route-gps-btn{display:none}

#ggCreateStep2 .gg-form-group + .gg-form-group{
  margin-top:0;
  padding-top:0;
  border-top:none;
}

#ggCreateStep2 .gg-profile-panel-body{
  overflow:hidden;
}

#ggFNote{
  min-height:120px;
  padding:14px 16px;
  border-radius:18px;
  border:1px solid #e3eaf3;
  background:#fff;
}

.gg-place-search-page{
  position:fixed;
  inset:0;
  background:var(--bg);
  z-index:120;
  display:flex;
  flex-direction:column;
}

.gg-place-search-header{
  flex-shrink:0;
  display:grid;
  grid-template-columns:44px minmax(0,1fr) 22px;
  align-items:center;
  column-gap:10px;
  padding:10px 16px;
  background:#fff;
  border-bottom:1px solid var(--border);
}

.gg-place-search-title{
  font-family:'Nunito Sans','Prompt',sans-serif;
  font-weight:700;
  font-size:1rem;
  color:var(--ink);
}

.gg-place-search-body{
  flex:1;
  overflow-y:auto;
  width:min(100%, 760px);
  margin:0 auto;
  padding:18px 14px 32px;
}

.gg-place-search-bar{
  display:grid;
  grid-template-columns:minmax(0,1fr) 44px;
  gap:10px;
  align-items:center;
  margin-bottom:14px;
}

.gg-place-search-input-wrap{
  min-width:0;
  display:flex;
  align-items:center;
  gap:10px;
  height:48px;
  padding:0 14px;
  border:1px solid #e3eaf3;
  border-radius:16px;
  background:#fff;
}

.gg-place-search-icon{
  width:18px;
  height:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#9aa4b2;
  flex-shrink:0;
}

.gg-place-search-icon svg{
  width:18px;
  height:18px;
}

.gg-place-search-input{
  flex:1;
  min-width:0;
  border:none;
  background:transparent;
  outline:none;
  font-size:.95rem;
  color:var(--ink);
}

.gg-place-search-results{
  display:block !important;
  overflow:hidden;
  border-radius:22px;
  border:1px solid rgba(18,35,61,.08);
  background:#fff;
  box-shadow:0 14px 28px rgba(15,23,42,.06);
}

.gg-place-search-results:empty{
  display:none !important;
}

.gg-place-search-results .gg-loc-result-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:15px 16px;
}

.gg-place-search-results .gg-loc-result-item:first-child{
  border-top-left-radius:22px;
  border-top-right-radius:22px;
}

.gg-place-search-results .gg-loc-result-item:last-child{
  border-bottom-left-radius:22px;
  border-bottom-right-radius:22px;
}

/* Final map search overrides */
.gg-place-map-header{
  position:relative;
  display:grid;
  grid-template-columns:44px minmax(0,1fr) 44px;
  align-items:center;
  gap:12px;
}

.gg-place-map-title{
  min-width:0;
}

.gg-place-map-search-inline{
  grid-column:2 / 4;
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
  min-height:44px;
}

.gg-place-map-search-btn,
.gg-place-map-search-close{
  background:transparent !important;
  border:none !important;
  border-radius:0 !important;
  box-shadow:none !important;
  padding:0 !important;
}

.gg-place-map-search-input{
  width:100%;
  min-width:0;
  border:none !important;
  background:transparent !important;
  box-shadow:none !important;
  padding:0 !important;
}

.gg-place-map-search-results{
  display:none;
  position:absolute;
  top:14px !important;
  left:14px !important;
  right:14px !important;
  z-index:655 !important;
  background:rgba(255,255,255,.98);
  border:1px solid rgba(18,35,61,.08);
  border-radius:20px;
  box-shadow:0 18px 38px rgba(15,23,42,.18);
  overflow:hidden;
  max-height:min(42vh, 320px);
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}

.gg-place-map-search-results.is-open{
  display:block !important;
}

.gg-place-map-header.is-searching + .gg-place-map-body .gg-place-map-controls{
  display:none !important;
}

.gg-place-map-page .leaflet-control-zoom{
  display:none !important;
}

.gg-place-map-header{
  position:relative;
  display:grid;
  grid-template-columns:44px minmax(0,1fr) 44px;
  align-items:center;
  gap:12px;
}

.gg-place-map-title{
  min-width:0;
}

.gg-place-map-search-inline{
  grid-column:2 / 4;
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
  min-height:44px;
}

.gg-place-map-search-btn,
.gg-place-map-search-close{
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
  border-radius:0 !important;
  padding:0 !important;
}

.gg-place-map-search-input{
  width:100%;
  min-width:0;
  border:none !important;
  background:transparent !important;
  box-shadow:none !important;
  padding:0 !important;
}

.gg-place-map-search-results{
  top:18px !important;
  left:14px !important;
  right:14px !important;
  z-index:655 !important;
}

.gg-place-map-header.is-searching + .gg-place-map-body .gg-place-map-search-results{
  top:14px !important;
}

.gg-place-map-header.is-searching + .gg-place-map-body .gg-place-map-controls{
  display:none !important;
}

.gg-place-map-canvas .leaflet-control-zoom,
.gg-place-map-page .leaflet-control-zoom{
  display:none !important;
}

/* 2026-04-17 image upload fixes */
.gg-create-page.gg-create-embedded .gg-profile-panel-body,
.gg-create-page.gg-create-embedded .gg-form-group,
.gg-create-page.gg-create-embedded .gg-create-upload-wrap{
  min-width:0 !important;
}

.gg-create-page.gg-create-embedded .gg-create-upload-wrap{
  width:100%;
  overflow:visible !important;
}

.gg-create-page.gg-create-embedded .gg-create-upload-btn{
  width:100%;
  max-width:100%;
  min-width:0;
  box-sizing:border-box;
}

.gg-create-page.gg-create-embedded .gg-create-image-preview{
  width:100%;
  max-width:100%;
  min-width:0;
  overflow:hidden;
}

.gg-create-page.gg-create-embedded .gg-create-image-row{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:92px;
  justify-content:flex-start;
  width:100%;
  max-width:100%;
  min-width:0;
  overflow-x:auto;
  overflow-y:hidden;
  padding:2px 2px 4px 0;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior-x:contain;
  touch-action:pan-x;
  scrollbar-width:none;
}

.gg-create-page.gg-create-embedded .gg-create-image-row::-webkit-scrollbar{
  display:none;
}

.gg-create-upload-wrap{
  display:grid;
  gap:10px;
}

.gg-create-title-input{
  min-height:52px;
  max-height:52px;
  border-radius:18px !important;
  padding-top:14px !important;
  padding-bottom:14px !important;
  background:#f8fafc !important;
  border:1px solid #d9e0ea !important;
  line-height:1.35;
  white-space:nowrap;
  overflow-y:hidden;
  margin-bottom:0 !important;
}

.gg-create-page.gg-create-embedded #ggFTitle{
  border-radius:18px !important;
  background:#f8fafc !important;
  min-height:48px !important;
  resize:none !important;
}

.gg-create-page.gg-create-embedded #ggFNote{
  border-radius:18px !important;
  background:#f8fafc !important;
}

.gg-create-page.gg-create-embedded #ggFNote,
.gg-create-page.gg-create-embedded #ggFTitle{
  overflow:hidden;
}

.gg-form-err-tight{
  min-height:0 !important;
  margin-top:4px !important;
}

.gg-form-err-tight:empty{
  display:none;
}

.gg-create-upload-input{
  display:none;
}

.gg-create-upload-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  width:100%;
  min-height:68px;
  border:1px dashed rgba(247,178,57,.36);
  border-radius:18px;
  background:#fffaf0;
  color:var(--brand-dark);
  font-weight:700;
  padding:16px 18px;
  text-align:center;
}

.gg-create-upload-btn-icon{
  width:18px;
  height:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

.gg-create-upload-btn-icon svg{
  width:18px;
  height:18px;
}

.gg-create-image-preview{
  display:block;
}

.gg-create-image-row{
  display:flex;
  gap:10px;
  overflow-x:auto;
  overflow-y:hidden;
  padding-top:2px;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
  touch-action:pan-x;
  overscroll-behavior-x:contain;
}

.gg-create-image-row::-webkit-scrollbar{
  display:none;
}

.gg-create-image-tile{
  position:relative;
  flex:0 0 auto;
  width:92px;
  height:92px;
  border-radius:16px;
  overflow:hidden;
  background:#fff;
  border:1px solid var(--border);
}

.gg-create-image-thumb{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.gg-create-image-clear{
  position:absolute;
  top:6px;
  right:6px;
  width:24px;
  height:24px;
  border:none;
  border-radius:999px;
  background:rgba(17,24,39,.72);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
  cursor:pointer;
}

.gg-create-image-clear svg{
  width:12px;
  height:12px;
  display:block;
  flex-shrink:0;
}

.gg-detail-cover-wrap{
  margin-bottom:16px;
  border-radius:22px;
  overflow:hidden;
  border:1px solid var(--border);
  background:#fff;
}

.gg-detail-cover{
  display:block;
  width:100%;
  max-height:280px;
  object-fit:cover;
}

/* 2026-04-17 topbar/create final polish */
.gg-topbar-logo.gg-topbar-page-title{
  color:var(--ink) !important;
}

.gg-topbar-logo.gg-topbar-page-title span{
  color:inherit !important;
}

#ggViewMine #ggMyList,
#ggViewNotifs #ggNotifsList{
  padding-top:16px;
}

.gg-create-page.gg-create-embedded.gg-create-single .gg-create-body{
  padding-top:16px !important;
}

@media (min-width:768px){
  #ggViewMine #ggMyList,
  #ggViewNotifs #ggNotifsList{
    padding-top:18px;
  }

  .gg-create-page.gg-create-embedded.gg-create-single .gg-create-body{
    padding-top:18px !important;
  }
}

.gg-place-search-header{
  grid-template-columns:44px minmax(0,1fr);
  grid-template-areas:
    "back bar";
    "back bar";
  row-gap:0;
  column-gap:12px;
  padding:10px 16px;
}

.gg-place-search-back{
  grid-area:back;
  align-self:center;
}

.gg-place-search-title{
  display:none;
}

.gg-place-search-bar-toolbar{
  grid-area:bar;
  margin-bottom:0;
  align-self:center;
}

.gg-place-search-body{
  padding:14px 14px calc(92px + env(safe-area-inset-bottom));
}

.gg-place-search-empty{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
  padding:26px 18px;
  text-align:center;
  color:var(--muted);
}

.gg-place-search-empty-title{
  font-size:.95rem;
  font-weight:700;
  color:var(--ink);
}

.gg-place-search-empty-sub{
  font-size:.84rem;
  line-height:1.45;
}

.gg-place-search-map-btn{
  position:fixed;
  left:50%;
  bottom:calc(14px + env(safe-area-inset-bottom));
  transform:translateX(-50%);
  z-index:122;
  min-height:44px;
  min-width:220px;
  padding:0 18px;
  border:none;
  border-radius:14px;
  background:var(--brand-dim);
  color:var(--brand-dark);
  font-family:'Sarabun',sans-serif;
  font-size:.86rem;
  font-weight:700;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}

.gg-place-search-map-btn svg{
  width:18px;
  height:18px;
}

.gg-place-map-page{
  position:fixed;
  inset:0;
  background:var(--bg);
  z-index:121;
  display:flex;
  flex-direction:column;
}

.gg-place-map-header{
  flex-shrink:0;
  display:grid;
  grid-template-columns:44px minmax(0,1fr) 44px;
  align-items:center;
  column-gap:10px;
  padding:10px 16px;
  background:#fff;
  border-bottom:1px solid var(--border);
  position:relative;
}

.gg-place-map-title{
  font-family:'Nunito Sans','Prompt',sans-serif;
  font-weight:700;
  font-size:1rem;
  color:var(--ink);
}

.gg-place-map-search-btn{
  width:44px;
  height:44px;
  border:none;
  border-radius:0;
  background:transparent;
  color:var(--ink);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-shadow:none;
  padding:0;
}

.gg-place-map-search-btn svg{
  width:20px;
  height:20px;
}

.gg-place-map-searchbar{
  position:absolute;
  top:0;
  left:60px;
  right:60px;
  height:64px;
  display:flex;
  align-items:center;
  z-index:670;
  padding:0;
  background:transparent;
  border:0;
}

.gg-place-map-searchbar-inner{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:44px;
  width:100%;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  padding:0;
}

.gg-place-map-searchbar-icon{
  color:var(--muted);
  display:inline-flex;
}

.gg-place-map-searchbar-icon svg{
  width:18px;
  height:18px;
}

.gg-place-map-search-input{
  flex:1;
  min-width:0;
  border:none;
  background:transparent;
  font-family:'Sarabun',sans-serif;
  font-size:.92rem;
  color:var(--ink);
  outline:none;
}

.gg-place-map-search-close{
  width:28px;
  height:28px;
  border:none;
  border-radius:0;
  background:transparent;
  color:var(--ink);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0;
}

.gg-place-map-search-close svg{
  width:16px;
  height:16px;
}

.gg-place-map-body{
  flex:1;
  position:relative;
  display:flex;
  flex-direction:column;
  width:100%;
  margin:0;
  padding:0;
  gap:0;
  min-height:0;
}

.gg-place-map-canvas{
  position:absolute;
  inset:0;
  flex:1;
  min-height:0;
  overflow:hidden;
  background:#eef4ff;
}

.gg-place-map-controls{
  position:absolute;
  top:14px;
  right:14px;
  z-index:650;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.gg-place-map-fab{
  min-height:42px;
  padding:0 14px;
  border:none;
  border-radius:14px;
  background:rgba(255,255,255,.96);
  color:var(--ink);
  box-shadow:0 12px 24px rgba(15,23,42,.14);
  backdrop-filter:blur(10px);
  font-family:'Sarabun',sans-serif;
  font-size:.82rem;
  font-weight:700;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}

.gg-place-map-fab svg{
  width:18px;
  height:18px;
}

.gg-place-map-search-results{
  position:absolute;
  top:16px;
  left:14px;
  right:14px;
  z-index:655;
  background:rgba(255,255,255,.98);
  border:1px solid rgba(18,35,61,.08);
  border-radius:20px;
  box-shadow:0 18px 38px rgba(15,23,42,.18);
  overflow:hidden;
  max-height:min(42vh, 320px);
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}

.gg-place-map-sheet{
  position:absolute;
  left:14px;
  right:14px;
  bottom:calc(14px + env(safe-area-inset-bottom));
  z-index:650;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(18,35,61,.08);
  border-radius:24px;
  box-shadow:0 24px 44px rgba(15,23,42,.18);
  backdrop-filter:blur(16px);
  padding:14px 14px 16px;
  display:flex;
  flex-direction:column;
  gap:12px;
}

.gg-place-map-sheet::before{
  content:"";
  width:42px;
  height:5px;
  border-radius:999px;
  background:#d8e1ee;
  align-self:center;
}

.gg-place-map-kicker{
  font-size:.76rem;
  font-weight:700;
  color:var(--brand-dark);
}

.gg-place-map-name{
  font-size:.98rem;
  font-weight:800;
  color:var(--ink);
}

.gg-place-map-sub{
  font-size:.84rem;
  color:var(--muted);
  line-height:1.45;
}

.gg-place-map-actions{
  display:flex;
  gap:10px;
  margin-top:2px;
}

.gg-place-map-secondary,
.gg-place-map-primary{
  min-height:46px;
  border:none;
  border-radius:14px;
  font-family:'Sarabun',sans-serif;
  font-size:.86rem;
  font-weight:700;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}

.gg-place-map-secondary{
  flex:0 0 auto;
  padding:0 14px;
  background:#fff7e6;
  color:var(--brand-dark);
  box-shadow:inset 0 0 0 1px rgba(247,178,57,.18);
}

.gg-place-map-primary{
  flex:1;
  padding:0 16px;
  background:#fff;
  color:#c53f36;
  border:1px solid rgba(18,35,61,.08);
  box-shadow:0 10px 20px rgba(15,23,42,.08);
}

.gg-place-map-loading{
  opacity:.7;
  pointer-events:none;
}

.gg-place-map-marker{
  width:28px;
  height:28px;
  border-radius:50% 50% 50% 0;
  transform:rotate(-45deg);
  background:linear-gradient(180deg,#f7b239 0%, #d98900 100%);
  border:2px solid #fff8e8;
  box-shadow:0 10px 18px rgba(15,23,42,.24);
  position:relative;
}

.gg-place-map-marker::after{
  content:"";
  position:absolute;
  inset:6px;
  border-radius:50%;
  background:#fff;
}

.gg-place-map-marker-wrap{
  background:transparent !important;
  border:none !important;
}

.gg-place-search-results .gg-loc-result-item + .gg-loc-result-item{
  border-top:1px solid #e8edf4;
}

.gg-place-search-results .gg-loc-result-ico{
  width:36px;
  height:36px;
  border-radius:12px;
  background:var(--brand-dim);
}

.gg-place-search-results .gg-loc-result-name{
  font-size:.92rem;
  font-weight:700;
  color:var(--ink);
}

.gg-place-search-results .gg-loc-result-sub{
  margin-top:2px;
  font-size:.8rem;
  color:var(--muted);
  line-height:1.35;
}

.gg-place-search-gps svg{
  width:18px;
  height:18px;
}

.gg-place-search-gps svg circle{
  display:none;
}

#ggViewCreate .gg-view-header{
  display:block;
}

#ggViewMine .gg-view-header,
#ggViewCreate .gg-view-header,
#ggViewNotifs .gg-view-header{
  display:none;
}

.gg-create-page.gg-create-embedded.gg-create-single .gg-create-body{
  width:min(100%, 900px);
  margin:0 auto;
  padding:0 18px 126px;
}

.gg-create-page.gg-create-embedded .gg-create-card{
  display:contents;
}

.gg-loc-gps-btn{
  width:44px;
  height:44px;
  border-radius:14px;
  background:var(--brand-dim);
  color:var(--brand-dark);
  border:1px solid rgba(247,178,57,.22);
}

.gg-loc-gps-btn svg{
  width:18px;
  height:18px;
}

.gg-loc-sel-ico.gg-loc-sel-ico-svg{
  font-size:0;
}

@media (min-width:768px){
  .gg-create-page.gg-create-single .gg-create-body{
    padding:102px 18px 140px;
  }
}

@media (max-width:767px){
  .gg-place-search-body{
    width:min(calc(100% - 28px), 388px);
    padding:18px 0 120px;
  }

  .gg-create-page.gg-create-embedded.gg-create-single .gg-create-body{
    width:min(calc(100% - 28px), 388px);
    padding:0 0 calc(12px + env(safe-area-inset-bottom));
  }

  .gg-bottom-nav{
    left:0;
    right:0;
    width:100%;
    transform:none;
    border-top-left-radius:0;
    border-top-right-radius:0;
    box-shadow:none;
    padding-left:0;
    padding-right:0;
    bottom:0;
  }

  .gg-bottom-nav .gg-nav-label{
    display:none;
  }

  .gg-bottom-nav .gg-nav-item,
  .gg-bottom-nav .gg-nav-create{
    gap:0;
    padding:10px 4px;
  }

  .gg-bottom-nav .gg-nav-svg{
    width:24px;
    height:24px;
  }
}

@media (max-width:767px){
  .gg-create-page.gg-create-single .gg-create-body{
    width:min(calc(100% - 28px), 388px);
    padding:82px 0 116px;
    gap:16px;
  }

  .gg-create-group.gg-profile-panel > .gg-profile-panel-title{
    padding:15px 16px 16px;
  }

  .gg-create-group.gg-profile-panel > .gg-profile-panel-body{
    padding-left:16px;
    padding-right:16px;
  }
}

/* 2026-04-17 icon system alignment */
.gg-cat-item-ico,
.gg-svc-pick-ico,
.gg-loc-ico-svg,
.gg-card-svc-icon{
  line-height:0;
}

.gg-cat-item-ico svg,
.gg-svc-pick-ico svg,
.gg-loc-ico-svg svg,
.gg-card-svc-icon svg{
  width:18px;
  height:18px;
}

.gg-cat-item-ico svg{
  width:20px;
  height:20px;
}

.gg-svc-pick-ico svg{
  width:20px;
  height:20px;
}

.gg-card-svc-tag{
  display:inline-flex;
  align-items:center;
  gap:8px;
}

.gg-card-svc-icon{
  width:18px;
  height:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--brand-dark);
}

/* 2026-04-17 create/profile alignment */
.gg-create-group{
  display:grid;
  gap:8px;
}

.gg-create-group-title{
  padding:0 6px;
  font-size:1.02rem;
  font-weight:800;
  color:var(--ink);
}

.gg-create-card .gg-form-group:first-child{
  margin-top:0;
}

.gg-create-datetime-shell,
.gg-create-field-shell,
.gg-loc-selected,
.gg-loc-results,
.gg-form-input,
.gg-pax-row{
  box-shadow:none;
}

.gg-create-datetime-shell,
.gg-create-field-shell,
.gg-form-input,
.gg-loc-selected,
.gg-loc-results,
.gg-loc-result-item,
.gg-loc-sel-inner{
  border-radius:0;
}

.gg-choice-tag,
.gg-svc-pick-btn,
.gg-join-mode-btn{
  min-height:40px;
  border-radius:999px;
  border:1px solid #e3eaf3;
  background:#fbfcfe;
  padding:10px 14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  width:auto;
  font-size:.84rem;
  color:var(--ink);
  font-weight:700;
}

.gg-choice-tag.on,
.gg-svc-pick-btn.on,
.gg-join-mode-btn.on{
  border-color:var(--brand);
  background:var(--brand-dim);
  color:var(--brand-dark);
}

.gg-join-mode-lbl,
.gg-svc-pick-lbl{
  color:inherit;
  font-size:.84rem;
  font-weight:700;
}

.gg-join-mode-row,
.gg-choice-tag-row,
.gg-svc-pick{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.gg-svc-pick{
  align-items:flex-start;
}

.gg-bottom-nav{
  border-radius:0;
}

.gg-nav-item,
.gg-nav-create{
  min-height:60px;
  border-radius:0;
}

.gg-nav-create-slot{
  flex:1;
  width:auto;
}

.gg-nav-create{
  position:static;
  width:100%;
  height:auto;
  background:transparent;
  color:var(--muted);
  border:none;
  box-shadow:none;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:3px;
  padding:8px 4px 6px;
}

.gg-nav-create:hover,
.gg-nav-create:active{
  transform:none;
  box-shadow:none;
}

.gg-nav-profile-wrap{
  display:flex;
  align-items:center;
  justify-content:center;
}

@media (min-width:768px){
  .gg-create-page.gg-create-single .gg-create-body{
    padding:92px 14px 136px;
  }

  .gg-create-footer{
    padding:16px;
  }

  .gg-bottom-nav .gg-nav-item,
  .gg-bottom-nav .gg-nav-create{
    border-radius:14px;
  }

  .gg-nav-create{
    min-height:52px;
  }
}

.gg-loc-ico-svg{
  width:18px;
  height:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--brand-dark);
}

.gg-create-field-input[type="date"],
.gg-create-field-input[type="time"],
.gg-create-field-input[type="datetime-local"],
.gg-create-field-input[type="text"],
.gg-create-field-input select,
select.gg-create-field-input{
  appearance:none;
  -webkit-appearance:none;
}

/* 2026-04-17 final create overrides */
.gg-create-page.gg-create-embedded .gg-create-group{
  display:block !important;
  gap:0 !important;
  padding:0 !important;
}

.gg-create-page.gg-create-embedded .gg-create-group.gg-profile-panel > .gg-profile-panel-title{
  padding:15px 14px 14px !important;
  margin:0 !important;
  text-align:left !important;
}

.gg-create-page.gg-create-embedded .gg-create-group.gg-profile-panel .gg-form-label{
  margin-left:0 !important;
  padding-left:0 !important;
  text-align:left !important;
}

.gg-create-page.gg-create-embedded .gg-create-group.gg-profile-panel > .gg-profile-panel-body{
  padding:0 14px 8px !important;
}

.gg-create-page.gg-create-embedded .gg-profile-panel-body > .gg-form-group{
  margin:0 !important;
  padding:0 !important;
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
}

.gg-create-page.gg-create-embedded .gg-profile-panel-body > .gg-form-group + .gg-form-group{
  margin-top:8px !important;
  padding-top:14px !important;
  border-top:1px solid #eef2f7 !important;
}

.gg-create-page.gg-create-embedded .gg-profile-panel-body > .gg-form-group .gg-form-label{
  margin-bottom:8px !important;
}

.gg-create-page.gg-create-embedded .gg-profile-panel-body > .gg-form-group .gg-form-err{
  margin-top:4px !important;
}

.gg-create-page.gg-create-embedded .gg-profile-panel-body > .gg-form-group.gg-form-group-date{
  margin-top:8px !important;
  padding-top:14px !important;
}

.gg-create-page.gg-create-embedded .gg-profile-panel-body > .gg-form-group.gg-form-group-date .gg-create-datetime-shell{
  padding:2px 0 0 !important;
}

.gg-create-page.gg-create-embedded .gg-profile-panel-body > .gg-form-group.gg-form-group-titlefield{
  margin-bottom:0 !important;
}

.gg-create-page.gg-create-embedded .gg-profile-panel-body > .gg-form-group.gg-form-group-titlefield .gg-form-err{
  margin-top:6px !important;
}

.gg-create-page.gg-create-embedded .gg-profile-panel-body > .gg-form-group.gg-form-group-titlefield + .gg-form-group.gg-form-group-date{
  margin-top:8px !important;
  padding-top:14px !important;
}

.gg-feed-card-topline{
  height:10px;
  width:100%;
}

.gg-feed-card-inner{
  display:grid;
  grid-template-columns:minmax(0,1fr) 118px;
  gap:16px;
  align-items:start;
}

.gg-feed-card-main{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.gg-feed-card-chiprow{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}

.gg-feed-card-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 12px;
  border-radius:999px;
  background:#f6f8fc;
  border:1px solid rgba(18,35,61,.08);
  color:var(--ink);
  font-size:.8rem;
  font-weight:700;
}

.gg-feed-card-chip-soft{
  background:#eef4ff;
  color:#49617f;
}

.gg-feed-card-title{
  font-family:'Nunito Sans','Prompt',sans-serif;
  font-size:1.35rem;
  line-height:1.22;
  font-weight:800;
  color:var(--ink);
  letter-spacing:-.02em;
}

.gg-feed-card-place{
  font-size:.98rem;
  line-height:1.45;
  color:#5c6678;
  font-weight:600;
}

.gg-feed-card-meta{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.gg-feed-card-creator{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}

.gg-feed-card-creator-avatar .gg-card-av-lg{
  width:34px;
  height:34px;
}

.gg-feed-card-creator-name{
  min-width:0;
  font-size:.86rem;
  font-weight:700;
  color:#6b7280;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.gg-feed-card-capacity{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
  font-size:.9rem;
  font-weight:700;
  color:#eb5f36;
}

.gg-feed-card-capacity.is-full{
  color:#9b1c1c;
}

.gg-feed-card-capacity-dot{
  color:#a7afbd;
}

.gg-feed-card-route{
  display:flex;
  align-items:flex-start;
  gap:8px;
  font-size:.88rem;
  line-height:1.45;
  color:#7b8494;
  font-weight:600;
}

.gg-feed-card-side{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:12px;
}

.gg-feed-card-side-avatar{
  align-self:flex-end;
}

.gg-feed-card-media{
  width:118px;
  height:118px;
  border-radius:22px;
  overflow:hidden;
  background:linear-gradient(145deg,#fff2d6,#ffe0a8);
  border:1px solid rgba(18,35,61,.08);
}

.gg-feed-card-thumb{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.gg-feed-card-thumb-fallback{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#b9770e;
}

.gg-feed-card-thumb-icon{
  width:36px;
  height:36px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

.gg-feed-card-thumb-icon svg{
  width:36px;
  height:36px;
}

.gg-feed-card-status{
  grid-column:1 / -1;
  display:flex;
  justify-content:flex-end;
  margin-top:-4px;
}

@media (max-width: 767px){
  .gg-feed-card-inner{
    grid-template-columns:minmax(0,1fr) 104px;
    gap:14px;
  }

  .gg-feed-card-title{
    font-size:1.12rem;
  }

  .gg-feed-card-place{
    font-size:.9rem;
  }

  .gg-feed-card-media{
    width:104px;
    height:104px;
    border-radius:18px;
  }
}

@media (min-width: 768px){
  .gg-create-page.gg-create-embedded .gg-place-map-page{
    position:fixed;
    top:74px;
    left:302px;
    right:22px;
    bottom:26px;
    border-radius:0;
    overflow:hidden;
    border:none;
    box-shadow:none;
    background:var(--bg);
    z-index:90;
  }

  .gg-create-page.gg-create-embedded .gg-place-map-header{
    padding:12px 14px;
    background:rgba(255,255,255,.92);
    border-bottom:1px solid rgba(18,35,61,.08);
  }

  .gg-create-page.gg-create-embedded .gg-place-map-sheet{
    left:18px;
    right:18px;
    bottom:18px;
    max-width:420px;
    margin-left:auto;
  }

  .gg-create-page.gg-create-embedded .gg-place-map-search-results{
    left:18px !important;
    right:auto !important;
    top:18px !important;
    max-width:460px;
  }

  .gg-create-page.gg-create-embedded .gg-place-map-controls{
    top:18px;
    right:18px;
  }
}

.gg-create-page.gg-create-embedded .gg-create-card{
  display:block !important;
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
  padding:0 !important;
  border-radius:0 !important;
}

.gg-create-page.gg-create-embedded{
  max-width:none !important;
  width:100% !important;
  margin:0 !important;
  border:none !important;
  box-shadow:none !important;
}

.gg-create-page.gg-create-embedded.gg-create-single .gg-create-body{
  background:transparent !important;
  border:none !important;
  border-radius:0 !important;
  box-shadow:none !important;
}

.gg-create-page.gg-create-embedded .gg-route-stack{
  gap:24px !important;
  padding:8px 0 10px !important;
}

.gg-create-page.gg-create-embedded .gg-route-stop{
  min-height:72px !important;
}

.gg-create-page.gg-create-embedded .gg-route-stack::before,
.gg-create-page.gg-create-embedded .gg-route-stop:first-child::after{
  display:none !important;
  content:none !important;
}

.gg-create-page.gg-create-embedded #ggFNote{
  min-height:128px;
  border-radius:18px;
}

.gg-create-page.gg-create-embedded #ggCreateStep1 .gg-svc-pick{
  gap:10px !important;
  padding-top:0 !important;
  margin-bottom:0 !important;
}

.gg-place-search-results .gg-loc-result-item:first-child{
  border-top-left-radius:22px;
  border-top-right-radius:22px;
}

.gg-place-search-results .gg-loc-result-item:last-child{
  border-bottom-left-radius:22px;
  border-bottom-right-radius:22px;
}
