/* ═══════════════════════════════════
   UI — Panel, Buttons, Clock, Log
   Woli Farm · Web3 Demo
═══════════════════════════════════ */

/* Clock strip */
#clock-strip{width:100%;max-width:var(--max);display:flex;align-items:center;gap:.75rem;padding:.6rem 1.25rem;background:rgba(0,0,0,.3);border-top:1px solid rgba(76,175,120,.1)}
#clock-time{font-family:var(--font-m);font-size:1.4rem;font-weight:500;color:var(--cream);letter-spacing:.05em;min-width:56px}
#day-bar{flex:1;height:6px;background:rgba(255,255,255,.08);border-radius:3px;position:relative;overflow:visible}
#day-fill{height:100%;background:linear-gradient(to right,var(--g3),var(--g4));border-radius:3px;transition:width 1s linear}
#day-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:10px;height:10px;border-radius:50%;background:var(--g4);border:2px solid var(--g1);transition:left 1s linear}
#day-label{font-family:var(--font-m);font-size:.7rem;color:var(--muted);white-space:nowrap;letter-spacing:.06em}

/* Task alerts */
#task-alerts{width:100%;max-width:var(--max);display:flex;flex-direction:column;gap:.3rem;padding:0 1.25rem}
.task-alert{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;border-radius:8px;font-family:var(--font-m);font-size:.75rem;font-weight:500;animation:alertSlide .3s ease}
.task-water{background:rgba(30,120,200,.2);border:1px solid rgba(60,160,240,.4);color:#7df}
.task-fert{background:rgba(60,160,60,.2);border:1px solid rgba(80,200,80,.4);color:#8fd4a8}
.task-timer{font-size:.7rem;opacity:.8}

/* Status cards */
#status-row{width:100%;max-width:var(--max);display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;padding:.75rem 1.25rem}
.scard{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:.6rem .75rem;text-align:center}
.scard-icon{font-size:1.2rem;line-height:1;margin-bottom:.15rem}
.scard-val{font-family:var(--font-d);font-size:1rem;font-weight:700;color:var(--cream)}
.scard-lbl{font-family:var(--font-m);font-size:.55rem;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;margin-top:.1rem}

/* Progress */
#progress-wrap{width:100%;max-width:var(--max);padding:.5rem 1.25rem .75rem}
.prog-label{display:flex;justify-content:space-between;font-family:var(--font-m);font-size:.62rem;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:.35rem}
.prog-track{height:7px;background:rgba(255,255,255,.07);border-radius:100px;overflow:hidden;margin-bottom:.5rem}
.prog-fill{height:100%;border-radius:100px;background:linear-gradient(to right,var(--g2),var(--g4));transition:width 1s ease}
#stage-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .85rem;border-radius:100px;font-family:var(--font-m);font-size:.65rem;background:rgba(76,175,120,.1);border:1px solid rgba(76,175,120,.2);color:var(--g4)}
#stage-badge .dot{width:5px;height:5px;border-radius:50%;background:var(--g4);animation:pulse 2s infinite}

/* Action buttons */
#action-row{width:100%;max-width:var(--max);display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;padding:.5rem 1.25rem}
.abtn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;padding:.7rem .5rem;border-radius:12px;border:1px solid;cursor:pointer;transition:all .2s;background:transparent}
.abtn:active{transform:scale(.96)}
.abtn:disabled{opacity:.4;cursor:not-allowed}
.abtn-icon{font-size:1.4rem;line-height:1}
.abtn-label{font-family:var(--font-m);font-size:.62rem;font-weight:500;letter-spacing:.05em;text-align:center;line-height:1.2}
.abtn-sub{font-family:var(--font-m);font-size:.55rem;opacity:.6}

.abtn-water{border-color:rgba(60,140,220,.35);color:#7ef}
.abtn-water:not(:disabled):hover{background:rgba(30,100,180,.2);border-color:rgba(60,140,220,.6)}
.abtn-plant{border-color:rgba(76,175,120,.5);color:var(--g5);animation:plantPulse 2s ease-in-out infinite}
.abtn-plant:hover{background:rgba(45,122,79,.25)}
.abtn-fert{border-color:rgba(76,175,120,.3);color:var(--g4)}
.abtn-fert:not(:disabled):hover{background:rgba(45,122,79,.2);border-color:rgba(76,175,120,.5)}
.abtn-shop{border-color:rgba(200,168,75,.3);color:var(--gold)}
.abtn-shop:hover{background:rgba(200,168,75,.12);border-color:rgba(200,168,75,.5)}
.abtn-reset{border-color:rgba(200,80,80,.25);color:#f88}
.abtn-reset:hover{background:rgba(200,80,80,.1)}
.abtn-done{border-color:rgba(76,175,120,.2) !important;color:var(--g4) !important;opacity:.6}
.abtn-urgent{border-color:rgba(255,200,50,.7) !important;color:#ffe !important;background:rgba(200,150,0,.2) !important;animation:urgentPulse 1s ease-in-out infinite}
.pulse-alert{animation:urgentPulse 1s ease-in-out 4 !important}

/* Log */
#log-wrap{width:100%;max-width:var(--max);padding:.5rem 1.25rem 1.5rem}
.log-header{display:flex;justify-content:space-between;font-family:var(--font-m);font-size:.62rem;color:var(--muted);letter-spacing:.06em;margin-bottom:.4rem;text-transform:uppercase}
#log{max-height:100px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--g2) transparent}
.log-line{padding:.15rem 0;border-bottom:1px solid rgba(255,255,255,.04);font-family:var(--font-m);font-size:.68rem;color:var(--muted)}
.log-ts{color:var(--g4);margin-right:.4rem}
.log-good .log-ts,.log-good{color:#8fd4a8}
.log-warn{color:var(--warn)}
.log-day{color:var(--gold)}
.log-harvest{color:var(--gold2);font-weight:500}

/* Notification bar */
.notif-hidden{display:none}
.notif-show{
  display:flex;align-items:center;gap:.75rem;
  width:100%;max-width:var(--max);
  padding:.75rem 1.25rem;
  background:linear-gradient(135deg,rgba(200,150,0,.15),rgba(30,100,180,.15));
  border-top:2px solid var(--gold);
  border-bottom:2px solid rgba(60,140,220,.4);
  animation:notifSlide .3s ease;
}
.notif-icon{font-size:1.6rem;flex-shrink:0}
.notif-body{flex:1}
.notif-title{font-family:var(--font-d);font-size:1rem;font-weight:700;color:var(--cream)}
.notif-sub{font-family:var(--font-m);font-size:.65rem;color:var(--muted)}
.notif-timer{font-family:var(--font-m);font-size:.75rem;color:var(--gold);white-space:nowrap}

/* Toast */
#toast{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%) translateY(16px);background:var(--g2);border:1px solid rgba(76,175,120,.35);border-radius:100px;padding:.5rem 1.4rem;font-family:var(--font-m);font-size:.78rem;color:var(--g5);opacity:0;transition:all .35s;pointer-events:none;white-space:nowrap;z-index:300;box-shadow:0 8px 24px rgba(0,0,0,.5)}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media(max-width:420px){
  #action-row{grid-template-columns:repeat(2,1fr)}
  #status-row{grid-template-columns:repeat(2,1fr)}
}
