*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none}
:root{
  --wood-dark:#5C3A1E;--wood-mid:#8B5E3C;--wood-light:#C4956A;
  --gold:#F5C842;--gold-dark:#D4A017;
  --cream:#FFF8E7;--warm-bg:#2D1B0E;
  --red:#C0392B;--red-light:#E74C3C;
  --green:#27AE60;--green-dark:#1E8449;
  --scene-h:100%;
}
html,body{height:100%;overflow:hidden;font-family:'Zen Maru Gothic',sans-serif;background:#0D0805}
#app{width:100%;max-width:430px;height:100%;margin:0 auto;position:relative;overflow:hidden;background:var(--warm-bg)}

/* ========== HEADER ========== */
.header{position:absolute;top:0;left:0;right:0;z-index:100;padding:12px 16px 10px;
  background:linear-gradient(180deg,rgba(45,27,14,0.97) 0%,rgba(45,27,14,0.8) 70%,transparent 100%);
  display:flex;justify-content:space-between;align-items:center}
.shop-name{font-size:17px;font-weight:900;color:var(--gold);text-shadow:0 2px 8px rgba(245,200,66,0.3);letter-spacing:2px}
.coin-display{display:flex;align-items:center;gap:6px;background:rgba(0,0,0,0.5);
  padding:6px 14px;border-radius:20px;border:1px solid rgba(212,160,23,0.5)}
.coin-icon{font-size:18px}
.coin-amount{font-size:17px;font-weight:700;color:var(--gold);min-width:36px;text-align:right}

/* ========== WELCOME ========== */
.welcome{position:absolute;inset:0;z-index:500;
  background:linear-gradient(180deg,#0D0805 0%,#1a0f07 20%,#2D1B0E 50%,#3D2817 80%,#2D1B0E 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px}
.welcome-title{font-size:30px;font-weight:900;color:var(--gold);margin-bottom:8px;
  text-shadow:0 0 20px rgba(245,200,66,0.3),0 3px 8px rgba(0,0,0,0.5);letter-spacing:4px}
.welcome-sub{font-size:14px;color:var(--wood-light);margin-bottom:40px;letter-spacing:1px}
.welcome-icon{font-size:72px;margin-bottom:28px;animation:welcomeBounce 2s ease-in-out infinite;
  filter:drop-shadow(0 8px 16px rgba(0,0,0,0.4))}
@keyframes welcomeBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.welcome-btn{background:linear-gradient(180deg,#E74C3C,#C0392B);color:#fff;
  border:none;padding:18px 56px;border-radius:16px;font-family:inherit;font-size:18px;
  font-weight:900;cursor:pointer;box-shadow:0 6px 24px rgba(192,57,43,0.5),0 0 40px rgba(231,76,60,0.2);
  transition:transform 0.15s;letter-spacing:2px}
.welcome-btn:active{transform:scale(0.95)}

/* ========== SCENE ========== */
.scene{position:absolute;top:0;left:0;right:0;bottom:0;overflow:hidden}
.scene-bg{position:absolute;inset:0;
  background:linear-gradient(180deg,#0D0805 0%,#1a0f07 8%,#261509 18%,#3D2817 35%,#4A3020 50%,#3D2817 65%,#2D1B0E 85%,#1a0f07 100%)}

/* Warm ambient glow */
.scene::after{content:'';position:absolute;top:0;left:0;right:0;height:50%;z-index:1;pointer-events:none;
  background:radial-gradient(ellipse at 50% 30%,rgba(255,107,53,0.08) 0%,transparent 70%);
  animation:ambientGlow 4s ease-in-out infinite alternate}
@keyframes ambientGlow{0%{opacity:0.7}100%{opacity:1}}

/* Lanterns */
.lantern{position:absolute;top:2%;width:8.5%;height:auto;aspect-ratio:3/4;z-index:5}
.lantern-body{width:100%;height:100%;background:radial-gradient(ellipse at center,#FF8C42,#FF6B35,#C0392B);
  border-radius:50% 50% 45% 45%;box-shadow:0 0 24px rgba(255,107,53,0.5),0 0 48px rgba(255,107,53,0.2);position:relative;
  animation:lanternSway 5s ease-in-out infinite}
.lantern-body::before{content:'酒';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  color:rgba(255,248,231,0.9);font-size:min(14px,3.5vw);font-weight:900}
.lantern-body::after{content:'';position:absolute;bottom:-15%;left:50%;transform:translateX(-50%);
  width:22%;height:18%;background:#C0392B;border-radius:0 0 50% 50%}
.lantern-string{position:absolute;top:-25%;left:50%;width:2px;height:25%;background:#6B4226;transform:translateX(-50%)}
.l1{left:12%;animation-delay:0s}
.l2{left:50%;transform:translateX(-50%);animation-delay:-1.7s}
.l3{right:12%;animation-delay:-3.4s}
@keyframes lanternSway{0%,100%{transform:rotate(-1deg)}50%{transform:rotate(1deg)}}

/* Beams */
.beam{position:absolute;height:8px;background:linear-gradient(180deg,#7B4E2D,#5C3A1E,#4A2F18);
  left:0;right:0;z-index:4;box-shadow:0 3px 8px rgba(0,0,0,0.5)}
.beam-top{top:8.5%}

/* Noren */
.noren{position:absolute;top:9.5%;left:0;right:0;display:flex;justify-content:center;gap:1%;z-index:6}
.noren-piece{width:22%;height:6%;background:linear-gradient(180deg,#B22222,#C0392B,#E74C3C);
  border-radius:0 0 10px 10px;box-shadow:0 3px 8px rgba(0,0,0,0.3);position:relative;
  animation:norenSway 6s ease-in-out infinite}
.noren-piece:nth-child(1){animation-delay:0s}
.noren-piece:nth-child(2){animation-delay:-1.5s}
.noren-piece:nth-child(3){animation-delay:-3s}
.noren-piece:nth-child(4){animation-delay:-4.5s}
@keyframes norenSway{0%,100%{transform:skewX(0deg)}25%{transform:skewX(0.5deg)}75%{transform:skewX(-0.5deg)}}
.noren-piece::after{content:'';position:absolute;bottom:0;left:0;right:0;height:30%;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,0.15))}

/* Wall decoration - Menu board */
.wall-deco{position:absolute;top:10%;right:5%;width:14%;height:8%;z-index:3;
  background:linear-gradient(180deg,#4A2F18,#3D2414);border:2px solid #6B4226;border-radius:3px;
  box-shadow:0 2px 8px rgba(0,0,0,0.4);display:flex;align-items:center;justify-content:center;
  color:var(--cream);font-size:min(10px,2.5vw);font-weight:700;letter-spacing:1px;writing-mode:vertical-rl}

/* Shelf */
.shelf{position:absolute;top:16%;left:2.5%;right:2.5%;height:7%;
  background:linear-gradient(180deg,#7B4E2D 0%,#5C3A1E 100%);
  border-radius:3px;z-index:3;box-shadow:0 4px 12px rgba(0,0,0,0.5)}
.shelf::before{content:'';position:absolute;top:-2px;left:0;right:0;height:2px;
  background:linear-gradient(90deg,#8B5E3C,#A67C00,#8B5E3C)}
.shelf::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:4px;
  background:#3D2414;border-radius:0 0 3px 3px}
.bottles{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;justify-content:space-around;
  align-items:flex-end;padding:0 5% 10%}
.bottle{width:3.5%;border-radius:4px 4px 2px 2px;position:relative}
.bottle-green{height:70%;background:linear-gradient(135deg,#1B5E20,#4CAF50,#1B5E20);opacity:0.9}
.bottle-brown{height:60%;background:linear-gradient(135deg,#4E342E,#8D6E63,#4E342E);opacity:0.9}
.bottle-clear{height:55%;background:linear-gradient(135deg,rgba(200,200,200,0.4),rgba(255,255,255,0.6),rgba(200,200,200,0.4))}
.bottle::before{content:'';position:absolute;top:-20%;left:50%;transform:translateX(-50%);
  width:55%;height:25%;background:inherit;border-radius:2px 2px 0 0}

/* Counter */
.counter{position:absolute;top:24%;left:0;right:0;height:5%;z-index:10;
  background:linear-gradient(180deg,#A67C00,#8B6914,#7A5A0A);
  box-shadow:0 4px 16px rgba(0,0,0,0.6),inset 0 1px 0 rgba(255,255,255,0.15)}
.counter::before{content:'';position:absolute;top:-3px;left:0;right:0;height:3px;
  background:linear-gradient(90deg,#C4956A,#D4A017,#C4956A)}
.counter::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:6px;
  background:linear-gradient(180deg,rgba(0,0,0,0.4),transparent)}

/* Counter items */
.counter-items{position:absolute;top:24%;left:0;right:0;height:5%;z-index:11;
  display:flex;justify-content:center;align-items:center;gap:2%;padding:0 3%}
.counter-item{font-size:min(22px,5.5vw);filter:drop-shadow(0 2px 3px rgba(0,0,0,0.4));
  animation:menuBob 3s ease-in-out infinite;cursor:default}
.counter-item:nth-child(2){animation-delay:-0.5s}
.counter-item:nth-child(3){animation-delay:-1s}
.counter-item:nth-child(4){animation-delay:-1.5s}
.counter-item:nth-child(5){animation-delay:-2s}
.counter-item:nth-child(6){animation-delay:-2.5s}
@keyframes menuBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-2px)}}

/* Floor */
.floor{position:absolute;top:29%;left:0;right:0;bottom:14%;z-index:1;
  background:linear-gradient(180deg,#3D2817 0%,#2D1B0E 20%,#241509 60%,#1a0f07 100%)}
.floor-pattern{position:absolute;inset:0;
  background:repeating-linear-gradient(90deg,transparent,transparent 19%,rgba(0,0,0,0.08) 19%,rgba(0,0,0,0.08) 20%)}

/* Tatami texture hint */
.floor::before{content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,transparent,transparent 49%,rgba(139,94,60,0.03) 49%,rgba(139,94,60,0.03) 50%);
  background-size:100% 20px}

/* Tables */
.table-area{position:absolute;top:29%;left:0;right:0;bottom:14%;z-index:2}
.table{position:absolute;width:78%;left:11%;height:3.5%;
  background:linear-gradient(180deg,#8B5E3C,#7B4E2D,#6B4226);border-radius:4px;
  box-shadow:0 3px 8px rgba(0,0,0,0.5),inset 0 1px 0 rgba(255,255,255,0.08)}
.table::before,.table::after{content:'';position:absolute;bottom:-130%;width:6px;height:130%;
  background:linear-gradient(180deg,#5C3A1E,#4A2F18);border-radius:0 0 2px 2px}
.table::before{left:14%}
.table::after{right:14%}
.table1{top:28%}.table2{top:62%}

/* Characters */
.char-slot{position:absolute;z-index:20;cursor:pointer;transition:all 0.3s ease;pointer-events:all}
.char-slot:active{transform:scale(0.9) !important}
.char-img{width:100%;height:100%;object-fit:contain;
  filter:drop-shadow(0 4px 8px rgba(0,0,0,0.5))}
.char-slot.entering{animation:charEnter 0.8s ease-out}
.char-slot.leaving{animation:charLeave 0.6s ease-in forwards}
@keyframes charEnter{0%{opacity:0;transform:translateY(20px) scale(0.7)}
  50%{opacity:1;transform:translateY(-8px) scale(1.05)}100%{transform:translateY(0) scale(1)}}
@keyframes charLeave{0%{opacity:1;transform:scale(1)}
  100%{opacity:0;transform:translateY(-30px) scale(0.7)}}
.char-slot.eating .char-img{animation:charEat 2s ease-in-out infinite}
@keyframes charEat{0%,100%{transform:rotate(0deg) translateY(0)}
  25%{transform:rotate(-2deg) translateY(-1px)}
  75%{transform:rotate(2deg) translateY(-1px)}}

/* Speech bubble */
.char-bubble{position:absolute;top:-36px;left:50%;transform:translateX(-50%);
  background:rgba(255,248,231,0.95);color:var(--wood-dark);font-size:11px;font-weight:700;
  padding:5px 12px;border-radius:12px;white-space:nowrap;pointer-events:none;
  box-shadow:0 2px 8px rgba(0,0,0,0.3);animation:bubbleIn 0.4s ease;z-index:30}
.char-bubble::after{content:'';position:absolute;bottom:-5px;left:50%;transform:translateX(-50%);
  border-left:5px solid transparent;border-right:5px solid transparent;
  border-top:6px solid rgba(255,248,231,0.95)}
@keyframes bubbleIn{0%{opacity:0;transform:translateX(-50%) translateY(5px) scale(0.8)}100%{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}}

/* Coin animations */
.coin-drop{position:absolute;z-index:50;font-size:24px;pointer-events:none;
  animation:coinDrop 1.2s ease-out forwards}
@keyframes coinDrop{0%{opacity:1;transform:translateY(0) scale(1)}
  40%{opacity:1;transform:translateY(-35px) scale(1.3)}
  100%{opacity:0;transform:translateY(-70px) scale(0.6)}}
.coin-text{position:absolute;z-index:51;font-size:15px;font-weight:900;color:var(--gold);
  pointer-events:none;animation:coinTextUp 1.4s ease-out forwards;white-space:nowrap;
  text-shadow:0 1px 4px rgba(0,0,0,0.8),0 0 8px rgba(245,200,66,0.4)}
@keyframes coinTextUp{0%{opacity:1;transform:translateY(0)}100%{opacity:0;transform:translateY(-60px)}}

/* Bottom bar */
.bottom-bar{position:absolute;bottom:0;left:0;right:0;z-index:100;
  background:linear-gradient(180deg,transparent 0%,rgba(13,8,5,0.7) 15%,rgba(13,8,5,0.95) 100%);
  padding:16px 14px 18px;display:flex;flex-direction:column;gap:8px}
.menu-btn-row{display:flex;gap:8px}
.btn{flex:1;padding:11px 6px;border:none;border-radius:12px;font-family:inherit;font-size:13px;
  font-weight:700;cursor:pointer;transition:all 0.15s;position:relative;overflow:hidden;letter-spacing:0.5px}
.btn:active{transform:scale(0.95)}
.btn-primary{background:linear-gradient(180deg,#E74C3C,#C0392B,#A93226);color:#fff;
  box-shadow:0 4px 16px rgba(192,57,43,0.4),inset 0 1px 0 rgba(255,255,255,0.2)}
.btn-secondary{background:linear-gradient(180deg,#8B5E3C,#6B4226,#5C3A1E);color:var(--cream);
  box-shadow:0 4px 12px rgba(0,0,0,0.3),inset 0 1px 0 rgba(255,255,255,0.1)}
.btn-gold{background:linear-gradient(180deg,#F5C842,#D4A017,#B8860B);color:var(--wood-dark);
  box-shadow:0 4px 16px rgba(245,200,66,0.4),inset 0 1px 0 rgba(255,255,255,0.3)}
.nav-row{display:flex;gap:8px}

/* Modal */
.modal-overlay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,0.75);
  display:flex;align-items:center;justify-content:center;padding:16px;
  opacity:0;pointer-events:none;transition:opacity 0.25s;backdrop-filter:blur(2px)}
.modal-overlay.active{opacity:1;pointer-events:all}
.modal{background:linear-gradient(180deg,#FFF8E7,#F5E6C8,#EDD9B5);border-radius:20px;
  padding:22px 18px;max-width:360px;width:100%;max-height:78vh;overflow-y:auto;
  box-shadow:0 20px 60px rgba(0,0,0,0.6),0 0 0 3px var(--wood-mid);
  transform:scale(0.9);transition:transform 0.3s cubic-bezier(0.34,1.56,0.64,1)}
.modal-overlay.active .modal{transform:scale(1)}
.modal-title{font-size:19px;font-weight:900;color:var(--wood-dark);text-align:center;
  margin-bottom:14px;padding-bottom:10px;border-bottom:2px dashed var(--wood-light)}

/* Character detail */
.char-detail{text-align:center}
.char-detail-img{width:110px;height:110px;margin:0 auto 10px;object-fit:contain;
  filter:drop-shadow(0 6px 12px rgba(0,0,0,0.3));animation:charDetailBounce 2s ease-in-out infinite}
@keyframes charDetailBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.char-detail-name{font-size:22px;font-weight:900;color:var(--wood-dark);margin-bottom:2px}
.char-detail-type{font-size:12px;color:var(--wood-mid);margin-bottom:10px}
.char-detail-desc{font-size:13px;color:#5C3A1E;line-height:1.7;margin-bottom:12px;
  background:rgba(139,94,60,0.08);padding:12px;border-radius:12px;text-align:left}
.char-detail-favs{display:flex;justify-content:center;gap:20px;margin-bottom:8px}
.char-detail-fav{display:flex;flex-direction:column;align-items:center;gap:4px}
.char-detail-fav-icon{font-size:30px}
.char-detail-fav-name{font-size:11px;color:var(--wood-mid);font-weight:700}
.char-rarity{display:inline-block;padding:3px 12px;border-radius:12px;font-size:11px;font-weight:700;margin-bottom:10px}
.rarity-high{background:#E8F5E9;color:#2E7D32}
.rarity-mid{background:#FFF3E0;color:#E65100}
.rarity-rare{background:linear-gradient(135deg,#FCE4EC,#F8BBD0);color:#C62828;box-shadow:0 0 8px rgba(198,40,40,0.2)}
.visit-count{font-size:12px;color:var(--wood-mid);margin-top:6px}

/* Menu selection */
.menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.menu-item{background:#fff;border-radius:12px;padding:12px 8px;text-align:center;cursor:pointer;
  border:2px solid #E8DDD0;transition:all 0.2s;position:relative}
.menu-item:active{transform:scale(0.95)}
.menu-item.selected{border-color:var(--red);background:#FFF0F0;box-shadow:0 0 12px rgba(192,57,43,0.15)}
.menu-item.locked{opacity:0.4;pointer-events:none;filter:grayscale(1)}
.menu-item-icon{font-size:32px;margin-bottom:4px}
.menu-item-name{font-size:13px;font-weight:700;color:var(--wood-dark)}
.menu-item-cost{font-size:11px;color:var(--gold-dark);margin-top:2px}
.menu-item-check{position:absolute;top:6px;right:6px;width:20px;height:20px;
  background:var(--red);border-radius:50%;color:#fff;font-size:12px;
  display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity 0.2s}
.menu-item.selected .menu-item-check{opacity:1}

/* Zukan */
.zukan-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:4px}
.zukan-card{background:#fff;border-radius:14px;padding:12px 8px;text-align:center;
  cursor:pointer;transition:all 0.2s;border:2px solid #E8DDD0;position:relative}
.zukan-card:active{transform:scale(0.95)}
.zukan-card.undiscovered{background:#E0D6C8;border-color:#C4B5A0}
.zukan-img{width:64px;height:64px;margin:0 auto 6px;object-fit:contain}
.zukan-img.silhouette{filter:brightness(0) opacity(0.25)}
.zukan-name{font-size:13px;font-weight:700;color:var(--wood-dark)}
.zukan-card.undiscovered .zukan-name{color:#A09080}
.zukan-visits{font-size:11px;color:var(--wood-mid);margin-top:2px}
.zukan-new{position:absolute;top:-6px;right:-6px;background:var(--red);color:#fff;
  font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;
  animation:pulse 1.5s ease-in-out infinite;box-shadow:0 2px 6px rgba(192,57,43,0.3)}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}

/* Shop */
.shop-grid{display:grid;grid-template-columns:1fr;gap:8px}
.shop-item{background:#fff;border-radius:12px;padding:12px;display:flex;align-items:center;gap:10px;
  cursor:pointer;transition:all 0.2s;border:2px solid #E8DDD0}
.shop-item:active{transform:scale(0.97)}
.shop-item.purchased{opacity:0.45;border-color:#D5CCBE}
.shop-item-icon{font-size:30px;flex-shrink:0;width:40px;text-align:center}
.shop-item-info{flex:1;text-align:left}
.shop-item-name{font-size:14px;font-weight:700;color:var(--wood-dark)}
.shop-item-desc{font-size:11px;color:var(--wood-mid);margin-top:2px;line-height:1.4}
.shop-item-cost{display:flex;align-items:center;gap:4px;font-size:14px;font-weight:700;
  color:var(--gold-dark);flex-shrink:0}
.shop-item-owned{font-size:12px;color:var(--green);font-weight:700}

/* Notification */
.notification{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:300;
  background:rgba(26,15,7,0.96);color:var(--cream);padding:16px 28px;border-radius:16px;
  font-size:15px;font-weight:700;text-align:center;
  box-shadow:0 12px 40px rgba(0,0,0,0.6),0 0 0 2px var(--gold-dark);
  animation:notifIn 0.3s ease,notifOut 0.3s ease 1.7s forwards;
  pointer-events:none;max-width:300px;line-height:1.5}
@keyframes notifIn{0%{opacity:0;transform:translate(-50%,-50%) scale(0.7)}
  100%{opacity:1;transform:translate(-50%,-50%) scale(1)}}
@keyframes notifOut{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}
  100%{opacity:0;transform:translate(-50%,-50%) scale(0.7)}}

/* Sparkle */
.sparkle{position:absolute;z-index:25;pointer-events:none;font-size:18px;
  animation:sparkle 1s ease-out forwards}
@keyframes sparkle{0%{opacity:1;transform:scale(0) rotate(0deg)}
  40%{opacity:1;transform:scale(1.3) rotate(180deg)}
  100%{opacity:0;transform:scale(0.3) rotate(360deg)}}

/* Status */
.status-badge{position:absolute;top:52px;left:50%;transform:translateX(-50%);z-index:90;
  background:rgba(0,0,0,0.65);color:var(--cream);padding:4px 14px;border-radius:12px;
  font-size:11px;font-weight:700;opacity:0;transition:opacity 0.3s;pointer-events:none}
.status-badge.show{opacity:1}

/* Visitor count indicator */
.visitor-count{position:absolute;top:48px;right:16px;z-index:100;
  font-size:11px;color:rgba(196,149,106,0.6);font-weight:700}

/* Scrollbar */
.modal::-webkit-scrollbar{width:5px}
.modal::-webkit-scrollbar-track{background:transparent}
.modal::-webkit-scrollbar-thumb{background:var(--wood-light);border-radius:3px}

/* Safe area for iPhone notch */
@supports(padding: env(safe-area-inset-bottom)){
  .bottom-bar{padding-bottom:calc(18px + env(safe-area-inset-bottom))}
  .header{padding-top:calc(12px + env(safe-area-inset-top))}
}
