/* styles.css — Path of Faith · vintage parchment & sepia theme */

*, *::before, *::after { box-sizing: border-box; }

.app {
  /* paper */
  --paper-a:#f7eed8; --paper-b:#ece0c0; --paper-c:#e3d4b1;
  --card:#fbf5e6; --card2:#fffaee; --line:#dac6a0; --line-soft:#e7d9bb;
  /* ink */
  --ink:#4b3826; --text:#4b3826; --muted:#8c7758; --faint:#ad9b78;
  /* metal */
  --gold:#c79a47; --gold-d:#9c722a; --gold-soft:rgba(199,154,71,.16);
  /* accents (rubber-stamp inks) */
  --accent:#b0432f; --accent-d:#8c3122; --red:#b0432f; --green:#5f7d49; --blue:#3f6a8c;
  --shadow:rgba(94,68,32,.16); --shadow-d:rgba(74,52,22,.26);
  --notch:var(--paper-b);
  --mono:'IBM Plex Mono', ui-monospace, monospace;
  --serif:'Trirong', Georgia, serif;
  font-family:'Sarabun', system-ui, sans-serif;
  height:100%; color:var(--text); position:relative; overflow:hidden;
  -webkit-font-smoothing:antialiased;
  background:
    radial-gradient(135% 80% at 50% -6%, var(--paper-a) 0%, var(--paper-b) 56%, var(--paper-c) 100%);
}
.app::before {
  content:''; position:absolute; inset:0; pointer-events:none; z-index:0;
  background-image:
    radial-gradient(circle at 18% 14%, rgba(176,140,80,.12), transparent 38%),
    radial-gradient(circle at 88% 82%, rgba(150,108,56,.10), transparent 42%),
    radial-gradient(circle at 70% 30%, rgba(120,90,50,.05), transparent 30%),
    repeating-linear-gradient(92deg, rgba(120,90,50,.025) 0 1px, transparent 1px 4px);
  mix-blend-mode:multiply; opacity:.9;
}
.app[data-theme="sepia"]{
  --paper-a:#f0e2c4; --paper-b:#e2cfa6; --paper-c:#d6bf92;
  --card:#f7eed6; --card2:#fdf6e4; --line:#cdb585; --line-soft:#ddc99e;
  --ink:#43301c; --text:#43301c; --muted:#806743; --faint:#a08a60;
  --gold:#bb8c3a; --gold-d:#90681f; --accent:#a23c26; --accent-d:#7f2c1a;
}
.app[data-theme="indigo"]{
  --paper-a:#f1ecdb; --paper-b:#e2dcc4; --paper-c:#d6cfb3;
  --card:#f9f4e6; --card2:#fffbef; --line:#d2c7a4;
  --ink:#39342a; --text:#39342a; --muted:#79715a; --faint:#a39882;
  --gold:#bf9647; --gold-d:#96702c; --accent:#3f5a86; --accent-d:#2e456a; --red:#3f5a86;
}

.scroller { position:absolute; inset:0; bottom:0; z-index:1; overflow-y:auto; overflow-x:hidden; -webkit-overflow-scrolling:touch; }
.scroller::-webkit-scrollbar { width:0; }
.screen { padding:54px 18px 108px; min-height:100%; }

/* ── buttons ── */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px;
  border:none; border-radius:14px; font:inherit; font-weight:600; font-size:15px;
  padding:13px 18px; cursor:pointer; width:100%; transition:transform .12s, filter .2s, opacity .2s; text-decoration:none; }
.btn:active { transform:scale(.97); }
.btn:disabled { opacity:.5; pointer-events:none; }
.btn-gold { color:#fff; background:linear-gradient(135deg, var(--accent), var(--accent-d));
  box-shadow:0 6px 16px rgba(140,49,34,.28), inset 0 1px 0 rgba(255,255,255,.22); }
.btn-gold:hover { filter:brightness(1.05); }
.btn-ghost { color:var(--ink); background:var(--card); border:1px solid var(--line); box-shadow:0 3px 8px var(--shadow); }

/* a true bronze button (medallion accents) */
.btn-bronze { color:#43300f; background:linear-gradient(135deg,#f0d18c,var(--gold) 55%,var(--gold-d));
  box-shadow:0 6px 16px rgba(156,114,42,.32), inset 0 1px 0 rgba(255,255,255,.5); }

/* ── brand header (home) ── */
/* ── gold ornate plaque header (every screen) ── */
.app-header { display:flex; flex-direction:row; align-items:center; gap:8px; margin:0 -4px 14px; }
.plaque-img { flex:1; min-width:0; width:100%; height:auto; object-fit:contain;
  filter:drop-shadow(0 5px 14px rgba(58,34,8,.34)); }
.app-header-lang { flex-shrink:0; }
.app-header-lang .lang-tog { padding:3px; }
.app-header-lang .lang-tog button { padding:6px 11px; font-size:12.5px; }

/* legacy aliases */
.brand-head { display:flex; align-items:center; gap:13px; margin-bottom:18px; }
.brand-mark { width:52px; height:52px; object-fit:contain; flex-shrink:0;
  filter:drop-shadow(0 3px 7px rgba(120,78,28,.30)); }
.brand-head .lang-tog { margin-left:auto; }
.brand-name { font-family:var(--serif); font-weight:700; font-size:20px; letter-spacing:.2px; color:var(--gold-d); }
.brand-sub { font-size:11.5px; color:var(--muted); margin-top:2px; }

/* logo brand header */
.brand-head-logo { display:flex; flex-direction:column; align-items:center; margin-bottom:14px; }
.brand-toprow { display:flex; justify-content:flex-end; width:100%; }
.brand-logo { width:100%; max-width:296px; height:auto; margin-top:-6px;
  filter:drop-shadow(0 8px 20px rgba(120,78,28,.28)); }

/* lang toggle */
.lang-tog { display:flex; background:var(--card); border:1px solid var(--line); border-radius:999px; padding:3px; gap:2px; box-shadow:0 2px 6px var(--shadow); }
.lang-tog button { border:none; background:none; color:var(--muted); font:inherit; font-size:12px; font-weight:600;
  padding:5px 11px; border-radius:999px; cursor:pointer; }
