:root{--primary: #FFB3BA;--primary-dark: #FF8E9E;--pink-dark: #FF6B8A;--secondary: #BAFFC9;--accent: #BAE1FF;--gold: #FFD700;--bg-main: #FFF5EE;--text-primary: #333;--text-secondary: #666;--card-bg: rgba(255, 255, 255, .85);--card-shadow: 0 2px 8px rgba(0, 0, 0, .06);--shadow-soft: 0 2px 10px rgba(0, 0, 0, .08);--shadow-pop: 0 4px 15px rgba(255, 179, 186, .4);--border-radius: 14px;--radius: 16px;--radius-sm: 10px;--radius-xs: 6px}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{font-family:Nunito,sans-serif;background:var(--bg-main);color:var(--text-primary);overflow:hidden;user-select:none;-webkit-user-select:none;touch-action:manipulation}#app{max-width:480px;margin:0 auto;height:100dvh;display:flex;flex-direction:column;background:linear-gradient(180deg,#fff5ee,#ffe4e1);position:relative}#game-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:linear-gradient(135deg,var(--primary),#FFDDE1);border-radius:0 0 var(--radius) var(--radius);box-shadow:var(--shadow-pop);z-index:10;min-height:48px}.level-badge{background:linear-gradient(135deg,#ff6b6b,#ff8e8e);color:#fff;padding:4px 12px;border-radius:20px;font-weight:800;font-size:14px;box-shadow:0 2px 6px #ff6b6b66}.coin-display{font-size:20px;font-weight:900;color:#b8860b;text-shadow:0 1px 2px rgba(0,0,0,.1)}.auto-income{font-size:12px;font-weight:700;color:#55a630;background:#ffffffb3;padding:2px 8px;border-radius:10px}#canvas-wrapper{flex:1;position:relative;overflow:hidden;min-height:200px}#game-canvas{width:100%;height:100%;display:block;cursor:pointer}.tab-content-overlay{position:absolute;bottom:54px;left:0;right:0;max-height:60%;overflow-y:auto;background:var(--card-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius) var(--radius) 0 0;box-shadow:0 -4px 20px #00000014;z-index:20;padding:16px;transition:transform .3s ease,opacity .3s ease}.tab-content-overlay.hidden{transform:translateY(100%);opacity:0;pointer-events:none}.tab-content-inner{animation:fadeIn .3s ease}.section-title{font-size:18px;font-weight:800;margin-bottom:8px;color:var(--text-primary)}.section-subtitle{font-size:13px;color:var(--text-secondary);margin-bottom:16px}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.gacha-section{text-align:center}.gacha-cost{font-size:14px;font-weight:700;color:var(--text-secondary);margin-top:10px}.puni-btn{border:none;padding:12px 32px;border-radius:30px;font-size:16px;font-weight:800;font-family:Nunito,sans-serif;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.puni-btn:active{transform:scale(.95)}.puni-btn-primary{background:linear-gradient(135deg,#4ecdc4,#44b3a8);color:#fff;box-shadow:0 4px 12px #4ecdc466}.puni-btn-gacha{background:linear-gradient(135deg,#ff6b6b,#ff8e53);color:#fff;padding:16px 48px;font-size:20px;box-shadow:0 4px 15px #ff6b6b66}.puni-btn-gacha:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%) rotate(45deg)}to{transform:translate(100%) rotate(45deg)}}.collection-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:8px 0}.collection-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;background:var(--card-bg);border-radius:var(--radius-sm);box-shadow:var(--card-shadow)}.collection-item.locked{opacity:.4;filter:grayscale(80%)}.char-preview{border-radius:50%;background:#00000008}.char-name{font-size:11px;font-weight:700;text-align:center}.rarity-stars{display:flex;gap:1px}.star{font-size:10px}.star.filled{color:var(--gold)}.star.empty{color:#ddd}.ranking-list{display:flex;flex-direction:column;gap:6px}.ranking-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--card-bg);border-radius:var(--radius-sm);box-shadow:var(--card-shadow)}.ranking-rank{font-weight:800;font-size:16px;min-width:30px;text-align:center}.ranking-rank.gold{color:gold}.ranking-rank.silver{color:silver}.ranking-rank.bronze{color:#cd7f32}.ranking-name{flex:1;font-weight:600;font-size:14px}.ranking-score{font-weight:700;font-size:13px;color:#b8860b}.town-info{display:flex;gap:10px;margin-bottom:16px}.town-stat{flex:1;display:flex;flex-direction:column;align-items:center;padding:10px 8px;background:var(--card-bg);border-radius:var(--radius-sm);box-shadow:var(--card-shadow)}.town-stat-label{font-size:10px;font-weight:600;color:var(--text-secondary)}.town-stat-value{font-size:16px;font-weight:800;margin-top:4px}.upgrade-section{display:flex;flex-direction:column;gap:8px}.upgrade-item{display:flex;align-items:center;justify-content:space-between;background:var(--card-bg);padding:12px 14px;border-radius:var(--radius-sm);box-shadow:var(--card-shadow)}.upgrade-info{display:flex;flex-direction:column;gap:2px}.upgrade-name{font-weight:700;font-size:14px}.upgrade-desc{font-size:11px;color:var(--text-secondary)}.upgrade-cost{font-size:12px;font-weight:700;color:#b8860b}.tab-bar{display:flex;justify-content:space-around;align-items:center;padding:6px 8px;padding-bottom:max(6px,env(safe-area-inset-bottom));background:#fff;border-top:1px solid rgba(0,0,0,.05);box-shadow:0 -2px 10px #0000000d;z-index:30}.tab-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 12px;border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;font-family:Nunito,sans-serif}.tab-btn.active{background:linear-gradient(135deg,#ffb3ba4d,#baffc94d);transform:scale(1.05)}.tab-icon{font-size:20px}.tab-label{font-size:10px;font-weight:700;color:var(--text-secondary)}.tab-btn.active .tab-label{color:var(--text-primary)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;transition:opacity .3s ease}.modal-overlay.hidden{opacity:0;pointer-events:none}.modal-content{background:#fff;border-radius:var(--radius);padding:24px;text-align:center;box-shadow:0 10px 40px #0003;animation:popIn .4s cubic-bezier(.68,-.55,.265,1.55);max-width:300px;width:90%}@keyframes popIn{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.modal-close-btn{background:linear-gradient(135deg,#ff6b6b,#ff8e53);color:#fff;border:none;padding:10px 30px;border-radius:25px;font-size:14px;font-weight:800;font-family:Nunito,sans-serif;cursor:pointer;margin-top:12px;transition:transform .2s}.modal-close-btn:active{transform:scale(.95)}.tab-content-overlay::-webkit-scrollbar{width:4px}.tab-content-overlay::-webkit-scrollbar-track{background:transparent}.tab-content-overlay::-webkit-scrollbar-thumb{background:#0000001a;border-radius:2px}
