*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
:root {
  --sky-day: #87CEEB;
  --sky-eve: #ff8c69;
  --sky-night: #0a0a2e;
  --green: #5cb85c;
  --dark-green: #3d8b3d;
  --brown: #8b5e3c;
  --gold: #ffd700;
  --font-title: 'Fredoka One', cursive;
  --font-ui: 'Comfortaa', cursive;
}
html, body { touch-action: none;  width:100%; height:100%; overflow:hidden; font-family:var(--font-ui); touch-action:none; }
#game-container { position:relative; width:100%; height:100%; overflow:hidden; }
#gameCanvas { position:absolute; top:0; left:0; display:block; }

/* START */
.screen { position:absolute; top:0;left:0;width:100%;height:100%; display:none;
  flex-direction:column; align-items:center; justify-content:center;
  background:linear-gradient(180deg,var(--sky-day),#c8f0c0); z-index:100; padding:20px; gap:10px; }
.screen.active { display:flex; }
.game-thumbnail {
  border-radius: 14px;
  border: 3px solid var(--green);
  box-shadow: 0 8px 30px rgba(0,100,0,0.3);
  max-width: 320px;
  width: 90%;
  aspect-ratio: 16/9;
  object-fit: cover;
}
.game-title { font-family:var(--font-title); font-size:clamp(2.5rem,10vw,4rem); color:#2d6a0a;
  text-shadow:2px 2px 0 #1a3d00; }
.game-sub { font-size:1.1rem; color:#4a7c3f; font-weight:700; }
.start-stats { display:flex; gap:14px; margin:6px 0; }
.stat-box { background:rgba(255,255,255,0.7); border:2px solid rgba(0,150,0,0.25); border-radius:12px;
  padding:8px 16px; display:flex; align-items:center; gap:6px; font-size:1rem; font-weight:700; color:#333; }
.stat-icon { font-size:1.2rem; }

/* BUTTONS */
.btn-farm { padding:14px 44px; background:linear-gradient(135deg,#4caf50,#2e7d32);
  border:2px solid #66bb6a; border-radius:50px; font-family:var(--font-title);
  font-size:1.1rem; color: #333; cursor:pointer; box-shadow:0 6px 20px rgba(0,150,0,0.4),0 3px 0 #1a4d1a;
  transition:all 0.15s; letter-spacing:1px; }
.btn-farm:hover { transform:translateY(-3px); }
.btn-farm:active { transform:translateY(1px); }
.btn-secondary-farm { padding:10px 28px; background:transparent; border:2px solid rgba(0,100,0,0.3);
  border-radius:30px; font-family:var(--font-ui); font-size:0.9rem; color:#4a7c3f;
  cursor:pointer; transition:all 0.15s; }
.btn-secondary-farm:hover { background:rgba(0,100,0,0.1); }

/* HUD */
#hud { position:absolute; top:0;left:0;right:0;bottom:0; pointer-events:none; z-index:50; }
.hud-top { display:flex; justify-content:space-between; align-items:center; padding:8px 14px;
  background: linear-gradient(135deg, #a1c4fd 0%, #c2e9fb 100%); backdrop-filter:blur(6px); pointer-events:auto; }
.hud-left-info, .hud-right-info { display:flex; flex-direction:column; gap:2px; min-width:100px; }
.hud-stat { font-size:0.85rem; font-weight:700; color: #333; text-shadow:1px 1px 2px rgba(0,0,0,0.5); }
.hud-center-time { display:flex; flex-direction:column; align-items:center; gap:3px; }
.time-bar-wrap { width:140px; height:8px; background: linear-gradient(135deg, #a1c4fd 0%, #c2e9fb 100%); border-radius:4px; overflow:hidden; border:1px solid rgba(255,255,255,0.2); }
.time-bar { height:100%; background:linear-gradient(90deg,#ff8c69,#ffd700,#87ceeb); border-radius:4px; transition:width 0.5s; }
.time-icons { display:flex; align-items:center; gap:6px; font-size:0.75rem; color: #333; }

/* INVENTORY */
.inventory-bar { position:absolute; top:56px; left:50%; transform:translateX(-50%);
  display:flex; gap:4px; background: linear-gradient(135deg, #a1c4fd 0%, #c2e9fb 100%); border:1px solid rgba(255,255,255,0.15);
  border-radius:10px; padding:5px; pointer-events:auto; }
.inv-slot { width:44px; height:44px; background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.2);
  border-radius:8px; display:flex; flex-direction:column; align-items:center; justify-content:center;
  font-size:1.2rem; cursor:pointer; transition:all 0.15s; position:relative; }
.inv-slot:hover { border-color:var(--gold); }
.inv-slot.selected { border-color:var(--gold); background:rgba(255,215,0,0.15); box-shadow: 0 8px 15px rgba(0,0,0,0.1); }
.inv-slot .slot-count { font-size:0.55rem; font-weight:700; color:var(--gold); position:absolute; bottom:1px; right:3px; }

/* TOOLS */
.tool-bar { position:absolute; bottom:0;left:0;right:0; display:flex; align-items:center;
  justify-content:center; gap:6px; padding:8px 12px;
  background: linear-gradient(135deg, #a1c4fd 0%, #c2e9fb 100%); backdrop-filter:blur(6px); pointer-events:auto; flex-wrap:wrap; }
.tool-btn { width:46px; height:46px; background:rgba(255,255,255,0.1); border:2px solid rgba(255,255,255,0.2);
  border-radius:10px; font-size:1.3rem; cursor:pointer; display:flex; align-items:center; justify-content:center;
  transition:all 0.15s; }
.tool-btn:hover { border-color:var(--gold); }
.tool-btn.active { border-color:var(--gold); background:rgba(255,215,0,0.2); box-shadow: 0 8px 15px rgba(0,0,0,0.1); }
.tool-sep { width:2px; height:30px; background:rgba(255,255,255,0.1); border-radius:1px; margin:0 4px; }
.btn-shop { padding:8px 16px; background:linear-gradient(135deg,#cc8800,#885500); border:1px solid var(--gold);
  border-radius:8px; font-family:var(--font-title); font-size:0.8rem; color: #333; cursor:pointer; }
.btn-sleep { padding:8px 14px; background:linear-gradient(135deg,#2266aa,#113366); border:1px solid #4488cc;
  border-radius:8px; font-family:var(--font-title); font-size:0.8rem; color: #333; cursor:pointer; }

/* MODAL */
.modal { position:fixed;top:0;left:0;right:0;bottom:0;background: linear-gradient(135deg, #a1c4fd 0%, #c2e9fb 100%);z-index:200;display:flex;align-items:center;justify-content:center; }
.modal-box { background:linear-gradient(135deg,#f0fae0,#d0f0a0); border:3px solid var(--green);
  border-radius:20px; padding:20px; max-width:380px; width:94%; display:flex; flex-direction:column; gap:10px;
  box-shadow:0 8px 40px rgba(0,100,0,0.4); max-height:85vh; overflow-y:auto; }
.modal-title { font-family:var(--font-title); font-size:1.4rem; color:#2d6a0a; text-align:center; }
.shop-tabs { display:flex; gap:6px; }
.tab-btn { flex:1; padding:8px; background:transparent; border:2px solid rgba(0,100,0,0.25); border-radius:8px;
  font-family:var(--font-ui); font-size:0.8rem; color:#4a7c3f; cursor:pointer; transition:all 0.15s; }
.tab-btn.active { background:var(--green); color: #333; border-color:var(--dark-green); }
.shop-content { display:flex; flex-direction:column; gap:6px; min-height:100px; }
.shop-item { display:flex; align-items:center; gap:10px; background:rgba(255,255,255,0.6);
  border:1px solid rgba(0,100,0,0.2); border-radius:10px; padding:8px 12px; cursor:pointer;
  transition:all 0.15s; }
.shop-item:hover { border-color:var(--green); background:rgba(255,255,255,0.85); }
.shop-item .si-icon { font-size:1.6rem; }
.shop-item .si-info { flex:1; }
.shop-item .si-name { font-weight:700; font-size:0.9rem; color:#2d3a00; }
.shop-item .si-desc { font-size:0.75rem; color:#5a7a3a; }
.shop-item .si-cost { font-family:var(--font-title); color:#cc6600; font-size:0.9rem; white-space:nowrap; }
.shop-gold { font-family:var(--font-title); color:#cc6600; text-align:center; font-size:0.95rem; }

/* DAY END */
#day-end { background:linear-gradient(180deg,#0a0a2e,#1a1a4e); }
.day-end-box { background:rgba(255,255,255,0.08); border:2px solid rgba(255,215,0,0.3); border-radius:20px;
  padding:28px 32px; max-width:380px; width:94%; display:flex; flex-direction:column; align-items:center; gap:14px; }
.day-end-title { font-family:var(--font-title); font-size:1.6rem; color:var(--gold); text-align:center; }
.day-end-summary { width:100%; display:flex; flex-direction:column; gap:6px; }
.summary-row { display:flex; justify-content:space-between; align-items:center; padding:4px 0;
  border-bottom:1px solid rgba(255,255,255,0.1); font-size:0.9rem; color: #555; }
.summary-row span:last-child { color:var(--gold); font-weight:700; }

/* TOAST */
.toast { position:fixed; bottom:100px; left:50%; transform:translateX(-50%); z-index:300;
  background: linear-gradient(135deg, #a1c4fd 0%, #c2e9fb 100%); color: #333; padding:10px 22px; border-radius:20px;
  font-size:0.9rem; white-space:nowrap; animation:toast-in 0.3s ease; pointer-events:none;
  border:1px solid rgba(255,255,255,0.15); }
@keyframes toast-in { 0%{transform:translateX(-50%) translateY(20px);opacity:0} 100%{transform:translateX(-50%) translateY(0);opacity:1} }

/* SOUND */
.sound-btn { position:fixed;bottom:80px;right:16px;z-index:200;font-size:1.2rem;
  background: linear-gradient(135deg, #a1c4fd 0%, #c2e9fb 100%);border:1px solid rgba(255,255,255,0.2);border-radius:50%;
  width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer; }

.hidden { display:none!important; }
@media(max-width:480px) { .start-stats{flex-wrap:wrap;justify-content:center} }
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:#aaa;border-radius:2px}
