/*
 * JEJAK — shared.css (OPTIMIZED)
 * Single source of truth untuk design system
 * Include di semua halaman: <link rel="stylesheet" href="/shared.css">
 */

/* ── GOOGLE FONTS ── */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Syne:wght@400;600;700;800&family=DM+Mono:wght@400;500&display=swap');

/* ── DESIGN TOKENS ── */
:root {
  /* Colors */
  --bg:#080808;--sf:#0f0f0f;--sfe:#141414;
  --bd:#222;--bd2:#2e2e2e;
  --tx:#f0ece6;--txs:#777;--txm:#444;
  --ap:#ff2d55;--as:#00e5ff;--aq:#bfff00;--gold:#ffd60a;--purple:#bf5af2;
  --ms:#ff9f0a;--mt:#bfff00;--mc:#00e5ff;--md:#bf5af2;
  
  /* Safe area */
  --sb:env(safe-area-inset-bottom);--st:env(safe-area-inset-top);
  
  /* Typography */
  --font-display:'Bebas Neue',sans-serif;
  --font-body:'Syne',-apple-system,sans-serif;
  --font-mono:'DM Mono',monospace;
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}
html,body{height:100%}
body{background:var(--bg);color:var(--tx);font-family:var(--font-body);font-size:14px;line-height:1.4;-webkit-font-smoothing:antialiased}

/* ── NOISE OVERLAY ── */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.028;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E") 0 0/200px 200px}

/* ── SHARED LAYOUT ── */
.page-wrap{height:100%;display:flex;flex-direction:column;overflow:hidden;max-width:480px;margin:0 auto}

/* ── BOTTOM NAV ── */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--bg);border-top:2px solid var(--bd);padding-bottom:var(--sb);z-index:100}
.nav-container{display:flex;justify-content:space-around;align-items:stretch;height:62px;max-width:480px;margin:0 auto}
.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--txm);text-decoration:none;font-family:var(--font-mono);font-size:9px;letter-spacing:1.5px;text-transform:uppercase;position:relative;border-right:2px solid var(--bd);transition:all .12s}
.nav-item:last-child{border-right:none}
.nav-item.active{color:var(--ap);background:rgba(255,45,85,.06)}
.nav-item.active::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--ap)}
.nav-icon{font-size:20px;line-height:1}

/* ── TOAST ── */
.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(100px);background:var(--tx);color:var(--bg);padding:12px 22px;font-family:var(--font-mono);font-size:12px;letter-spacing:.5px;z-index:600;opacity:0;transition:all .25s cubic-bezier(.175,.885,.32,1.275);pointer-events:none;white-space:nowrap;border:2px solid #000;box-shadow:4px 4px 0 #000}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.error{background:var(--ap);color:#fff}