.lang-tog button.on { background:linear-gradient(135deg,var(--gold),var(--gold-d)); color:#fff; }

/* ── hero ── */
.hero-card { position:relative; background:var(--card); border:1px solid var(--line); border-radius:22px;
  padding:24px 22px 22px; display:flex; flex-direction:column; align-items:center; overflow:hidden;
  box-shadow:0 12px 30px var(--shadow), inset 0 1px 0 rgba(255,255,255,.5); }
.hero-card::after { content:''; position:absolute; inset:6px; border:1px solid var(--line-soft); border-radius:17px; pointer-events:none; }
.hero-glow { position:absolute; top:-40%; left:50%; transform:translateX(-50%); width:260px; height:260px;
  background:radial-gradient(circle, var(--gold-soft), transparent 70%); pointer-events:none; }
.ring-num { font-family:var(--serif); font-size:56px; font-weight:600; line-height:1;
  background:linear-gradient(160deg,var(--gold),var(--gold-d)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.ring-den { font-size:12px; color:var(--muted); margin-top:3px; }
.ring.on-light .ring-den { color:var(--muted); }

.hero-light { background:var(--card); border-color:var(--line); }
.hero-label { margin-top:14px; font-size:11.5px; letter-spacing:2px; text-transform:uppercase; color:var(--gold-d); font-weight:700; }
.hero-hint { font-size:14px; color:var(--ink); margin:4px 0 16px; text-align:center; }
.hero-card .btn { width:auto; padding-left:22px; padding-right:22px; position:relative; z-index:1; white-space:nowrap; }

/* ── nearest ── */
.near-card { display:flex; align-items:center; gap:13px; width:100%; margin-top:14px;
  background:var(--card); border:1px solid var(--line); border-radius:16px; padding:11px 14px 11px 11px; cursor:pointer; box-shadow:0 5px 14px var(--shadow); }
.near-kicker { display:flex; align-items:center; gap:5px; font-size:10.5px; letter-spacing:.5px; text-transform:uppercase; color:var(--gold-d); margin-bottom:3px; font-weight:600; }
.near-name { font-size:14.5px; font-weight:600; }
.near-dist { font-family:var(--serif); font-size:22px; color:var(--gold-d); font-weight:600; }
.near-dist span { font-size:11px; color:var(--muted); margin-left:2px; }

/* ── section head ── */
.sec-head { display:flex; align-items:baseline; justify-content:space-between; margin:26px 2px 13px; }
.sec-head h3 { margin:0; font-family:var(--serif); font-size:18px; font-weight:700; color:var(--ink); white-space:nowrap; }
.sec-head span { font-family:var(--mono); font-size:13px; color:var(--gold-d); }
.sec-sub { display:flex; align-items:center; gap:7px; font-size:12.5px; color:var(--muted); margin:0 2px 11px; }

/* ── grid layout ── */
.grid2 { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.gcard { position:relative; display:flex; flex-direction:column; align-items:center; gap:8px; padding:18px 12px 14px;
  background:var(--card); border:1px solid var(--line); border-radius:18px; cursor:pointer; transition:.18s; box-shadow:0 5px 13px var(--shadow); }
.gcard.on { border-color:var(--gold); }
.gcard-no { position:absolute; top:10px; left:11px; font-family:var(--mono); font-size:11px; color:var(--faint); }
.gcard-name { font-size:12.5px; font-weight:600; text-align:center; line-height:1.35; min-height:34px; text-wrap:pretty; }

/* ── list layout ── */
.list { display:flex; flex-direction:column; gap:9px; }
.lrow { display:flex; align-items:center; gap:13px; width:100%; padding:10px 12px;
  background:var(--card); border:1px solid var(--line); border-radius:14px; cursor:pointer; text-align:left; transition:.18s; box-shadow:0 4px 11px var(--shadow); }
.lrow-body { flex:1; min-width:0; }
.lrow-name { font-size:14px; font-weight:600; line-height:1.3; }
.lrow-sub { font-size:11.5px; color:var(--muted); margin-top:2px; }

/* ── feature layout ── */
.feat-list { display:flex; flex-direction:column; gap:16px; }
.fcard { width:100%; background:var(--card); border:1px solid var(--line); border-radius:18px; overflow:hidden; cursor:pointer; text-align:left; transition:.18s; box-shadow:0 7px 18px var(--shadow); }
.fcard.on { border-color:var(--gold); }
.fcard-no { position:absolute; top:12px; left:14px; font-family:var(--serif); font-size:30px; color:rgba(255,255,255,.92); font-weight:600; text-shadow:0 2px 6px rgba(60,40,16,.5); }
.fcard-glyph { position:absolute; right:16px; bottom:14px; color:rgba(255,255,255,.8); }
.fcard-badge { position:absolute; top:12px; right:12px; display:flex; align-items:center; gap:4px; font-size:11px; font-weight:600;
  color:#fff; background:var(--green); padding:4px 9px; border-radius:999px; }
.fcard-body { padding:12px 15px 14px; }

/* chips */
.chip { display:inline-flex; align-items:center; gap:4px; font-size:11px; font-weight:600; padding:4px 9px; border-radius:999px; white-space:nowrap; }
.chip-on { color:#fff; background:var(--green); }
.chip-off { color:var(--muted); background:var(--paper-b); border:1px solid var(--line); }

/* ── image link → all sites page ── */
.sites-link { position:relative; display:block; width:100%; margin-top:16px; aspect-ratio:16/7; border-radius:20px; overflow:hidden;
  border:1px solid var(--line); cursor:pointer; padding:0; box-shadow:0 10px 26px var(--shadow); }
.sites-link img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .4s ease; }
.sites-link:hover img { transform:scale(1.05); }
.sites-link-scrim { position:absolute; inset:0; background:linear-gradient(90deg, rgba(40,24,8,.78) 0%, rgba(40,24,8,.30) 60%, transparent 100%); }
.sites-link-txt { position:absolute; left:18px; top:50%; transform:translateY(-50%); right:54px; text-align:left; }
.sites-link-t { font-family:var(--serif); font-weight:700; font-size:20px; color:#fff; line-height:1.2; text-shadow:0 1px 6px rgba(0,0,0,.6); }
.sites-link-s { font-size:11.5px; color:rgba(255,255,255,.85); margin-top:3px; text-shadow:0 1px 4px rgba(0,0,0,.6); text-wrap:pretty; }
.sites-link-go { position:absolute; right:14px; top:50%; transform:translateY(-50%); width:34px; height:34px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; color:#3a2606;
  background:linear-gradient(135deg,#fbe7a8,var(--gold)); box-shadow:0 3px 8px rgba(0,0,0,.3); }

/* back link */
.back-link { display:inline-flex; align-items:center; gap:5px; background:none; border:none; cursor:pointer;
  color:var(--gold-d); font:inherit; font-size:13px; font-weight:600; padding:2px 0; margin-bottom:6px; }
.back-link:hover { color:var(--accent); }

/* ── photo banner (real images, top of home) ── */
.photo-banner { position:relative; width:100%; aspect-ratio:16/9; margin-bottom:16px; border-radius:20px; overflow:hidden;
  border:1px solid var(--line); box-shadow:0 10px 28px var(--shadow); }
.photo-track { display:flex; height:100%; transition:transform .6s cubic-bezier(.4,0,.2,1); }
.photo-slide { position:relative; flex:0 0 100%; height:100%; }
.photo-slide img { width:100%; height:100%; object-fit:cover; display:block; }
.photo-scrim { position:absolute; inset:0; background:linear-gradient(0deg, rgba(40,24,8,.55), transparent 42%); }
.photo-cap { position:absolute; left:14px; right:48px; bottom:24px; color:#fff; font-family:var(--serif); font-weight:600;
  font-size:14.5px; line-height:1.3; text-shadow:0 1px 6px rgba(0,0,0,.6); text-wrap:pretty; }

/* ── banner carousel (16:9) ── */
.banner { position:relative; width:100%; aspect-ratio:16/9; margin-top:16px; border-radius:18px; overflow:hidden;
  border:1px solid var(--line); box-shadow:0 9px 24px var(--shadow); }
.banner-track { display:flex; height:100%; transition:transform .55s cubic-bezier(.4,0,.2,1); }
.banner-slide { position:relative; flex:0 0 100%; height:100%; }
.banner-scrim { position:absolute; inset:0; background:linear-gradient(90deg, rgba(54,36,14,.7) 0%, rgba(54,36,14,.22) 55%, transparent 100%),
  linear-gradient(0deg, rgba(54,36,14,.55), transparent 55%); }
.banner-txt { position:absolute; left:16px; right:54px; bottom:30px; color:#fdf6e6; }
.banner-tag { display:inline-block; font-size:10px; font-weight:700; letter-spacing:.4px; color:#fff;
  background:linear-gradient(135deg,var(--accent),var(--accent-d)); padding:3px 9px; border-radius:999px; margin-bottom:8px; }
.banner-title { font-family:var(--serif); font-size:18px; font-weight:700; line-height:1.3; text-wrap:pretty; }
.banner-sub { font-size:11.5px; color:rgba(253,246,230,.85); margin-top:3px; text-wrap:pretty; }
.banner-arrow { position:absolute; top:50%; transform:translateY(-50%); width:30px; height:30px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; color:#fff; background:rgba(54,36,14,.4); border:1px solid rgba(255,255,255,.25);
  cursor:pointer; backdrop-filter:blur(4px); opacity:0; transition:opacity .2s; }
.banner:hover .banner-arrow { opacity:1; }
.banner-arrow.left { left:8px; }
.banner-arrow.right { right:8px; }
.banner-dots { position:absolute; bottom:11px; left:0; right:0; display:flex; justify-content:center; gap:6px; }
.banner-dot { width:7px; height:7px; border-radius:999px; border:none; padding:0; cursor:pointer; background:rgba(255,255,255,.5); transition:.25s; }
.banner-dot.on { width:18px; background:var(--gold); }

.muni-foot { display:flex; align-items:center; justify-content:center; gap:8px; margin-top:28px;
  font-size:11px; color:var(--faint); text-align:center; }

/* hover lift for tappable paper cards */
.near-card, .gcard, .lrow, .fcard { transition:transform .15s, box-shadow .2s; }
.near-card:hover, .gcard:hover, .lrow:hover, .fcard:hover { transform:translateY(-1px); box-shadow:0 10px 22px var(--shadow-d); }
.reward-locked { background:var(--card); border:1px dashed var(--line); }

/* ── about the project ── */
.about { margin-top:26px; }
.about .sec-head h3 { flex-shrink:0; }
.about-badge { display:inline-flex; align-items:center; gap:4px; flex-shrink:0; white-space:nowrap;
  font-family:inherit !important; font-size:10px !important; font-weight:600;
  color:var(--gold-d); background:var(--gold-soft); border:1px solid var(--line); padding:3px 9px; border-radius:999px; }
.about-card { background:var(--card); border:1px solid var(--line); border-radius:16px; padding:16px;
  box-shadow:0 7px 18px var(--shadow), inset 0 1px 0 rgba(255,255,255,.5); }
.about-intro { font-size:13.5px; line-height:1.8; color:var(--ink); margin:0; text-wrap:pretty; }
.about-intro + .about-intro { margin-top:11px; color:var(--muted); }
.about-sub { display:flex; align-items:center; gap:8px; font-family:var(--serif); font-size:15.5px; font-weight:700; color:var(--gold-d); margin:22px 2px 12px; }
.about-emoji { font-size:16px; }
.about-list { display:flex; flex-direction:column; gap:11px; }
.about-item { display:flex; gap:11px; font-size:12.5px; line-height:1.65; color:var(--muted); text-wrap:pretty; }
.about-item b { color:var(--ink); font-weight:700; }
.about-dot { flex-shrink:0; width:24px; height:24px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  color:var(--gold-d); background:var(--gold-soft); border:1px solid var(--line); margin-top:1px; }
.about-steps { display:flex; flex-direction:column; gap:11px; }
.about-step { display:flex; gap:13px; background:var(--card); border:1px solid var(--line); border-radius:14px; padding:13px 15px;
  box-shadow:0 5px 14px var(--shadow), inset 0 1px 0 rgba(255,255,255,.5); }
.about-step-no { flex-shrink:0; width:30px; height:30px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-family:var(--serif); font-size:17px; font-weight:700; color:#fff;
  background:linear-gradient(135deg,var(--accent),var(--accent-d)); box-shadow:inset 0 1px 0 rgba(255,255,255,.25); }
.about-step-head { font-size:13.5px; font-weight:700; color:var(--ink); margin-bottom:3px; }
.about-step-text { font-size:12px; line-height:1.6; color:var(--muted); text-wrap:pretty; }

/* ── emblem disc ── */
.emblem { box-shadow:inset 0 0 0 2px rgba(255,255,255,.25), inset 0 2px 8px rgba(70,48,18,.25); transition:filter .5s, opacity .5s; }
.emblem.locked { filter:grayscale(.9) brightness(.92) sepia(.3); }

/* ── medallions (vintage wax-seal / stamp) ── */
.medal-wrap { display:flex; flex-direction:column; align-items:center; gap:7px; }
.medal-frame { position:relative; display:flex; align-items:center; justify-content:center; }
.medal-frame.medallion { border-radius:50%; padding:8px; background:linear-gradient(145deg,#f0d189,var(--gold) 45%,var(--gold-d));
  box-shadow:0 5px 13px var(--shadow-d), inset 0 1px 0 rgba(255,255,255,.6), inset 0 -2px 3px rgba(120,80,10,.5); }
.medal-frame.coin { border-radius:50%; padding:11px; background:radial-gradient(70% 70% at 35% 30%, #f3d896, var(--gold) 55%, var(--gold-d));
  box-shadow:0 5px 13px var(--shadow-d), inset 0 0 0 2px rgba(255,255,255,.4), inset 0 2px 4px rgba(255,255,255,.5), inset 0 -3px 5px rgba(120,80,10,.55); }
.medal-frame.coin .emblem { box-shadow:inset 0 0 0 2px rgba(120,80,10,.4), inset 0 2px 6px rgba(70,48,18,.35); }
.medal-frame.passport { border-radius:14px; padding:9px; background:var(--card);
  border:2px solid var(--gold); box-shadow:inset 0 0 0 4px var(--gold-soft), 0 4px 11px var(--shadow); }
.medal-frame.passport .emblem { border-radius:9px; box-shadow:inset 0 0 0 2px rgba(199,154,71,.5), inset 0 2px 6px rgba(70,48,18,.3); }
.medal-frame.off { filter:grayscale(.7) brightness(.96) sepia(.25); opacity:.78; }
.medal-frame.off.medallion, .medal-frame.off.coin { background:linear-gradient(145deg,#d8cbac,#b6a584 50%,#9a8862); }
.medal-frame.off.passport { border-color:var(--line); }
.medal-no { position:absolute; top:-3px; left:-3px; width:21px; height:21px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-size:12px; font-weight:700;
  color:#fbf3df; background:var(--accent); border:1.5px solid var(--card); z-index:2; box-shadow:0 2px 5px var(--shadow); }
.medal-frame.ink-red .medal-no { background:var(--red); }
.medal-frame.ink-green .medal-no { background:var(--green); }
.medal-frame.ink-blue .medal-no { background:var(--blue); }
.medal-check, .medal-lock { position:absolute; right:-2px; bottom:-2px; width:22px; height:22px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; z-index:2; }
.medal-check { background:var(--green); color:#fff; box-shadow:0 2px 6px var(--shadow-d); border:1.5px solid var(--card); }
.medal-lock { background:var(--paper-c); color:var(--faint); border:1px solid var(--line); }
.medal-name { font-size:11px; font-weight:600; text-align:center; line-height:1.3; max-width:96px; text-wrap:pretty; }
.medal-name.dim { color:var(--muted); }
.medal-date { font-family:var(--mono); font-size:9px; color:var(--gold-d); letter-spacing:.2px; }
.medal-date.dim2 { color:var(--faint); }

.stamp-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:18px 8px; padding:6px 4px 0; }

/* ── map ── */
.map-scene { position:relative; width:100%; height:230px; border-radius:18px; overflow:hidden;
  border:1px solid var(--line); box-shadow:inset 0 0 30px rgba(120,90,50,.18), 0 6px 16px var(--shadow); }
.map-pin { position:absolute; transform:translate(-50%,-50%); border:none; background:none; cursor:pointer; padding:0;
  transition:transform .15s; }
.map-pin-dot { display:flex; align-items:center; justify-content:center; width:28px; height:30px; border-radius:50% 50% 50% 50%/55% 55% 45% 45%;
  background:linear-gradient(150deg,#f0d189,var(--gold) 52%,var(--gold-d)); border:1.5px solid #fff7e4;
  box-shadow:0 5px 9px var(--shadow-d); font-family:var(--serif); font-size:13px; font-weight:700; color:#4a3318; line-height:1;
  clip-path:path('M14 0 A14 14 0 1 1 14 0 Z'); }
.map-pin-dot { clip-path:none; border-radius:50% 50% 50% 2px; transform:rotate(45deg); }
.map-pin-dot > * , .map-pin span { display:inline-block; transform:rotate(-45deg); }
.map-pin.got .map-pin-dot { filter:saturate(1.15) brightness(1.04); border-color:#fff; }
.map-pin.active .map-pin-dot { outline:3px solid var(--gold-soft); outline-offset:1px; }
.map-pin:hover { transform:translate(-50%,-50%) scale(1.12); }
.map-pin:active { transform:translate(-50%,-50%) scale(.92); }

/* ── contact ── */
.screen-title { font-family:var(--serif); font-size:25px; font-weight:700; color:var(--gold-d); margin-bottom:16px; }
.screen-title .lang-tog { margin-left:auto; }
.contact-card { display:flex; gap:14px; align-items:center; background:var(--card); border:1px solid var(--line); border-radius:18px; padding:16px; box-shadow:0 6px 16px var(--shadow); }
.contact-icon { width:46px; height:46px; border-radius:14px; display:flex; align-items:center; justify-content:center;
  color:#fff; background:linear-gradient(135deg,var(--accent),var(--accent-d)); flex-shrink:0; }
.contact-kicker { font-size:11px; color:var(--gold-d); font-weight:600; }
.contact-main { font-size:14px; font-weight:600; margin:2px 0 4px; line-height:1.3; }
.contact-num { font-family:var(--mono); font-size:18px; letter-spacing:1px; color:var(--ink); }
.contact-row2 { display:flex; gap:10px; margin-top:11px; align-items:stretch; }
.contact-row2 .btn { width:auto; flex-shrink:0; }
.web-inquiry { display:flex; align-items:center; gap:13px; width:100%; margin-top:11px; text-decoration:none;
  background:linear-gradient(165deg, rgba(255,255,255,.19), rgba(255,255,255,.07)); border:1px solid rgba(255,255,255,.22);
  border-radius:18px; padding:13px 15px 13px 13px; color:var(--ink);
  box-shadow:0 8px 20px rgba(0,0,0,.14), inset 0 1px 0 rgba(255,255,255,.20); transition:.18s; }
.web-inquiry:hover { background:linear-gradient(165deg, rgba(255,255,255,.26), rgba(255,255,255,.11)); }
.web-inquiry:active { transform:scale(.99); }
.web-inquiry-ic { width:44px; height:44px; border-radius:13px; flex-shrink:0; display:flex; align-items:center; justify-content:center;
  color:#fbf3df; background:linear-gradient(135deg, var(--accent), var(--accent-d)); box-shadow:0 4px 10px var(--shadow); }
.web-inquiry-t { font-size:14px; font-weight:700; color:var(--ink); }
.web-inquiry-s { font-size:11.5px; color:var(--muted); margin-top:2px; line-height:1.4; text-wrap:pretty; }
.hours-pill { flex:1; display:flex; align-items:center; gap:7px; font-size:12px; color:var(--muted);
  background:var(--card); border:1px solid var(--line); border-radius:14px; padding:0 14px; }
.redeem-card { margin-top:18px; background:var(--card); border:1px solid var(--line); border-radius:18px; overflow:hidden; box-shadow:0 7px 18px var(--shadow); }
.redeem-pin { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color:#fff; filter:drop-shadow(0 3px 6px rgba(54,36,14,.5)); }
.redeem-body { padding:15px 16px 17px; }
.redeem-title { display:flex; align-items:center; gap:8px; font-family:var(--serif); font-size:16px; font-weight:700; color:var(--gold-d); }
.redeem-sub { font-size:12.5px; color:var(--muted); margin:6px 0 13px; line-height:1.5; }
.faq { display:flex; flex-direction:column; gap:9px; }
.faq-item { background:var(--card); border:1px solid var(--line); border-radius:14px; overflow:hidden; box-shadow:0 4px 11px var(--shadow); }
.faq-item.open { border-color:var(--gold); }
.faq-q { display:flex; align-items:center; justify-content:space-between; gap:12px; width:100%; text-align:left;
  border:none; background:none; color:var(--ink); font:inherit; font-size:13.5px; font-weight:600; padding:13px 15px; cursor:pointer; }
.faq-a { font-size:12.5px; color:var(--muted); line-height:1.6; padding:0 15px 14px; }
.social-row { display:flex; align-items:center; gap:10px; margin-top:24px; }
.social-b { width:38px; height:38px; border-radius:12px; display:flex; align-items:center; justify-content:center;
  color:var(--gold-d); background:var(--card); border:1px solid var(--line); box-shadow:0 3px 9px var(--shadow); }
.social-txt { font-family:var(--mono); font-size:11px; color:var(--faint); margin-left:auto; }

/* ── profile ── */
.prof-head { display:flex; flex-direction:row; align-items:center; gap:15px; padding:4px 4px 18px; }
.prof-avatar { width:66px; height:66px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center;
  color:var(--gold-d); background:var(--card); border:2px solid var(--gold); box-shadow:0 6px 16px var(--shadow); }
.prof-id { min-width:0; }
.prof-name { font-family:var(--serif); font-size:21px; font-weight:700; white-space:nowrap; color:var(--ink); }
.prof-member { display:flex; align-items:center; gap:5px; font-size:12px; color:var(--gold-d); margin-top:4px; }

/* achievement card */
.achieve-card { display:block; width:100%; text-align:left; padding:16px; border-radius:18px; cursor:default;
  background:linear-gradient(165deg, rgba(255,255,255,.19), rgba(255,255,255,.07)); border:1px solid rgba(255,255,255,.22);
  box-shadow:0 8px 20px var(--shadow), inset 0 1px 0 rgba(255,255,255,.20); }
.achieve-card.done { cursor:pointer; border-color:rgba(232,196,90,.5); }
.achieve-top { display:flex; align-items:center; gap:16px; }
.achieve-num { flex-shrink:0; text-align:center; }
.achieve-big { font-family:var(--serif); font-size:42px; font-weight:700; line-height:1; color:var(--gold-d); }
.achieve-den { font-size:10.5px; color:var(--muted); margin-top:4px; }
.achieve-text { flex:1; display:flex; gap:9px; align-items:flex-start; font-size:13px; color:var(--ink); line-height:1.5; text-wrap:pretty; }
.achieve-text svg { flex-shrink:0; margin-top:2px; color:var(--gold-d); }
.achieve-bar { height:9px; border-radius:99px; margin-top:14px; overflow:hidden; background:rgba(120,78,28,.14); }
.achieve-bar span { display:block; height:100%; border-radius:99px;
  background:linear-gradient(90deg, #cda24a, #e8c45a); box-shadow:0 0 8px rgba(232,196,90,.5);
  transition:width 1s cubic-bezier(.22,1,.36,1); }

/* menu rows (travel stats / certificate) */
.menu-rows { display:flex; flex-direction:column; gap:10px; margin-top:14px; }
.menu-row { display:flex; align-items:center; gap:13px; width:100%; text-align:left; cursor:pointer;
  padding:13px 15px; border-radius:16px;
  background:linear-gradient(165deg, rgba(255,255,255,.19), rgba(255,255,255,.07)); border:1px solid rgba(255,255,255,.22);
  box-shadow:0 8px 20px var(--shadow), inset 0 1px 0 rgba(255,255,255,.20); transition:.16s; }
.menu-row:hover { background:linear-gradient(165deg, rgba(255,255,255,.26), rgba(255,255,255,.11)); }
.menu-row span { flex:1; font-size:14.5px; font-weight:600; color:var(--ink); }
.menu-ic { width:38px; height:38px; border-radius:11px; flex-shrink:0; display:flex; align-items:center; justify-content:center;
  color:#fbf3df; background:linear-gradient(135deg, var(--accent), var(--accent-d)); box-shadow:0 3px 8px var(--shadow); }

.stat-row { display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; margin-top:14px; }
.stat { background:var(--card); border:1px solid var(--line); border-radius:14px; padding:14px 6px; text-align:center; box-shadow:0 5px 13px var(--shadow); }
.stat-n { font-family:var(--serif); font-size:26px; font-weight:700; color:var(--gold-d); }
.stat-n small { font-size:14px; color:var(--muted); }
.stat-l { font-size:10.5px; color:var(--muted); margin-top:2px; }
.reward-box { display:flex; flex-direction:column; gap:12px; }
.cert-teaser { display:flex; align-items:center; gap:13px; width:100%; cursor:pointer; text-align:left;
  background:linear-gradient(135deg, var(--gold-soft), rgba(199,154,71,.04)); border:1px solid var(--gold);
  border-radius:16px; padding:13px 15px; box-shadow:0 6px 16px var(--shadow); }
.cert-seal { flex-shrink:0; }
.cert-teaser-t { font-family:var(--serif); font-size:16px; font-weight:700; color:var(--gold-d); }
.cert-teaser-s { font-size:11.5px; color:var(--muted); margin-top:2px; }
.lucky-box { background:var(--card); border:1px solid var(--line); border-radius:16px; padding:16px; text-align:center; box-shadow:0 6px 16px var(--shadow); }
.lucky-label { display:flex; align-items:center; justify-content:center; gap:6px; font-size:12px; color:var(--gold-d); font-weight:600; }
.lucky-nums { display:flex; gap:14px; justify-content:center; margin:12px 0 8px; }
.lucky-d { width:58px; height:64px; display:flex; align-items:center; justify-content:center; border-radius:13px;
  font-family:var(--serif); font-size:34px; font-weight:700; color:#43300f;
  background:linear-gradient(135deg,#f0d189,var(--gold) 55%,var(--gold-d)); box-shadow:inset 0 1px 0 rgba(255,255,255,.55), 0 5px 13px var(--shadow); }
.lucky-hint { font-size:11px; color:var(--muted); }
.reward-locked { display:flex; align-items:center; gap:16px; padding:16px; border-radius:18px; }
.rl-text { flex:1; display:flex; gap:9px; align-items:flex-start; font-size:13px; color:var(--muted); line-height:1.5; }
.list2 { display:flex; flex-direction:column; background:var(--card); border:1px solid var(--line); border-radius:16px; overflow:hidden; box-shadow:0 6px 16px var(--shadow); }
.lrow2 { display:flex; align-items:center; gap:13px; padding:14px 16px; color:var(--ink); font-size:14px; border-bottom:1px solid var(--line-soft); }
.lrow2:last-child { border-bottom:none; }
.lrow2 span { flex:1; }
.lrow2 em { font-style:normal; color:var(--muted); font-size:13px; }
.lrow2.danger { color:var(--accent); }

/* ── bottom nav ── */
.bottom-nav { position:absolute; left:0; right:0; bottom:0; height:88px; z-index:40;
  display:flex; align-items:flex-start; justify-content:space-around; padding:10px 8px 0;
  background:linear-gradient(180deg, rgba(247,238,216,0), var(--paper-a) 40%);
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px); border-top:1px solid var(--line); }
.nav-item { flex:1; display:flex; flex-direction:column; align-items:center; gap:4px; background:none; border:none; cursor:pointer;
  color:var(--faint); font:inherit; font-size:10px; font-weight:600; padding-top:6px; transition:color .18s; }
.nav-item.active { color:var(--gold-d); }
.nav-scan { flex:0 0 auto; margin-top:-22px; }
.nav-scan button { width:62px; height:62px; border-radius:50%; border:3px solid var(--paper-a); cursor:pointer;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1px;
  color:#43300f; background:linear-gradient(135deg,#f0d189,var(--gold) 50%,var(--gold-d));
  box-shadow:0 8px 20px rgba(156,114,42,.45), inset 0 1px 0 rgba(255,255,255,.55); }
.nav-scan button span { font-size:9px; font-weight:700; }
.nav-scan button:active { transform:scale(.94); }

/* ── overlays shared ── */
.scan-stage { position:absolute; inset:0; z-index:60; display:flex; flex-direction:column; color:#f6edd9;
  background:linear-gradient(180deg, #2c2317, #191209); }
.scan-x { position:absolute; top:52px; right:16px; z-index:5; width:38px; height:38px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; color:#f6edd9; background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.2); cursor:pointer; }

/* scan camera */
.scan-cam { position:relative; flex:1; margin:54px 0 0; overflow:hidden; }
.reticle { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:200px; height:200px; }
.reticle span { position:absolute; width:34px; height:34px; border:3px solid var(--gold); }
.reticle span:nth-child(1){ top:0; left:0; border-right:none; border-bottom:none; border-radius:10px 0 0 0; }
.reticle span:nth-child(2){ top:0; right:0; border-left:none; border-bottom:none; border-radius:0 10px 0 0; }
.reticle span:nth-child(3){ bottom:0; left:0; border-right:none; border-top:none; border-radius:0 0 0 10px; }
.reticle span:nth-child(4){ bottom:0; right:0; border-left:none; border-top:none; border-radius:0 0 10px 0; }
.scan-line { position:absolute; left:6px; right:6px; height:3px; border-radius:3px; top:6px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent); box-shadow:0 0 12px var(--gold);
  animation:scanline 1.3s ease-in-out infinite; }
@keyframes scanline { 0%{ top:6px } 50%{ top:188px } 100%{ top:6px } }
.gps-overlay { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:16px;
  background:rgba(20,14,6,.62); backdrop-filter:blur(3px); font-size:14px; color:#f6edd9; }
.gps-spin { width:46px; height:46px; border-radius:50%; border:4px solid rgba(255,255,255,.18); border-top-color:var(--gold); animation:spin .8s linear infinite; }
@keyframes spin { to { transform:rotate(360deg); } }
.scan-foot { padding:22px 22px 34px; display:flex; flex-direction:column; gap:13px; align-items:center; }
.scan-guide { font-size:13.5px; color:rgba(246,237,217,.78); text-align:center; line-height:1.5; max-width:280px; }
.scan-foot .btn { max-width:300px; }
.scan-fallback { background:none; border:none; color:var(--gold); font:inherit; font-size:12.5px; text-decoration:underline; cursor:pointer; }

/* unlock celebrate (parchment) */
.scan-stage.celebrate { align-items:center; justify-content:center; color:var(--ink);
  background:radial-gradient(120% 80% at 50% 20%, var(--paper-a), var(--paper-b) 60%, var(--paper-c)); }
.scan-stage.celebrate .scan-x { color:var(--ink); background:var(--card); border-color:var(--line); }
.unlock-card { display:flex; flex-direction:column; align-items:center; text-align:center; padding:0 30px; z-index:2; }
.unlock-medal { position:relative; margin-bottom:22px; animation:pop .6s cubic-bezier(.2,1.3,.4,1) both; }
.unlock-ring { position:absolute; inset:-16px; border-radius:50%; border:2px solid var(--gold); opacity:.5; animation:halo 1.6s ease-out infinite; }
@keyframes pop { 0%{ transform:scale(.3); opacity:0 } 100%{ transform:scale(1); opacity:1 } }
@keyframes halo { 0%{ transform:scale(.9); opacity:.6 } 100%{ transform:scale(1.5); opacity:0 } }
.unlock-title { font-family:var(--serif); font-size:25px; font-weight:700; color:var(--gold-d); }
.unlock-name { font-family:var(--serif); font-size:19px; font-weight:700; margin:6px 0 8px; color:var(--ink); }
.unlock-sub { font-size:13px; color:var(--muted); line-height:1.5; margin-bottom:20px; }
.unlock-count { font-size:13px; color:var(--ink); margin-bottom:14px; }
.unlock-count b { color:var(--gold-d); font-family:var(--serif); font-size:18px; }
.unlock-card .btn { max-width:260px; }
.scan-done-all { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:18px; text-align:center; padding:30px; }
.scan-done-all h2 { font-family:var(--serif); font-size:24px; color:var(--gold-d); margin:0; }
.sparkles { position:absolute; inset:0; pointer-events:none; z-index:1; }
.sparkles span { position:absolute; background:radial-gradient(circle,var(--gold),transparent 70%); border-radius:50%;
  animation:spark 1.6s ease-out infinite; }
@keyframes spark { 0%{ transform:scale(0); opacity:0 } 30%{ opacity:1 } 100%{ transform:scale(1.4) translateY(-20px); opacity:0 } }

/* upload fallback (parchment) */
.sheet-dark { color:var(--ink); background:radial-gradient(120% 80% at 50% 6%, var(--paper-a), var(--paper-b) 62%, var(--paper-c)); }
.sheet-dark .scan-x { color:var(--ink); background:var(--card); border-color:var(--line); }
.upload-wrap { padding:80px 26px 34px; display:flex; flex-direction:column; align-items:center; text-align:center; gap:13px; flex:1; }
.upload-wrap h2 { font-family:var(--serif); font-size:22px; margin:0; color:var(--ink); }
.up-warn, .pending-ic { width:62px; height:62px; border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--gold-d); background:var(--gold-soft); border:1px solid var(--gold); }
.up-body { font-size:13.5px; color:var(--muted); line-height:1.6; margin:0; }
.up-target { display:flex; align-items:center; gap:10px; background:var(--card); border:1px solid var(--line); border-radius:14px; padding:8px 14px 8px 8px; font-size:13px; font-weight:600; box-shadow:0 4px 11px var(--shadow); }
.dropzone { position:relative; width:100%; height:170px; border-radius:16px; border:2px dashed var(--gold);
  background:var(--card); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px;
  color:var(--gold-d); font:inherit; font-size:13px; font-weight:600; cursor:pointer; overflow:hidden; }
.dropzone.filled { border-style:solid; }
.up-hint { font-size:11.5px; color:var(--faint); line-height:1.5; margin:0; }
.upload-wrap .btn { width:100%; margin-top:auto; }
.upload-wrap .btn + .btn { margin-top:0; }

/* ── detail sheet ── */
.detail-sheet { position:absolute; inset:0; z-index:65; background:var(--paper-a); display:flex; flex-direction:column; overflow-y:auto; }
.detail-hero { position:relative; height:300px; flex-shrink:0; }
.detail-glyph { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.7); }
.detail-scrim { position:absolute; inset:0; background:linear-gradient(180deg, rgba(54,36,14,.28) 0%, transparent 32%, rgba(40,26,10,.78) 100%); }
.detail-back { position:absolute; top:52px; left:16px; width:38px; height:38px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  color:#fff; background:rgba(40,26,10,.4); border:1px solid rgba(255,255,255,.25); cursor:pointer; backdrop-filter:blur(6px); }
.detail-no { position:absolute; top:50px; right:18px; font-family:var(--serif); font-size:42px; font-weight:700; color:rgba(255,255,255,.6); text-shadow:0 2px 8px rgba(40,26,10,.5); }
.detail-hero-txt { position:absolute; left:20px; right:20px; bottom:20px; color:#fdf6e6; }
.detail-hero-txt h2 { font-family:var(--serif); font-size:24px; font-weight:700; margin:6px 0 2px; line-height:1.25; text-wrap:pretty; }
.detail-earned { display:inline-flex; align-items:center; gap:5px; font-size:11px; font-weight:600; color:#fff; background:var(--green); padding:4px 10px; border-radius:999px; }
.detail-en { font-size:13px; color:rgba(253,246,230,.75); }
.detail-body { padding:20px; }
.detail-seal-row { display:flex; align-items:center; gap:14px; margin:-46px 0 14px; position:relative; }
.detail-meta { display:flex; gap:16px; margin-bottom:18px; }
.detail-meta span { display:flex; align-items:center; gap:6px; font-size:12.5px; color:var(--muted); }
.detail-h4 { display:flex; align-items:center; gap:8px; font-family:var(--serif); font-size:15px; font-weight:700; color:var(--gold-d); margin:0 0 9px; }
.detail-p { font-size:14px; line-height:1.85; color:var(--ink); margin:0 0 22px; text-wrap:pretty; }
.detail-actions { display:flex; flex-direction:column; gap:11px; }

/* ── success receipt ── */
.cert-stage { position:absolute; inset:0; z-index:60; display:flex; flex-direction:column;
  background:radial-gradient(120% 80% at 50% 6%, var(--paper-a), var(--paper-b) 60%, var(--paper-c)); overflow-y:auto; }
.cert-stage::before { content:''; position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(60% 38% at 16% 8%, rgba(176,140,80,.14), transparent 70%),
    radial-gradient(50% 32% at 92% 4%, rgba(150,108,56,.12), transparent 70%); }
.receipt-scroll { position:relative; padding:70px 22px 34px; display:flex; flex-direction:column; gap:18px; min-height:100%; }
.receipt { position:relative; margin-top:18px; background:#fffdf6; color:var(--ink); border-radius:18px; padding:40px 24px 26px;
  box-shadow:0 22px 50px var(--shadow-d); text-align:center; border:1px solid var(--line); }
.receipt::after { content:''; position:absolute; inset:7px; border:1px solid var(--line-soft); border-radius:12px; pointer-events:none; }
.receipt-check { position:absolute; top:-30px; left:50%; transform:translateX(-50%); width:60px; height:60px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; color:#fff; background:linear-gradient(145deg,#7aa85f,var(--green));
  border:5px solid #fffdf6; box-shadow:0 8px 18px rgba(95,125,73,.4); }
.receipt-title { font-family:var(--serif); font-size:24px; font-weight:700; color:var(--ink); }
.receipt-sub { font-size:12.5px; color:var(--muted); margin-top:4px; }
.receipt-muni { display:flex; align-items:center; justify-content:center; gap:7px; font-size:11px; font-weight:600; color:var(--gold-d); margin-top:12px; }
.receipt-rows { display:flex; flex-direction:column; gap:11px; margin-top:20px; text-align:left; }
.receipt-row { display:flex; align-items:baseline; justify-content:space-between; gap:14px; }
.receipt-lbl { font-size:12px; color:var(--faint); flex-shrink:0; }
.receipt-val { font-size:13.5px; font-weight:700; color:var(--ink); font-family:var(--mono); text-align:right; }
.receipt-perf { position:relative; height:1px; margin:22px -24px 20px; border-top:2px dashed var(--line); }
.receipt-perf .notch { position:absolute; top:50%; width:24px; height:24px; border-radius:50%; background:var(--notch); transform:translateY(-50%); }
.receipt-perf .notch.left { left:-12px; }
.receipt-perf .notch.right { right:-12px; }
.receipt-lucky { background:linear-gradient(135deg, #fbf0d4, #f5e7c8); border:1px solid var(--line); border-radius:14px; padding:15px; }
.receipt-lucky-label { display:flex; align-items:center; justify-content:center; gap:6px; font-size:11.5px; font-weight:600; color:var(--gold-d); }
.receipt-lucky-row { display:flex; gap:14px; justify-content:center; margin:11px 0 7px; }
.receipt-lucky-row span { width:54px; height:60px; display:flex; align-items:center; justify-content:center; border-radius:12px;
  font-family:var(--serif); font-size:32px; font-weight:700; color:#43300f;
  background:linear-gradient(135deg,#f0d189,var(--gold) 55%,var(--gold-d)); box-shadow:inset 0 1px 0 rgba(255,255,255,.55), 0 5px 13px var(--shadow); }
.receipt-lucky-hint { font-size:10.5px; color:var(--faint); }
.receipt-note { display:flex; align-items:center; justify-content:center; gap:7px; font-size:13px; font-weight:700; color:var(--ink); margin-top:20px; }
.receipt-steps { list-style:none; margin:12px 0 0; padding:0; display:flex; flex-direction:column; gap:8px; text-align:left; }
.receipt-steps li { display:flex; align-items:flex-start; gap:9px; font-size:12px; line-height:1.5; color:var(--muted); text-wrap:pretty; }
.receipt-steps li svg { flex-shrink:0; margin-top:2px; color:var(--green); }
.receipt-actions { display:flex; gap:11px; }
.receipt-actions .btn-ghost { background:var(--card); border:1px solid var(--line); color:var(--ink); }

/* ── install prompt ── */
.install-wrap { position:absolute; inset:0; z-index:80; display:flex; align-items:flex-end; background:rgba(40,26,10,.4); backdrop-filter:blur(2px); }
.install-card { margin:0 12px 14px; width:100%; background:var(--card);
  border:1px solid var(--line); border-radius:22px; padding:22px; text-align:center; display:flex; flex-direction:column; align-items:center; gap:8px;
  box-shadow:0 -10px 40px var(--shadow-d); animation:slideup .4s cubic-bezier(.2,1,.3,1) both; }
@keyframes slideup { from { transform:translateY(40px); opacity:0 } to { transform:translateY(0); opacity:1 } }
.install-title { font-family:var(--serif); font-size:18px; font-weight:700; margin-top:4px; color:var(--ink); }
.install-body { font-size:13px; color:var(--muted); line-height:1.5; }
.install-row { display:flex; gap:10px; width:100%; margin-top:8px; }

/* ─── auth screens (login / register) ─────────────────────────────── */
.auth-screen {
  position: absolute; inset: 0; z-index: 5;
  overflow-y: auto; -webkit-overflow-scrolling: touch;
  background:
    radial-gradient(135% 70% at 50% -8%, var(--paper-a) 0%, var(--paper-b) 56%, var(--paper-c) 100%);
}
.auth-screen::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background-image:
    radial-gradient(circle at 20% 16%, rgba(176,140,80,.10), transparent 38%),
    radial-gradient(circle at 86% 84%, rgba(150,108,56,.09), transparent 42%),
    repeating-linear-gradient(92deg, rgba(120,90,50,.022) 0 1px, transparent 1px 4px);
  mix-blend-mode: multiply; opacity: .9;
}

.auth-cover {
  position: relative;
  width: 100%;
  display: flex; flex-direction: column;
  background: linear-gradient(180deg, #ede1c1, #e7d8b6);
  border-bottom: 1px solid rgba(140, 105, 60, .35);
  box-shadow: 0 6px 14px -8px rgba(74, 52, 22, .35);
  flex-shrink: 0;
}
.auth-cover-img {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 8;
  overflow: hidden;
  background: linear-gradient(180deg, #d8c89e, #c9b485);
}
.auth-cover-img img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center 30%;
  filter: sepia(.55) saturate(.7) brightness(1.04) contrast(1.04);
  opacity: .92;
  mix-blend-mode: multiply;
}
.auth-cover-fade {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(247,238,216,0) 55%, rgba(237,225,193,0.85) 100%);
  pointer-events: none;
}
.auth-cover-title {
  padding: 12px 22px 16px;
  text-align: center;
  font-family: var(--serif); color: #6b4824;
  background: linear-gradient(180deg, rgba(247,238,216,0.95), rgba(247,238,216,1));
}
.auth-cover-th { font-size: 20px; font-weight: 600; letter-spacing: .4px; line-height: 1.15; color: #7a5128; }
.auth-cover-headline {
  display: flex; align-items: baseline; justify-content: center; gap: 4px;
  font-size: 30px; font-weight: 700; margin: 4px 0 2px; line-height: 1; color: #6b4824;
}
.auth-cover-headline .cover-num {
  color: var(--accent); font-size: 1.35em; line-height: 1; margin-right: 6px;
  text-shadow: 0 1px 0 rgba(255, 240, 210, .5);
}
.auth-cover-sub { font-size: 14px; color: var(--gold-d); letter-spacing: .3px; margin-top: 2px; }
.auth-cover-en {
  margin-top: 6px; font-family: var(--mono);
  font-size: 10px; letter-spacing: 1.6px; color: rgba(110, 74, 29, .65);
}

.auth-card { position: relative; z-index: 2; padding: 18px 22px 28px; }

.auth-lang-tog {
  position: absolute; top: 14px; right: 18px;
  display: inline-flex; align-items: center; gap: 5px;
  background: var(--card); border: 1px solid var(--line);
  border-radius: 999px; padding: 5px 10px;
  font: inherit; font-size: 11px; font-weight: 600; letter-spacing: .5px;
  color: var(--ink); cursor: pointer;
  box-shadow: 0 2px 5px rgba(120, 90, 50, .08);
}

.auth-divider { display: flex; align-items: center; gap: 9px; margin-top: 4px; }
.auth-divider .auth-orn-line {
  flex: 1; height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold-d) 25%, var(--gold-d) 75%, transparent);
  opacity: .5;
}
.auth-divider .auth-orn-diamond { color: var(--gold-d); font-size: 10px; transform: translateY(-1px); }
.auth-divider-text {
  font-family: var(--mono);
  font-size: 12px; letter-spacing: 4.5px; font-weight: 600;
  color: var(--gold-d); white-space: nowrap;
}

.auth-welcome {
  text-align: center; margin: 10px 0 16px;
  font-family: var(--serif); font-size: 21px; font-weight: 600;
  color: var(--ink);
}

.auth-form { display: flex; flex-direction: column; gap: 11px; margin-top: 4px; }

.auth-field {
  display: flex; align-items: center;
  background: rgba(255, 250, 238, .72);
  border: 1px solid var(--line); border-radius: 14px;
  padding: 11px 14px;
  box-shadow: inset 0 1px 2px rgba(120, 90, 50, .04);
  transition: border-color .15s, box-shadow .15s;
}
.auth-field:focus-within { border-color: var(--gold-d); box-shadow: 0 0 0 3px var(--gold-soft); }
.auth-field-icon { color: var(--muted); margin-right: 10px; display: inline-flex; align-items: center; }
.auth-field input {
  flex: 1; min-width: 0;
  background: transparent; border: none; outline: none;
  font: inherit; font-size: 15px; color: var(--ink);
}
.auth-field input::placeholder { color: var(--faint); opacity: 1; }
.auth-eye {
  background: none; border: none; cursor: pointer; color: var(--muted);
  padding: 4px; margin-left: 4px; display: inline-flex; align-items: center;
}
.auth-eye:hover { color: var(--ink); }

.auth-forgot {
  align-self: flex-end;
  background: none; border: none;
  font: inherit; font-size: 13px;
  color: var(--accent); text-decoration: underline;
  cursor: pointer; padding: 0 2px; margin-top: -2px;
}
.auth-forgot:hover { color: var(--accent-d); }

.auth-error {
  background: rgba(176, 67, 47, .10);
  border: 1px solid rgba(176, 67, 47, .30);
  color: var(--accent-d);
  padding: 9px 12px; border-radius: 10px;
  font-size: 13px; text-align: center;
}

.auth-agree {
  display: flex; align-items: flex-start; gap: 9px;
  font-size: 12.5px; color: var(--muted); line-height: 1.4;
  padding: 2px 2px 0; cursor: pointer;
}
.auth-agree input {
  margin-top: 2px; accent-color: var(--accent);
  width: 16px; height: 16px; flex-shrink: 0;
}

.auth-submit {
  margin-top: 4px; padding: 15px 18px;
  font-size: 17px; letter-spacing: .4px; gap: 12px;
}
.auth-submit img { filter: brightness(2.6) saturate(.4) drop-shadow(0 1px 0 rgba(0,0,0,.2)); }

.auth-or {
  display: flex; align-items: center; gap: 12px;
  margin: 18px 0 12px; color: var(--muted);
}
.auth-or span {
  flex: 1; height: 1px;
  background: linear-gradient(90deg, transparent, var(--line-soft), transparent);
}
.auth-or em {
  font-style: normal; font-family: var(--serif);
  font-size: 13px; color: var(--muted); letter-spacing: 1.5px;
}

.auth-socials {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 9px;
  margin-bottom: 14px;
}
.auth-social {
  display: flex; flex-direction: column; align-items: center; gap: 7px;
  background: var(--card2); border: 1px solid var(--line); border-radius: 14px;
  padding: 12px 4px 11px;
  cursor: pointer; font: inherit; color: var(--ink);
  box-shadow: 0 2px 5px rgba(120, 90, 50, .08);
  transition: transform .12s, box-shadow .15s, background .15s;
}
.auth-social:hover { background: #fdf7e6; box-shadow: 0 4px 9px rgba(120, 90, 50, .14); }
.auth-social:active { transform: scale(.97); }
.auth-social-icon {
  width: 38px; height: 38px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; box-shadow: 0 1px 3px rgba(0, 0, 0, .12);
  background: #fff;
}
.auth-social-line { background: #06C755; color: #fff; font-size: 10px; letter-spacing: .5px; }
.auth-social-fb { background: #1877F2; color: #fff; font-family: Georgia, serif; font-size: 22px; line-height: 1; }
.auth-social-google {
  background: #fff; font-family: Arial, sans-serif;
  font-size: 22px; line-height: 1;
  background-image: linear-gradient(135deg, #EA4335 0%, #FBBC05 40%, #34A853 65%, #4285F4 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}
.auth-social-label { font-size: 10px; line-height: 1.3; color: var(--muted); text-align: center; }
.auth-social-label b { color: var(--ink); font-weight: 600; font-size: 11px; }

.auth-register-link {
  width: 100%;
  display: flex; align-items: center; justify-content: center; gap: 10px;
  background: var(--card); border: 1px solid var(--line); border-radius: 14px;
  padding: 13px 14px;
  font: inherit; font-size: 14.5px; font-weight: 500;
  color: var(--ink); cursor: pointer;
  box-shadow: 0 2px 6px rgba(120, 90, 50, .08);
  transition: background .15s, box-shadow .15s;
}
.auth-register-link:hover { background: var(--card2); box-shadow: 0 4px 10px rgba(120, 90, 50, .14); }
.auth-register-link:active { transform: scale(.98); }

.auth-stamps {
  display: flex; justify-content: space-between; align-items: center;
  padding: 26px 2px 4px; gap: 16px;
}
.vintage-stamp {
  width: 96px; height: 96px;
  opacity: .55;
  filter: drop-shadow(0 1px 0 rgba(255, 250, 238, .5));
  color: var(--accent-d);
}
.vintage-stamp.stamp-ship { transform: rotate(-8deg); }
.vintage-stamp.stamp-temple { transform: rotate(7deg); }

/* ── Redeem QR (user-facing prize redemption) ─────────────────── */
.redeem-card { padding-bottom: 22px; }
.redeem-locked {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  padding: 24px 18px;
  color: var(--muted);
}
.redeem-locked-text { font-size: 13.5px; text-align: center; line-height: 1.45; max-width: 280px; }
.redeem-progress {
  font-family: var(--serif); font-size: 22px; font-weight: 700; color: var(--accent-d);
  background: rgba(176, 67, 47, .08);
  padding: 8px 22px; border-radius: 999px;
  border: 1px solid rgba(176, 67, 47, .25);
}
.redeem-qr {
  display: flex; align-items: center; justify-content: center;
  padding: 14px;
  background: #fbf5e6;
  border: 1px solid var(--line);
  border-radius: 14px;
  margin: 6px 12px 14px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.6), 0 2px 8px rgba(120, 90, 50, .12);
}
.redeem-qr img { display: block; width: 240px; height: 240px; }
.redeem-info { text-align: center; margin: 0 12px 14px; }
.redeem-name {
  font-family: var(--serif); font-size: 17px; font-weight: 700;
  color: var(--ink);
}
.redeem-lucky {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 8px;
  background: var(--gold-soft);
  border: 1px solid var(--gold-d);
  border-radius: 999px;
  padding: 5px 12px;
  font-size: 13px; color: var(--ink);
}
.redeem-lucky b {
  font-family: var(--mono); font-weight: 700;
  color: var(--accent-d); margin-left: 2px;
}
.redeem-steps {
  display: flex; flex-direction: column; gap: 8px;
  padding: 14px 16px 6px;
  margin: 0 6px;
  border-top: 1px dashed var(--line);
}
.redeem-step {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 12.5px; color: var(--muted); line-height: 1.4;
}
.redeem-step span {
  flex-shrink: 0;
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--gold-soft); border: 1px solid var(--gold-d);
  color: var(--accent-d); font-family: var(--serif); font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px;
}
.redeem-done {
  display: flex; flex-direction: column; align-items: center; gap: 14px;
  padding: 20px 16px 8px;
}
.redeem-done-info { text-align: center; font-size: 13px; color: var(--ink); }
.redeem-done-line { margin: 4px 0; }
.redeem-done-line b { color: var(--accent-d); font-family: var(--mono); }

/* profile menu row that's locked (not yet complete) */
.menu-row.menu-row-locked { opacity: .55; }
.menu-row.menu-row-locked:active { opacity: .55; transform: none; }

/* detail gallery (admin-uploaded extra images) */
.detail-gallery {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px;
  margin: 14px 0 8px;
}
.detail-gallery-tile {
  aspect-ratio: 1;
  border-radius: 10px;
  border: 1px solid var(--line);
  box-shadow: 0 2px 5px rgba(120, 90, 50, .12);
}

.profile-logout {
  margin: 16px auto 0;
  display: inline-flex; align-items: center; gap: 8px;
  background: transparent; border: 1px solid var(--line);
  color: var(--muted); padding: 8px 14px;
  border-radius: 999px; font: inherit; font-size: 13px;
  cursor: pointer;
}
.profile-logout:hover { color: var(--accent-d); border-color: var(--accent); }
