:root{--bg:#FFF8F2;--surf:#FFF;--surf2:#FFF2EA;--bdr:#F2E6DC;--bdr2:#DDD0C4;--tx:#2D1B0E;--tx2:#7A5C48;--tx3:#B89A84;--rose:#E8527A;--rose-bg:#FFF0F4;--rose-m:#F06090;--rose-d:#C23A60;--pur:#9B6DD0;--pur-bg:#F5EEFF;--pur-d:#7A4EAD;--mint:#3BAA8C;--mint-bg:#E8F7F2;--mint-d:#2A8A70;--sun:#F5A623;--sun-bg:#FFF5E4;--sun-d:#D4850E;--sky:#4A9FD4;--sky-bg:#EAF4FC;--r:16px;--rs:10px;--rp:99px;--sh:0 1px 8px rgba(232,82,122,.07),0 3px 16px rgba(0,0,0,.04)}
*{box-sizing:border-box;margin:0;padding:0}
html{overflow-x:clip}
body{font-family:"Nunito",sans-serif;background:var(--bg);color:var(--tx);min-height:100vh;display:flex;flex-direction:column;overflow-x:clip}
img{max-width:100%;height:auto}
nav{background:var(--surf);border-bottom:2px solid var(--bdr);padding:0 1.25rem;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;height:60px;position:sticky;top:0;z-index:1001;gap:6px;flex-shrink:0;transition:transform .25s ease}
.nav-mid{display:flex;align-items:center;gap:2px;justify-content:center}
.nav-right-wrap{display:flex;gap:5px;align-items:center;justify-content:flex-end}
.nav-logo{display:flex;align-items:center;gap:8px;cursor:pointer;flex-shrink:0}
.nav-logo-icon{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#F472B6,#E8527A);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.nav-logo-text{font-family:"Playfair Display",serif;font-size:18px;color:var(--tx);font-weight:400;white-space:nowrap}
.nav-logo-text span{color:var(--rose);font-style:italic}
.nav-mid{display:flex;align-items:center;gap:2px}
.btn-nav{background:none;border:none;color:var(--tx2);padding:6px 10px;border-radius:var(--rp);font-family:"Nunito",sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}
.btn-nav:hover{background:var(--rose-bg);color:var(--rose)}
.nav-right{display:flex;gap:5px;align-items:center;flex-shrink:0}
.btn-cta{background:linear-gradient(135deg,var(--rose),#C23A60);color:#fff;border:none;padding:8px 14px;border-radius:var(--rp);font-family:"Nunito",sans-serif;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap}
.btn-cta-ghost{background:var(--rose-bg);color:var(--rose);border:1.5px solid #F9C0D0;padding:7px 12px;border-radius:var(--rp);font-family:"Nunito",sans-serif;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .15s}
.btn-cta-ghost:hover{background:var(--rose);color:#fff}
.todo-nav{background:none;border:2px dashed var(--sun);color:var(--sun-d);padding:6px 10px;border-radius:var(--rp);font-family:"Nunito",sans-serif;font-size:11px;font-weight:700;cursor:not-allowed;white-space:nowrap;opacity:.8}
.page{display:none;flex:1}.page.active{display:block}
.pw{max-width:680px;margin:0 auto;padding:2rem 1.5rem}
.hero-outer{background:var(--bg);overflow:hidden}
.hero-wrap{max-width:680px;margin:0 auto;padding:2.5rem 1.5rem 1.5rem;position:relative}
.hero-deco{position:absolute;top:10px;right:0;width:min(200px,38vw);pointer-events:none}
.hero-tag{display:inline-flex;align-items:center;gap:7px;background:var(--rose-bg);color:var(--rose);font-size:12px;font-weight:700;letter-spacing:.04em;padding:4px 12px;border-radius:var(--rp);margin-bottom:1rem;border:1.5px solid #F9C0D0}
.hero-title{font-family:"Playfair Display",serif;font-size:min(44px,8vw);font-weight:400;line-height:1.1;margin-bottom:.85rem;position:relative;z-index:1}
.hero-title em{font-style:italic;color:var(--rose)}
.hero-sub{font-size:15px;color:var(--tx2);line-height:1.7;max-width:460px;margin-bottom:1.5rem;font-weight:500;position:relative;z-index:1}
.hero-btns{display:flex;flex-direction:column;gap:8px;margin-bottom:1.25rem;position:relative;z-index:1}.hero-btns-row1,.hero-btns-row2{display:flex;gap:8px;flex-wrap:wrap}.hero-btns-row1 .btn-hero,.hero-btns-row1 .btn-hero-ghost{flex:1;min-width:140px}.hero-btns-row2 .btn-hero-ghost{flex:1;min-width:130px}
.btn-hero{background:linear-gradient(135deg,var(--rose),#C23A60);color:#fff;border:none;padding:12px 24px;border-radius:var(--rp);font-family:"Nunito",sans-serif;font-size:14px;font-weight:700;cursor:pointer;box-shadow:0 3px 12px rgba(232,82,122,.35);transition:transform .12s}
.btn-hero:hover{transform:translateY(-1px)}
.btn-hero-ghost{background:var(--surf);color:var(--tx);border:2px solid var(--bdr2);padding:12px 24px;border-radius:var(--rp);font-family:"Nunito",sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:border-color .15s}
.btn-hero-ghost:hover{border-color:var(--rose);color:var(--rose)}
.pioneer-bar{background:linear-gradient(135deg,var(--pur-bg),#fff);border:1.5px solid #C8A8F0;border-radius:var(--r);padding:.85rem 1.1rem;display:flex;align-items:center;gap:12px;margin-bottom:.75rem}
.founder-bar{background:linear-gradient(135deg,var(--mint-bg),#fff);border:1.5px solid #90D4B8;border-radius:var(--r);padding:.85rem 1.1rem;display:flex;align-items:center;gap:12px;margin-bottom:1.25rem;cursor:pointer;transition:opacity .15s}
.founder-bar:hover{opacity:.9}
.founder-bar .pt{font-size:13px;color:var(--mint-d);font-weight:700}
.founder-bar .ps{font-size:11px;color:var(--mint-d);margin-top:2px;opacity:.8}
.founder-bar .pbar{height:6px;background:#B0E8D4;border-radius:3px;margin-top:6px;overflow:hidden}
.founder-bar .pbar-fill{height:100%;background:linear-gradient(90deg,var(--mint),#2A8A70);border-radius:3px;transition:width .6s}
.founder-promo{background:var(--mint-bg);border:1.5px solid #90D4B8;border-radius:var(--rs);padding:.75rem 1rem;font-size:13px;color:var(--mint-d);font-weight:600;margin-bottom:1rem;line-height:1.6;display:none}
.pt{font-size:13px;color:var(--pur-d);font-weight:700}
.ps{font-size:11px;color:var(--pur);margin-top:2px}
.pbar{height:6px;background:#E8D8F8;border-radius:3px;margin-top:6px;overflow:hidden}
.pbar-fill{height:100%;background:linear-gradient(90deg,var(--pur),var(--rose));border-radius:3px;transition:width .6s}
.stats-top-wrap{max-width:680px;margin:0 auto;padding:0 1.5rem .5rem}
.slabel{font-size:11px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--tx3);margin-bottom:.6rem}
.stats-top{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:1rem}
.stat-card{background:var(--surf);border:1.5px solid var(--bdr);border-radius:var(--r);padding:.75rem .9rem;text-align:center;box-shadow:var(--sh)}
.stat-card .n{font-family:"Playfair Display",serif;font-size:24px;font-weight:600;color:var(--rose);line-height:1}
.stat-card .l{font-size:11px;color:var(--tx2);margin-top:3px;font-weight:700}
.stats-banner{background:linear-gradient(135deg,#2D1B0E,#4A2010);padding:1rem 2rem;display:flex;justify-content:center;gap:0;flex-wrap:wrap}
.stat-block{text-align:center;padding:.35rem 1.25rem;border-right:1px solid rgba(255,255,255,.1)}
.stat-block:last-child{border-right:none}
.stat-block .sl{font-size:10px;color:rgba(255,255,255,.35);margin-bottom:2px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.stat-block .n{font-family:"Playfair Display",serif;font-size:20px;font-weight:600;color:rgba(255,255,255,.7);line-height:1}
.stat-block .l{font-size:10px;color:rgba(255,255,255,.35);margin-top:3px;font-weight:700}
.records-wrap{max-width:680px;margin:0 auto;padding:1rem 1.5rem}
.record-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.record-box{border-radius:var(--r);padding:1rem 1.1rem;display:flex;align-items:center;gap:12px;cursor:pointer;transition:opacity .15s}
.record-box:hover{opacity:.9}
.rb-finds{background:linear-gradient(135deg,#1a1030,#3d1f6e)}
.rb-last{background:linear-gradient(135deg,#0d2818,#1a5030)}
.rb-icon{font-size:24px;flex-shrink:0}
.rb-label{font-size:10px;color:rgba(255,255,255,.4);margin-bottom:3px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.rb-name{font-size:13px;font-weight:700;color:#fff;line-height:1.3}
.rb-sub{font-size:11px;margin-top:2px;font-weight:500}
.hp-map-wrap{max-width:680px;margin:0 auto;padding:0 1.5rem 1rem}
.hp-map-title{font-size:11px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--tx3);margin-bottom:.6rem}
.hp-map-container{height:240px;border-radius:var(--r);overflow:hidden;border:1.5px solid var(--bdr);box-shadow:var(--sh);isolation:isolate}
.hp-map-hint{font-size:11px;color:var(--tx3);margin-top:5px;font-weight:500}
.region-bar{max-width:680px;margin:0 auto;padding:.5rem 1.5rem .25rem;display:flex;gap:8px;align-items:center}
.region-bar input{flex:1;padding:8px 12px;border:1.5px solid var(--bdr);border-radius:var(--rp);font-family:"Nunito",sans-serif;font-size:13px;background:var(--surf);color:var(--tx);outline:none;font-weight:500}
.region-bar input:focus{border-color:var(--rose)}
.btn-sm-rose{background:var(--rose-bg);color:var(--rose);border:1.5px solid #F9C0D0;padding:7px 14px;border-radius:var(--rp);font-family:"Nunito",sans-serif;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .15s}
.btn-sm-rose:hover{background:var(--rose);color:#fff}
.btn-sm-gray{background:var(--surf2);color:var(--tx2);border:1.5px solid var(--bdr2);padding:7px 12px;border-radius:var(--rp);font-family:"Nunito",sans-serif;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap}
.stone-card{background:var(--surf);border:1.5px solid var(--bdr);border-radius:var(--r);padding:1rem 1.15rem;margin-bottom:10px;cursor:pointer;transition:box-shadow .15s,transform .12s,border-color .15s;box-shadow:var(--sh)}
.stone-card:hover{border-color:var(--rose-m);box-shadow:0 3px 16px rgba(232,82,122,.12),0 6px 24px rgba(0,0,0,.06);transform:translateY(-1px)}
.sc-top{display:flex;gap:12px;align-items:flex-start}
.sc-icon{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;border:1.5px solid rgba(0,0,0,.06)}
.sc-img{width:52px;height:52px;border-radius:12px;object-fit:cover;flex-shrink:0;border:1.5px solid rgba(0,0,0,.06)}
.sc-main{flex:1;min-width:0}
.sc-name{font-weight:700;font-size:14px;margin-bottom:2px}
.sc-id{font-size:11px;color:var(--tx3);font-family:monospace;letter-spacing:.06em}
.sc-badges{display:flex;gap:4px;margin-top:6px;flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:700;padding:2px 8px;border-radius:var(--rp)}
.b-rose{background:var(--rose-bg);color:var(--rose)}.b-am{background:var(--sun-bg);color:var(--sun-d)}.b-pur{background:var(--pur-bg);color:var(--pur-d)}.b-mint{background:var(--mint-bg);color:var(--mint-d)}.b-sky{background:var(--sky-bg);color:var(--sky)}.b-adopted{background:#F0FFF4;color:#276749}
.sc-footer{display:flex;gap:14px;margin-top:9px;padding-top:9px;border-top:1.5px solid var(--bdr)}
.sc-stat{font-size:12px;color:var(--tx2);font-weight:600}
.sc-stat b{font-weight:800;color:var(--tx)}
.ach-row{display:flex;gap:5px;margin-top:7px;flex-wrap:wrap}
.ach-pill{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:var(--rp);font-size:11px;font-weight:700;border:1.5px solid}
.ap-gold{background:#FFFBEA;color:#92650A;border-color:#F0D060}.ap-silver{background:#F4F4F6;color:#5A5870;border-color:#C0BDD8}.ap-rose{background:var(--rose-bg);color:var(--rose);border-color:#F9C0D0}.ap-mint{background:var(--mint-bg);color:var(--mint-d);border-color:#90D4B8}.ap-sky{background:var(--sky-bg);color:var(--sky);border-color:#90C8E8}.mil-item.earned.pur{background:var(--pur-bg);border-color:#C8A8F0}
.mil-item.earned.worldg{background:linear-gradient(135deg,#2D1B00,#5A3A00);border-color:#C8940A}
.mil-item.earned.worldg .mn{color:#F5D060}
.mil-item.earned.worldg .md{color:#D4A010}
.ap-pur{background:var(--pur-bg);color:var(--pur-d);border-color:#C8A8F0}
.ap-worldg{background:linear-gradient(135deg,#2D1B00,#5A3A00);color:#F5D060;border-color:#C8940A}.ap-bronze{background:#FDF0DC;color:#6A3800;border-color:#C89050}.ap-n1{background:#EAF4FB;color:#1060A0;border-color:#90C8E8}.ap-n2{background:#C8E4F8;color:#0A4A80;border-color:#50A0D8}.ap-n3{background:#90C0E8;color:#062840;border-color:#2070B0}.ap-n4{background:#2870B0;color:#E8F4FF;border-color:#0A4888}.ap-k1{background:#EDFCE8;color:#1A6010;border-color:#70D060}.ap-k2{background:#90D880;color:#0A3808;border-color:#30A020}.ap-k3{background:#228018;color:#D8F8D0;border-color:#0A5008}.ap-c1{background:#F3EEFF;color:#5A30A0;border-color:#C8A8F0}.ap-c2{background:#C8A0F0;color:#200840;border-color:#8050C0}.ap-c3{background:#6030A8;color:#F0E8FF;border-color:#401880}.ap-o-coral{background:#FFF0E8;color:#A03010;border-color:#F0A880}.ap-o-rose{background:#FFF0F4;color:#C23A60;border-color:#F9C0D0}.ap-o-amber{background:#FFF8E0;color:#806000;border-color:#F0C840}.ap-o-teal{background:#E6F7F4;color:#0A5A50;border-color:#60C8B0}.ap-special{background:linear-gradient(135deg,#2D1B00,#5A3A00);color:#F5D060;border-color:#C8940A}
.ap-world{background:#0A0818;color:#C4A0F0;border-color:#9B6DD0}
.sc{background:var(--surf);border:1.5px solid var(--bdr);border-radius:var(--r);padding:1.15rem;box-shadow:var(--sh);margin-bottom:12px}
.sct{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--tx3);margin-bottom:.9rem;display:flex;align-items:center;gap:6px}
.fp,.wp{max-width:680px;margin:0 auto;padding:2rem 1.5rem}
h2.ph{font-family:"Playfair Display",serif;font-size:28px;font-weight:400;margin-bottom:.3rem}
p.sub{font-size:14px;color:var(--tx2);margin-bottom:1.5rem;line-height:1.6;font-weight:500}
.fg{margin-bottom:1rem}
.fl{font-size:13px;font-weight:700;display:block;margin-bottom:5px}
.fh{font-size:11px;color:var(--tx3);margin-top:4px;font-weight:500}
input[type=text],input[type=number],input[type=email],input[type=password],textarea,select{width:100%;padding:10px 13px;border:1.5px solid var(--bdr);border-radius:var(--rs);font-family:"Nunito",sans-serif;font-size:14px;background:var(--surf);color:var(--tx);transition:border-color .15s;outline:none;font-weight:500}
input:focus,textarea:focus,select:focus{border-color:var(--rose)}input:disabled,textarea:disabled,select:disabled{background:var(--surf2)!important;color:var(--tx3)!important;cursor:not-allowed;border-color:var(--bdr)!important}
textarea{resize:vertical;min-height:80px;line-height:1.6}
.photo-area{border:2px dashed var(--bdr2);border-radius:var(--r);padding:1.25rem;text-align:center;cursor:pointer;transition:all .15s;background:var(--surf2);position:relative;overflow:hidden}
.photo-area:hover{border-color:var(--rose);background:var(--rose-bg)}
.photo-area.has-photo{border-color:var(--mint);background:var(--mint-bg);padding:.4rem}
.photo-icon{font-size:28px;margin-bottom:.4rem}
.photo-text{font-size:13px;color:var(--tx2);font-weight:600}
.photo-hint{font-size:11px;color:var(--tx3);margin-top:3px}
.photo-prev{width:100%;max-height:180px;object-fit:contain;border-radius:8px;display:none}
.photo-inp{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.code-hidden{background:var(--surf2);color:var(--tx3);border-radius:var(--rs);padding:12px 16px;font-family:monospace;font-size:20px;letter-spacing:4px;text-align:center;margin:1rem 0;border:2px dashed var(--bdr2)}
.code-show{background:var(--tx);color:#fff;border-radius:var(--rs);padding:12px 16px;font-family:monospace;font-size:20px;letter-spacing:4px;text-align:center;margin:1rem 0}
.ptkm-hint{background:var(--pur-bg);border:1.5px solid #C8A8F0;border-radius:var(--rs);padding:.6rem 1rem;font-size:12px;color:var(--pur-d);font-weight:600;margin-top:.5rem}
.success-card{background:linear-gradient(135deg,var(--mint-bg),#fff);border:1.5px solid #90D4B8;border-radius:var(--r);padding:1.35rem;text-align:center;display:none;margin-top:1rem}
.success-card h3{font-family:"Playfair Display",serif;font-size:21px;font-weight:400;color:var(--mint-d);margin-bottom:.4rem}
.success-card p{font-size:13px;color:#2D6040;line-height:1.6;font-weight:500}
.success-btns{display:flex;gap:8px;margin-top:.9rem;flex-wrap:wrap}
.btn-p{background:linear-gradient(135deg,var(--rose),#C23A60);color:#fff;border:none;padding:11px 22px;border-radius:var(--rp);font-family:"Nunito",sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:opacity .15s;width:100%;box-shadow:0 2px 8px rgba(232,82,122,.3)}
.btn-p:hover{opacity:.9}.btn-p:disabled{opacity:.5;cursor:not-allowed}
.btn-s{background:var(--surf2);color:var(--tx);border:1.5px solid var(--bdr2);padding:10px 20px;border-radius:var(--rp);font-family:"Nunito",sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;flex:1}
.btn-s:hover{border-color:var(--rose);color:var(--rose)}
.btn-g{background:none;border:1.5px solid var(--bdr2);color:var(--tx2);padding:7px 16px;border-radius:var(--rp);font-family:"Nunito",sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:5px}
.btn-g:hover{color:var(--rose);border-color:var(--rose)}
.divider{height:1.5px;background:var(--bdr);margin:1.35rem 0;border-radius:1px}
.loading{text-align:center;padding:2.5rem;color:var(--tx3);font-size:14px;font-weight:600}
.empty-state{text-align:center;padding:2.5rem 1rem;color:var(--tx3)}
.ph-wrap{max-width:680px;margin:0 auto;padding:2rem 1.5rem}
.profile-header{background:var(--surf);border:1.5px solid var(--bdr);border-radius:var(--r);padding:1.35rem;box-shadow:var(--sh);margin-bottom:12px}
.ph-top{display:flex;gap:14px;align-items:flex-start;margin-bottom:1.1rem}
.ph-icon{width:66px;height:66px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:30px;flex-shrink:0;border:1.5px solid rgba(0,0,0,.06)}
.ph-img{width:66px;height:66px;border-radius:14px;object-fit:cover;flex-shrink:0;border:1.5px solid rgba(0,0,0,.06)}
.ph-name{font-family:"Playfair Display",serif;font-size:22px;font-weight:400;margin-bottom:2px}
.ph-code{font-family:monospace;font-size:12px;color:var(--tx3);letter-spacing:.06em;font-weight:600}
.ph-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.ph-stat{background:var(--surf2);border-radius:var(--rs);padding:.65rem;text-align:center;border:1px solid var(--bdr)}
.ph-stat .n{font-family:"Playfair Display",serif;font-size:24px;font-weight:400;color:var(--rose)}
.ph-stat .l{font-size:11px;color:var(--tx2);margin-top:1px;font-weight:700}
.mil-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.mil-item{display:flex;align-items:flex-start;gap:9px;padding:.7rem;border-radius:var(--rs);border:1.5px solid var(--bdr)}
.mil-item.earned.gold{background:#FFFBEA;border-color:#F0D060}.mil-item.earned.gold .mn{color:#7A5000}.mil-item.earned.gold .md{color:#92650A}.mil-item.earned.bronze{background:#FDF0DC;border-color:#C89050}.mil-item.earned.bronze .mn{color:#6A3800}.mil-item.earned.bronze .md{color:#8A5010}.mil-item.earned.silver{background:#F5F4FA;border-color:#C0BDD8}.mil-item.earned.rose{background:var(--rose-bg);border-color:#F9C0D0}.mil-item.earned.mint{background:var(--mint-bg);border-color:#90D4B8}.mil-item.earned.sky{background:var(--sky-bg);border-color:#90C8E8}.mil-item.earned.pink{background:#FEF0F6;border-color:#F0A0CC}.mil-item.earned.pink .mn{color:#A0206A}.mil-item.earned.pink .md{color:#C03080}.mil-item.earned.world{background:#0A0818;border-color:#9B6DD0}
.mil-item.earned.world .mn{color:#C4A0F0}.mil-item.earned.world .md{color:#9B6DD0}
.mil-item.earned.n1{background:#EAF4FB;border-color:#90C8E8}.mil-item.earned.n1 .mn{color:#1060A0}.mil-item.earned.n1 .md{color:#2080C0}
.mil-item.earned.n2{background:#C8E4F8;border-color:#50A0D8}.mil-item.earned.n2 .mn{color:#0A4A80}.mil-item.earned.n2 .md{color:#1060A0}
.mil-item.earned.n3{background:#90C0E8;border-color:#2070B0}.mil-item.earned.n3 .mn{color:#062840}.mil-item.earned.n3 .md{color:#0A3860}
.mil-item.earned.n4{background:#2870B0;border-color:#0A4888}.mil-item.earned.n4 .mn{color:#E8F4FF}.mil-item.earned.n4 .md{color:#B0D8F8}
.mil-item.earned.k1{background:#EDFCE8;border-color:#70D060}.mil-item.earned.k1 .mn{color:#1A6010}.mil-item.earned.k1 .md{color:#2A8020}
.mil-item.earned.k2{background:#90D880;border-color:#30A020}.mil-item.earned.k2 .mn{color:#0A3808}.mil-item.earned.k2 .md{color:#1A5810}
.mil-item.earned.k3{background:#228018;border-color:#0A5008}.mil-item.earned.k3 .mn{color:#D8F8D0}.mil-item.earned.k3 .md{color:#90D080}
.mil-item.earned.c1{background:#F3EEFF;border-color:#C8A8F0}.mil-item.earned.c1 .mn{color:#5A30A0}.mil-item.earned.c1 .md{color:#7B50C0}
.mil-item.earned.c2{background:#C8A0F0;border-color:#8050C0}.mil-item.earned.c2 .mn{color:#200840}.mil-item.earned.c2 .md{color:#401870}
.mil-item.earned.c3{background:#6030A8;border-color:#401880}.mil-item.earned.c3 .mn{color:#F0E8FF}.mil-item.earned.c3 .md{color:#C8A8F0}
.mil-item.earned.o-coral{background:#FFF0E8;border-color:#F0A880}.mil-item.earned.o-coral .mn{color:#A03010}.mil-item.earned.o-coral .md{color:#C04020}
.mil-item.earned.o-rose{background:#FFF0F4;border-color:#F9C0D0}.mil-item.earned.o-rose .mn{color:#C23A60}.mil-item.earned.o-rose .md{color:#E8527A}
.mil-item.earned.o-amber{background:#FFF8E0;border-color:#F0C840}.mil-item.earned.o-amber .mn{color:#806000}.mil-item.earned.o-amber .md{color:#A08000}
.mil-item.earned.o-teal{background:#E6F7F4;border-color:#60C8B0}.mil-item.earned.o-teal .mn{color:#0A5A50}.mil-item.earned.o-teal .md{color:#0A7A6A}
.mil-item.earned.special{background:linear-gradient(135deg,#2D1B00,#5A3A00);border-color:#C8940A}.mil-item.earned.special .mn{color:#F5D060}.mil-item.earned.special .md{color:#D4A010}
.mi{font-size:20px;flex-shrink:0}.mn{font-size:13px;font-weight:700;margin-bottom:1px}.md{font-size:11px;color:var(--tx2);line-height:1.4;font-weight:500}
.mil-item.locked .mi{filter:grayscale(1);opacity:.35}.mil-item.locked .mn,.mil-item.locked .md{color:var(--tx3)}
.map-c{height:220px;border-radius:var(--rs);overflow:hidden;border:1.5px solid var(--bdr);isolation:isolate}
.tl-item{display:flex;gap:11px;padding:.6rem 0;border-bottom:1.5px solid var(--bdr)}
.tl-item:last-child{border-bottom:none}
.tl-dot-w{flex-shrink:0;padding-top:5px}
.tl-dot{width:8px;height:8px;border-radius:50%}
.dot-rose{background:var(--rose)}.dot-blue{background:var(--sky)}.dot-pur{background:var(--pur)}
.tl-event{font-size:13px;font-weight:700}
.tl-meta{font-size:11px;color:var(--tx2);margin-top:2px;line-height:1.5;font-weight:500}
.tl-msg{font-size:12px;color:var(--tx2);font-style:italic;margin-top:4px;padding:5px 10px;background:var(--surf2);border-radius:var(--rs);border-left:2px solid var(--rose-m)}
.tl-photo{width:100%;max-height:160px;object-fit:cover;border-radius:var(--rs);margin-top:5px}
.tl-disp{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:700;padding:2px 8px;border-radius:var(--rp);margin-top:4px}
.disp-moved{background:var(--mint-bg);color:var(--mint-d)}.disp-thinking{background:var(--sun-bg);color:var(--sun-d)}.disp-keeping{background:var(--rose-bg);color:var(--rose)}
.geo-status{font-size:12px;margin-top:5px;padding:5px 10px;border-radius:var(--rs);font-weight:600}
.geo-ok{background:var(--mint-bg);color:var(--mint-d)}.geo-err{background:var(--rose-bg);color:var(--rose)}.geo-loading{background:var(--surf2);color:var(--tx2)}
.story-text{font-size:14px;color:var(--tx2);line-height:1.75;font-style:italic;border-left:2px solid var(--rose-m);padding-left:12px;margin-bottom:8px;font-weight:500}
.todo-s{border:2px dashed var(--sun);border-radius:var(--r);padding:1rem 1.15rem;position:relative;background:var(--sun-bg);margin-bottom:12px}
.todo-b{position:absolute;top:-12px;left:14px;background:var(--sun);color:#fff;font-size:11px;font-weight:800;padding:2px 10px;border-radius:var(--rp);letter-spacing:.04em}
.todo-i{font-size:13px;color:var(--sun-d);line-height:1.6;font-weight:500}
.todo-i b{font-weight:800;display:block;margin-bottom:3px;font-size:13px}
.preview-s{border:2px dashed var(--pur);border-radius:var(--r);padding:.85rem 1.1rem;position:relative;background:var(--pur-bg);margin-bottom:12px}
.preview-b{position:absolute;top:-12px;left:14px;background:var(--pur);color:#fff;font-size:11px;font-weight:800;padding:2px 10px;border-radius:var(--rp);letter-spacing:.04em}
.like-btn{display:flex;align-items:center;gap:8px;background:none;border:1.5px solid var(--bdr);padding:8px 16px;border-radius:var(--rp);cursor:pointer;font-family:"Nunito",sans-serif;font-size:14px;font-weight:600;color:var(--tx2);transition:all .15s}
.like-btn:hover{border-color:var(--rose);color:var(--rose)}
.like-btn.liked{background:var(--rose-bg);border-color:var(--rose);color:var(--rose)}
.comment-item{padding:.65rem 0;border-bottom:1.5px solid rgba(155,109,208,.15)}
.comment-item:last-child{border-bottom:none}
.comment-author{font-size:13px;font-weight:700;color:var(--pur-d)}
.comment-text{font-size:13px;color:var(--tx2);margin-top:2px;line-height:1.55;font-weight:500}
.comment-date{font-size:11px;color:var(--tx3);font-weight:500;margin-left:8px}
.reply-btn{background:none;border:none;font-size:11px;color:var(--tx3);cursor:pointer;font-family:"Nunito",sans-serif;font-weight:700;padding:3px 0;margin-top:3px;transition:color .15s}
.reply-btn:hover{color:var(--pur-d)}
.replies{margin-top:.5rem;padding-left:.85rem;border-left:2px solid #C8A8F0}
.reply-item{padding:.4rem 0;border-bottom:1px solid rgba(155,109,208,.1)}
.reply-item:last-child{border-bottom:none}
.reply-item .comment-author{font-size:12px}
.reply-item .comment-text{font-size:12px}
.reply-form{margin-top:.5rem;background:rgba(155,109,208,.06);border-radius:var(--rs);padding:.65rem;border:1px solid #C8A8F0}
.sc-comments{background:linear-gradient(135deg,#F8F2FF,var(--surf));border-color:#C8A8F0!important}
.qr-wrap{display:flex;flex-direction:column;align-items:center;gap:.65rem}
.qr-box{background:#fff;padding:10px;border-radius:var(--rs);border:1.5px solid var(--bdr)}
.warn-box{background:#FFF8E1;border:1.5px solid #FFD54F;border-radius:var(--rs);padding:.65rem .9rem;font-size:12px;color:#8B6914;font-weight:600;margin-bottom:.65rem;display:none}
.lb-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:1.25rem}
.lb-section-head{font-size:14px;font-weight:800;color:var(--tx2);margin:.75rem 0 .6rem;padding-bottom:.4rem;border-bottom:2px solid var(--bdr)}
.lb-placeholder{opacity:.45;border-style:dashed!important}
.lb-item{display:flex;align-items:center;gap:9px;padding:.55rem 0;border-bottom:1.5px solid var(--bdr);cursor:pointer}
.lb-item:last-child{border-bottom:none}
.lb-item:hover .lb-name{color:var(--rose)}
.lb-rank{font-family:"Playfair Display",serif;font-size:18px;font-weight:600;color:var(--tx3);width:24px;text-align:center;flex-shrink:0}
.lb-rank.gold{color:#92650A}.lb-rank.silver{color:#5A5870}.lb-rank.bronze{color:#8B4513}
.lb-info{flex:1;min-width:0}
.lb-name{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .15s}
.lb-sub{font-size:11px;color:var(--tx2);font-weight:500}
.lb-val{font-size:13px;font-weight:800;color:var(--rose);flex-shrink:0}
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--tx);color:#fff;padding:10px 20px;border-radius:var(--rp);font-size:13px;z-index:999;opacity:0;transition:opacity .3s;pointer-events:none;white-space:nowrap;font-weight:600}
.toast.show{opacity:1}
.ach-popup{position:fixed;bottom:20px;right:16px;background:var(--surf);border:1.5px solid #F0D060;border-radius:var(--r);padding:.9rem 1.1rem;box-shadow:0 6px 24px rgba(0,0,0,.12);z-index:998;opacity:0;transform:translateY(12px);transition:opacity .4s,transform .4s;pointer-events:none;max-width:260px}
.ach-popup.show{opacity:1;transform:translateY(0)}
.ach-popup-tag{font-size:10px;font-weight:800;letter-spacing:.08em;color:#92650A;text-transform:uppercase;margin-bottom:3px}
.ach-popup-title{font-size:14px;font-weight:700;margin-bottom:2px}
.ach-popup-desc{font-size:12px;color:var(--tx2);font-weight:500}
.map-scroll-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,.6);color:#fff;padding:6px 14px;border-radius:var(--rp);font-size:13px;font-weight:600;pointer-events:none;opacity:0;transition:opacity .2s;z-index:1000;white-space:nowrap}
.map-scroll-hint.show{opacity:1}
.feed-pagination{display:flex;align-items:center;justify-content:center;gap:4px;padding:1rem 0 .5rem;flex-wrap:wrap}
.pg-btn{background:var(--surf);border:1.5px solid var(--bdr);color:var(--tx2);font-family:"Nunito",sans-serif;font-size:13px;font-weight:700;padding:6px 12px;border-radius:var(--rp);cursor:pointer;transition:all .15s;min-width:36px}
.pg-btn:hover:not(:disabled){border-color:var(--rose);color:var(--rose);background:var(--rose-bg)}
.pg-btn.pg-active{background:var(--rose);border-color:var(--rose);color:#fff;cursor:default}
.pg-btn:disabled{opacity:.35;cursor:default}
.pg-btn.pg-more{border-style:dashed;color:var(--tx3)}
.pg-btn.pg-arrow{padding:6px 10px}
.pg-ellipsis{font-size:13px;color:var(--tx3);padding:0 2px;line-height:36px}
.feed-load-more{display:block;width:100%;margin-top:.5rem;padding:10px;background:var(--surf2);border:1.5px dashed var(--bdr2);border-radius:var(--r);font-family:"Nunito",sans-serif;font-size:13px;font-weight:700;color:var(--tx2);cursor:pointer;transition:all .15s;text-align:center}
.feed-load-more:hover{border-color:var(--rose);color:var(--rose);background:var(--rose-bg)}
.feed-load-more:disabled{opacity:.5;cursor:wait}
.act-badge{font-size:10px!important;padding:2px 7px!important;white-space:nowrap}
.act-new{background:#FFF0F4;color:var(--rose)}
.act-found{background:var(--mint-bg);color:var(--mint-d)}
.act-adopted{background:var(--pur-bg);color:var(--pur-d)}
.act-keeping{background:var(--rose-bg);color:var(--rose)}
.act-thinking{background:var(--sun-bg);color:var(--sun-d)}
footer{background:var(--tx);color:rgba(255,255,255,.45);padding:1.75rem 1.5rem;text-align:center;font-size:13px;line-height:1.7;font-weight:500;flex-shrink:0;margin-top:auto}
footer .flogo{font-family:"Playfair Display",serif;font-size:17px;color:rgba(255,255,255,.75);margin-bottom:.6rem}
footer .flogo span{color:#F9A0B8;font-style:italic}
footer a{color:rgba(255,255,255,.55);text-decoration:underline}
input[type=checkbox]{width:auto;accent-color:var(--rose)}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px;border-radius:var(--rs);transition:background .15s;flex-shrink:0}
.hamburger:hover{background:var(--surf2)}
.hamburger span{display:block;width:22px;height:2px;background:var(--tx);border-radius:2px;transition:all .25s;margin:5px 0}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none;position:fixed;top:60px;left:0;right:0;background:var(--surf);border-bottom:2px solid var(--bdr);z-index:1000;padding:.75rem 1.25rem 1rem;box-shadow:0 8px 24px rgba(0,0,0,.1);overscroll-behavior:contain;max-height:calc(100vh - 60px);overflow-y:auto}
.mobile-menu.open{display:block}
.mm-item{display:flex;align-items:center;gap:10px;width:100%;padding:.75rem .9rem;border-radius:var(--rs);font-family:"Nunito",sans-serif;font-size:15px;font-weight:600;color:var(--tx2);background:none;border:none;cursor:pointer;text-align:left;transition:background .15s}
.mm-item:hover{background:var(--surf2);color:var(--rose)}
.mm-item:active{background:var(--rose-bg)}
.mm-sep{height:1.5px;background:var(--bdr);margin:.4rem 0}
.mm-item.mm-primary{background:linear-gradient(135deg,var(--rose),#C23A60);color:#fff;margin-top:.4rem;justify-content:center;font-size:15px;font-weight:700;box-shadow:0 2px 8px rgba(232,82,122,.3)}
.mm-item.mm-primary:hover{opacity:.9;color:#fff}
.mm-item.mm-todo{color:var(--sun-d);opacity:.8;cursor:not-allowed;border:1.5px dashed var(--sun);background:var(--sun-bg)}
.mm-item.mm-todo:hover{background:var(--sun-bg);color:var(--sun-d)}
.mm-item.mm-ghost{border:1.5px solid #F9C0D0;background:var(--rose-bg);color:var(--rose);justify-content:center;margin-top:.25rem}
@media(max-width:640px){
  nav{padding:0 .75rem}
  nav{display:flex}
  #nav-right-wrap{margin-left:auto}
  .nav-mid{display:none}
  .nav-right-wrap .todo-nav,.nav-right-wrap .btn-cta,.nav-right-wrap .nav-user{display:none!important}
  .hamburger{display:block}
  #mob-auth{display:flex!important}
  .hero-wrap{padding:2rem 1rem 1.25rem}
  .hero-title{font-size:32px}
  .hero-btns-row1 .btn-hero,.hero-btns-row1 .btn-hero-ghost,.hero-btns-row2 .btn-hero-ghost{padding:11px 16px;font-size:13px}
  .stats-top{grid-template-columns:repeat(2,1fr);gap:6px}
  .stats-top-wrap{padding:0 1rem .5rem}
  .records-wrap{padding:1rem}
  .record-row{grid-template-columns:1fr}
  .hp-map-wrap{padding:0 1rem 1rem}
  .pw{padding:1.5rem 1rem}
  .fp,.wp,.ph-wrap{padding:1.5rem 1rem}
  .lb-grid{grid-template-columns:1fr}
  .lb-section-head{font-size:13px}
  .mil-grid{grid-template-columns:1fr}
  .ph-stats{grid-template-columns:repeat(3,1fr)}
  .success-btns{flex-direction:column}
  .stats-banner{padding:.75rem 1rem}
  .stat-block{padding:.3rem .75rem}
}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:9999;display:none;align-items:center;justify-content:center;padding:1rem;cursor:pointer}
.lightbox.open{display:flex}
.lightbox img{max-width:100%;max-height:90vh;border-radius:var(--rs);box-shadow:0 8px 40px rgba(0,0,0,.5);object-fit:contain;cursor:default}
.lightbox-close{position:absolute;top:16px;right:20px;color:#fff;font-size:36px;cursor:pointer;line-height:1;opacity:.75;font-weight:300}
.lightbox-close:hover{opacity:1}
.tl-photo{cursor:zoom-in}
/* AUTH */
.auth-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:1000;display:none;align-items:center;justify-content:center;padding:1rem}
.auth-overlay.open{display:flex}
.auth-box{background:var(--surf);border-radius:var(--r);width:100%;max-width:420px;padding:1.75rem;box-shadow:0 8px 40px rgba(0,0,0,.18);position:relative;max-height:90vh;overflow-y:auto}
.auth-close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:22px;cursor:pointer;color:var(--tx3);line-height:1}
.auth-close:hover{color:var(--tx)}
.auth-tabs{display:flex;border-bottom:2px solid var(--bdr);margin-bottom:1.35rem}
.auth-tab{flex:1;background:none;border:none;padding:.65rem;font-family:"Nunito",sans-serif;font-size:14px;font-weight:700;color:var(--tx3);cursor:pointer;border-bottom:2.5px solid transparent;margin-bottom:-2px;transition:all .15s}
.auth-tab.active{color:var(--rose);border-bottom-color:var(--rose)}
.auth-head{font-family:"Playfair Display",serif;font-size:22px;font-weight:400;margin-bottom:.35rem}
.auth-sub{font-size:13px;color:var(--tx2);margin-bottom:1.25rem;font-weight:500;line-height:1.5}
.btn-google{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px;border:2px solid var(--bdr2);border-radius:var(--rp);background:var(--surf);font-family:"Nunito",sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:border-color .15s;margin-bottom:1rem}
.btn-google:hover{border-color:var(--sky)}
.btn-google img{width:20px;height:20px}
.auth-or{text-align:center;font-size:12px;color:var(--tx3);font-weight:600;margin:.75rem 0;position:relative}
.auth-or::before,.auth-or::after{content:'';position:absolute;top:50%;width:42%;height:1px;background:var(--bdr)}
.auth-or::before{left:0}.auth-or::after{right:0}
.auth-err{background:var(--rose-bg);border:1.5px solid #F9C0D0;border-radius:var(--rs);padding:.6rem .9rem;font-size:13px;color:var(--rose);font-weight:600;margin-bottom:.75rem;display:none}
.auth-ok{background:var(--mint-bg);border:1.5px solid #90D4B8;border-radius:var(--rs);padding:.6rem .9rem;font-size:13px;color:var(--mint-d);font-weight:600;margin-bottom:.75rem;display:none}
.username-check{font-size:11px;margin-top:4px;font-weight:600}.uc-warn{color:var(--sun-d)}
.uc-ok{color:var(--mint-d)}.uc-err{color:var(--rose)}.uc-loading{color:var(--tx3)}
/* NAV USER */
.nav-user{position:relative;display:flex;align-items:center;gap:8px;cursor:pointer;padding:6px 10px;border-radius:var(--rp);transition:background .15s}
.nav-user:hover{background:var(--surf2)}
.nav-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--rose),#C23A60);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0}
.nav-uname{font-size:13px;font-weight:700;color:var(--tx)}
.user-dd{position:absolute;top:calc(100% + 6px);right:0;background:var(--surf);border:1.5px solid var(--bdr);border-radius:var(--r);box-shadow:0 4px 20px rgba(0,0,0,.1);min-width:160px;z-index:300;display:none;overflow:hidden}
.user-dd.open{display:block}
.dd-item{display:flex;align-items:center;gap:8px;width:100%;padding:.65rem 1rem;background:none;border:none;font-family:"Nunito",sans-serif;font-size:13px;font-weight:600;color:var(--tx2);cursor:pointer;text-align:left;transition:background .15s}
.dd-item:hover{background:var(--surf2);color:var(--rose)}
.dd-sep{height:1px;background:var(--bdr);margin:4px 0}
/* USERNAME MODAL */
.uname-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:1100;display:none;align-items:center;justify-content:center;padding:1rem}
.uname-overlay.open{display:flex}
.uname-box{background:var(--surf);border-radius:var(--r);width:100%;max-width:380px;padding:1.75rem;box-shadow:0 8px 40px rgba(0,0,0,.2)}
/* PROFILE ME */
.profile-me-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:1rem}
.tab-bar{display:flex;border-bottom:2px solid var(--bdr);margin-bottom:1rem}
.tab-btn{flex:1;background:none;border:none;padding:.6rem;font-family:"Nunito",sans-serif;font-size:13px;font-weight:700;color:var(--tx3);cursor:pointer;border-bottom:2.5px solid transparent;margin-bottom:-2px;transition:all .15s}
.tab-btn.active{color:var(--rose);border-bottom-color:var(--rose)}
.btn-gps{display:inline-flex;align-items:center;gap:5px;background:var(--sky-bg);border:1.5px solid #90C8E8;color:var(--sky);padding:9px 12px;border-radius:var(--rs);font-family:"Nunito",sans-serif;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .15s}
.btn-gps:hover{background:var(--sky);color:#fff}.btn-gps:disabled{opacity:.55;cursor:wait}
.city-row{display:flex;gap:8px;align-items:flex-start}.city-row input{flex:1}
