:root{--bg-1: #ffeef2;--bg-2: #ede1ff;--bg-3: #d9f3ff;--card: #ffffff;--card-soft: #faf7ff;--fg: #1f1b3a;--fg-soft: #4a4670;--muted: #8b87a8;--brand: #8b5cf6;--brand-2: #ec4899;--brand-3: #f59e0b;--accent: #06b6d4;--good: #10b981;--warn: #f59e0b;--danger: #ef4444;--radius: 22px;--radius-sm: 14px;--shadow-sm: 0 2px 8px rgba(80, 50, 140, .08);--shadow: 0 8px 28px rgba(120, 70, 200, .14);--shadow-lg: 0 20px 50px rgba(120, 70, 200, .18);--gradient: linear-gradient(135deg, #8b5cf6 0%, #ec4899 50%, #f59e0b 100%);--gradient-soft: linear-gradient(135deg, #ffeef2 0%, #ede1ff 50%, #d9f3ff 100%)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:radial-gradient(900px 500px at -10% -10%,rgba(236,72,153,.2) 0%,transparent 60%),radial-gradient(900px 600px at 110% 10%,rgba(139,92,246,.18) 0%,transparent 60%),radial-gradient(700px 500px at 50% 110%,rgba(6,182,212,.15) 0%,transparent 60%),var(--gradient-soft);background-attachment:fixed;color:var(--fg);font-family:Nunito,Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;overscroll-behavior:none}.app-shell{display:flex;flex-direction:column;height:100dvh}.app-main{flex:1;overflow:auto;padding-bottom:88px}.center{display:grid;place-items:center;height:100%;color:var(--muted)}.page{padding:20px 18px;max-width:720px;margin:0 auto}.page h1{margin:8px 0 18px;font-size:26px;font-weight:800;letter-spacing:-.01em;background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.page h2{margin:20px 0 10px;font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:700}.card{background:var(--card);border:1px solid rgba(139,92,246,.08);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.card+.card{margin-top:14px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 18px;border-radius:999px;border:none;background:var(--gradient);color:#fff;font-weight:700;font-size:15px;cursor:pointer;width:100%;box-shadow:0 8px 20px #ec489952;transition:transform .15s ease,box-shadow .15s ease}.btn:hover{transform:translateY(-1px);box-shadow:0 12px 24px #ec48996b}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}.btn.secondary{background:#fff;color:var(--fg);border:1.5px solid rgba(139,92,246,.22);box-shadow:var(--shadow-sm)}.btn.ghost{background:transparent;color:var(--fg-soft);box-shadow:none}.btn.danger{background:linear-gradient(135deg,#ef4444,#f97316);box-shadow:0 8px 20px #ef444452}.btn-row{display:flex;gap:10px}.btn-row .btn{flex:1}.input,.select{width:100%;background:var(--card-soft);border:1.5px solid rgba(139,92,246,.15);color:var(--fg);padding:14px 16px;border-radius:var(--radius-sm);font-size:15px;font-family:inherit;transition:border-color .15s ease,box-shadow .15s ease}.input:focus,.select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px #8b5cf626}label{display:block;font-size:12px;color:var(--fg-soft);font-weight:700;margin:12px 0 6px;text-transform:uppercase;letter-spacing:.05em}.row{display:flex;align-items:center;gap:12px}.row.between{justify-content:space-between}.pill{font-size:11px;padding:5px 10px;border-radius:999px;background:#8b5cf61f;color:var(--brand);border:1px solid rgba(139,92,246,.25);font-weight:700}.pill.good{background:#10b9811f;color:var(--good);border-color:#10b9814d}.pill.warn{background:#f59e0b26;color:var(--warn);border-color:#f59e0b59}.nav{position:fixed;bottom:0;left:0;right:0;display:grid;grid-template-columns:repeat(5,1fr);background:#ffffffeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(139,92,246,.1);padding:10px env(safe-area-inset-right) calc(10px + env(safe-area-inset-bottom)) env(safe-area-inset-left);z-index:30;box-shadow:0 -8px 30px #7846c814}.nav a{display:flex;flex-direction:column;align-items:center;gap:2px;text-decoration:none;color:var(--muted);font-size:11px;font-weight:700;padding:6px 0;border-radius:12px;transition:color .15s ease,transform .15s ease}.nav a.active{color:var(--brand);transform:translateY(-2px)}.nav a.active .ico{transform:scale(1.15)}.nav .ico{font-size:22px;transition:transform .18s ease}.login{display:grid;place-items:center;min-height:100dvh;padding:24px;text-align:center}.login .logo-img{width:240px;height:240px;object-fit:contain;background:transparent;margin-bottom:8px;filter:drop-shadow(0 12px 28px rgba(124,58,237,.25));animation:float 6s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes pulseDot{0%{box-shadow:0 0 #ffffffb3}70%{box-shadow:0 0 0 8px #fff0}to{box-shadow:0 0 #fff0}}.login h1{font-size:38px;margin:0 0 6px;font-weight:900;letter-spacing:-.02em;background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.login .tagline{color:var(--fg-soft);margin:0 0 28px;font-size:16px;font-weight:600}.login .card{max-width:380px;width:100%;text-align:left}.login .signin-btn{max-width:360px;background:#fff;color:var(--fg);border:1.5px solid rgba(139,92,246,.18);box-shadow:var(--shadow)}.login .signin-btn:hover{box-shadow:var(--shadow-lg)}.login .signin-btn .g-icon{width:22px;height:22px}.login .footnote{color:var(--muted);font-size:12px;margin-top:28px;max-width:320px;font-weight:600}.map-wrap{position:relative;height:100%}.map-overlay{position:absolute;left:14px;right:14px;top:14px;display:flex;gap:10px;justify-content:space-between;z-index:5}.map-card{background:#fffffff2;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-radius:999px;padding:10px 16px;border:1px solid rgba(139,92,246,.12);font-size:13px;font-weight:700;color:var(--fg);box-shadow:var(--shadow-sm)}.share-toggle{background:#fff;color:var(--fg);width:auto;padding:10px 16px;border-radius:999px;border:1.5px solid rgba(139,92,246,.18);font-weight:700;font-size:13px;cursor:pointer;box-shadow:var(--shadow-sm)}.share-toggle.on{background:var(--gradient);color:#fff;border-color:transparent;box-shadow:0 6px 16px #ec489952}.share-toggle.small{padding:6px 12px;font-size:11px}.share-toggle:disabled{opacity:.5;cursor:not-allowed}.share-stack{display:flex;flex-direction:column;gap:6px;align-items:flex-end}.modal.tutorial{max-width:460px;padding:22px}.tutorial-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.tutorial-icon{font-size:36px;background:var(--gradient-soft);width:56px;height:56px;border-radius:16px;display:grid;place-items:center}.tutorial-dots{display:flex;gap:6px}.tutorial-dots .dot{width:8px;height:8px;border-radius:50%;background:#8b5cf633;transition:all .2s}.tutorial-dots .dot.active{background:var(--brand);width:22px;border-radius:4px}.tutorial-dots .dot.done{background:var(--brand-2)}.tutorial-body{font-size:14px;line-height:1.5;color:var(--fg-soft);max-height:50vh;overflow-y:auto}.tutorial-body ol,.tutorial-body ul{padding-left:20px;margin:8px 0}.tutorial-body li{margin-bottom:6px}.tutorial-body code{background:#8b5cf614;padding:1px 6px;border-radius:4px;font-size:12px}.tutorial-body a{color:var(--brand);font-weight:700}.tutorial-body .muted.small{font-size:12px;color:var(--muted)}.chip-inline{display:inline-block;padding:1px 8px;border-radius:999px;background:#8b5cf61f;color:var(--brand);font-weight:700;font-size:12px}.tutorial-skip{position:absolute;top:12px;right:14px;background:none;border:none;color:var(--muted);cursor:pointer;font-size:12px;font-weight:700}.tutorial-skip:hover{color:var(--fg)}.modal.tutorial{position:relative}.avatar{width:140px;height:140px;border-radius:50%;background:linear-gradient(135deg,#ffd9a8,#ffb38a);display:grid;place-items:center;margin:0 auto;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}.avatar svg{width:100%;height:100%}.swatches{display:flex;flex-wrap:wrap;gap:10px}.swatch{width:40px;height:40px;border-radius:14px;border:3px solid transparent;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .15s ease}.swatch:hover{transform:scale(1.06)}.swatch.active{border-color:var(--brand);transform:scale(1.08)}.avatar-page{padding-bottom:32px}.avatar-preview{border-radius:28px;padding:16px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;box-shadow:var(--shadow-lg);min-height:240px}.tab-bar{display:flex;gap:6px;overflow-x:auto;padding:4px 0 8px;margin-bottom:8px;scrollbar-width:none}.tab-bar::-webkit-scrollbar{display:none}.tab{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 14px;border-radius:16px;border:2px solid transparent;background:var(--card);color:var(--fg);font-size:12px;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .15s ease,border-color .15s ease}.tab .tab-icon{font-size:20px;line-height:1}.tab.active{border-color:var(--brand);transform:translateY(-2px)}.editor-card h3{margin:14px 0 8px;font-size:14px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.editor-card h3:first-child{margin-top:0}.chip-row{display:flex;flex-wrap:wrap;gap:8px}.chip{padding:8px 14px;border-radius:999px;border:2px solid transparent;background:#8b5cf614;color:var(--fg);font-weight:600;font-size:13px;cursor:pointer;transition:all .15s ease}.chip:hover{background:#8b5cf62e}.chip.active{background:var(--brand);color:#fff;border-color:var(--brand)}.chip.locked{opacity:.5;cursor:not-allowed}.layer-toggle{display:flex;gap:6px;flex-wrap:wrap}.fab{position:absolute;right:18px;bottom:18px;width:60px;height:60px;border-radius:50%;border:none;background:linear-gradient(135deg,#ec4899,#8b5cf6);color:#fff;font-size:32px;font-weight:300;line-height:1;cursor:pointer;box-shadow:0 8px 24px #8b5cf673;z-index:5;transition:transform .15s ease}.fab:hover{transform:scale(1.06)}.fab:disabled{opacity:.5;cursor:not-allowed}.fab.active{background:linear-gradient(135deg,#22c55e,#0ea5e9);box-shadow:0 8px 24px #22c55e80}.drop-banner{position:absolute;left:50%;transform:translate(-50%);bottom:92px;z-index:6;background:#0f0c20eb;color:#fff;padding:10px 14px;border-radius:999px;display:flex;align-items:center;gap:10px;font-size:13px;font-weight:600;box-shadow:0 8px 24px #0000004d;max-width:92vw}.drop-banner .chip{background:#ffffff26;color:#fff;padding:6px 12px;font-size:12px}.drop-banner .chip.active{background:#22c55e}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f0c208c;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--card);border-radius:var(--radius);padding:20px;width:100%;max-width:420px;box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto}.modal h2{margin-bottom:8px}.modal label{display:block;margin-top:10px;font-size:12px;font-weight:600;color:var(--muted)}.badge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.badge{background:var(--card);border-radius:var(--radius);padding:16px 12px;text-align:center;border:1px solid rgba(139,92,246,.08);box-shadow:var(--shadow-sm);transition:transform .15s ease}.badge:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.badge .ico{font-size:36px}.badge.locked{opacity:.4;filter:grayscale(1)}.badge .name{font-size:13px;margin-top:6px;font-weight:800;color:var(--fg)}.list{display:flex;flex-direction:column;gap:10px}.list-item{display:flex;align-items:center;gap:12px;background:var(--card);padding:14px;border-radius:var(--radius);border:1px solid rgba(139,92,246,.08);box-shadow:var(--shadow-sm)}.list-item .avatar-mini{width:44px;height:44px;border-radius:50%;background:var(--gradient);display:grid;place-items:center;font-weight:800;color:#fff;font-size:16px;box-shadow:0 4px 12px #ec489947}.empty{color:var(--muted);text-align:center;padding:28px 16px;font-weight:600}.error{color:var(--danger);font-size:13px;font-weight:600}