/* ── BUTTONS ── */
.btn-primary{background:var(--ap);border:2px solid #000;color:#fff;font-family:var(--font-display);font-size:20px;letter-spacing:3px;padding:18px;cursor:pointer;box-shadow:5px 5px 0 #000;transition:transform .08s,box-shadow .08s;width:100%}
.btn-primary:active{transform:translate(3px,3px);box-shadow:2px 2px 0 #000}
.btn-primary:disabled{opacity:.3;cursor:not-allowed;box-shadow:none}
.btn-secondary{background:transparent;border:2px dashed var(--bd2);color:var(--txs);font-family:var(--font-body);font-size:13px;font-weight:600;padding:14px 18px;cursor:pointer;width:100%;transition:all .15s}
.btn-secondary:hover,.btn-secondary:active{border-color:var(--as);color:var(--as)}

/* ── CARDS ── */
.card{background:var(--sf);border:2px solid var(--bd2);box-shadow:4px 4px 0 #000}
.card-head{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:2px solid var(--bd);background:var(--bg)}

/* ── MOOD BADGES ── */
.mood-badge{font-family:var(--font-mono);font-size:9px;padding:5px 10px;text-transform:uppercase;letter-spacing:1.5px;border:2px solid}
.mood-badge.surviving{color:var(--ms);border-color:var(--ms);background:rgba(255,159,10,.08)}
.mood-badge.thriving{color:var(--mt);border-color:var(--mt);background:rgba(191,255,0,.08)}
.mood-badge.chaotic{color:var(--mc);border-color:var(--mc);background:rgba(0,229,255,.08)}
.mood-badge.doom{color:var(--md);border-color:var(--md);background:rgba(191,90,242,.08)}

/* ── MODAL ── */
.modal{display:none;position:fixed;inset:0;background:var(--bg);z-index:200;flex-direction:column;overflow:hidden}
.modal.on{display:flex}
.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;padding-top:calc(16px + var(--st));border-bottom:2px solid var(--bd)}
.modal-title{font-family:var(--font-display);font-size:22px;letter-spacing:2px}
.modal-close{width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:var(--sf);border:2px solid var(--bd2);color:var(--txs);font-size:16px;cursor:pointer;box-shadow:3px 3px 0 #000;transition:all .08s}
.modal-close:active{transform:translate(2px,2px);box-shadow:1px 1px 0 #000}
.modal-body{flex:1;overflow-y:auto;padding:24px 18px calc(24px + var(--sb));-webkit-overflow-scrolling:touch}

/* ── OFFLINE INDICATOR ── */
.offline-banner{display:none;position:fixed;top:0;left:0;right:0;background:var(--ap);color:#fff;font-family:var(--font-mono);font-size:11px;letter-spacing:1px;text-align:center;padding:8px;z-index:9998;border-bottom:2px solid #000}
.offline-banner.show{display:block}

/* ── SKELETON LOADER ── */
.skeleton{background:linear-gradient(90deg,var(--sf) 25%,var(--sfe) 50%,var(--sf) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite}
@keyframes skeleton-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skeleton-card{height:120px;border:2px solid var(--bd2);margin-bottom:14px}

/* ── UPLOAD PROGRESS ── */
.upload-progress-wrap{position:fixed;bottom:calc(80px + var(--sb));left:16px;right:16px;max-width:448px;margin:0 auto;background:var(--sf);border:2px solid var(--bd2);padding:12px 16px;z-index:500;box-shadow:4px 4px 0 #000;display:none}
.upload-progress-wrap.show{display:block}
.upload-progress-label{font-family:var(--font-mono);font-size:10px;color:var(--txs);letter-spacing:1px;margin-bottom:8px;display:flex;justify-content:space-between}
.upload-progress-bar{height:4px;background:var(--bd2);position:relative;overflow:hidden}
.upload-progress-fill{height:100%;background:var(--ap);transition:width .3s ease;width:0}

/* ── REACTION BUTTONS ── */
.react-btn{flex:1;min-width:60px;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 8px;background:transparent;border:none;border-right:2px solid var(--bd);font-size:16px;color:var(--txs);cursor:pointer;touch-action:manipulation;transition:all .1s;font-family:var(--font-mono)}
.react-btn:last-child{border-right:none}
.react-btn.active{background:var(--ap);color:#fff}
.react-btn:active{background:var(--bd2)}
.react-count{font-family:var(--font-mono);font-size:11px}

/* ── SECTION HEADERS ── */
.sect-title{font-family:var(--font-display);font-size:28px;letter-spacing:2px;line-height:1}
.sect-meta{font-family:var(--font-mono);font-size:9px;color:var(--txm);letter-spacing:2px}

/* ── UTILITY ── */
.mono{font-family:var(--font-mono)}
.display{font-family:var(--font-display)}
.txt-ap{color:var(--ap)}
.txt-as{color:var(--as)}
.txt-aq{color:var(--aq)}
.txt-muted{color:var(--txs)}
.border-box{border:2px solid var(--bd2);box-shadow:3px 3px 0 #000}
