/* ============================================================
   GIGGS Governance Dashboard · Shell Stylesheet
   Premium white/gold institutional aesthetic
   ============================================================ */

:root{
  --paper:#F0E8D5;
  --paper-soft:#E8DFC8;
  --paper-deep:#DDD0B0;
  --white:#FFFFFF;
  --ink:#0A0908;
  --ink-soft:#1F1B17;
  --slate:#6B6660;
  --slate-light:#9B958E;
  --rule:#E8DFC8;
  --rule-soft:#F0E8D5;
  --rule-faint:#F7F1E0;

  --gold:#C9A24C;
  --gold-light:#E8D098;
  --gold-deep:#8B6F2A;
  --gold-shine:#F2D98A;

  --verified:#4A7C59;
  --verified-soft:#E6EFE9;
  --alert:#B23B3B;
  --alert-soft:#F4E1E1;
  --warn:#C77F2F;
  --warn-soft:#F5E8D5;

  --display:'Inter', system-ui, sans-serif;
  --body:'Inter', system-ui, sans-serif;
  --mono:'JetBrains Mono', 'Courier New', monospace;

  --rad-sm:4px;
  --rad-md:8px;
  --rad-lg:14px;

  --sb-w:280px;

  --shadow-sm:0 1px 2px rgba(26,22,20,.05);
  --shadow-md:0 1px 2px rgba(26,22,20,.04), 0 8px 24px rgba(26,22,20,.06);
  --shadow-lg:0 1px 2px rgba(26,22,20,.06), 0 16px 48px rgba(139,111,42,.1);
}

*{box-sizing:border-box; margin:0; padding:0}
html,body{height:100%}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:14px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

a{color:inherit; text-decoration:none}
button{font-family:inherit; cursor:pointer}
input,select,textarea{font-family:inherit; font-size:14px}

/* Brand mark — used in shell + login */
.brand-mark{
  width:32px; height:32px; border-radius:50%; flex-shrink:0;
  background:radial-gradient(circle at 30% 30%, var(--gold-shine), var(--gold) 40%, var(--gold-deep));
  box-shadow:inset 0 -2px 4px rgba(0,0,0,.15), 0 2px 6px rgba(201,162,76,.3);
  position:relative;
}
.brand-mark::after{
  content:""; position:absolute; inset:5px; border-radius:50%;
  border:1px solid rgba(255,255,255,.45);
}
.brand-name{font-family:var(--display); font-weight:500; font-size:16px; letter-spacing:.04em; line-height:1}
.brand-sub{font-size:9.5px; letter-spacing:.16em; color:var(--slate); margin-top:3px; text-transform:uppercase}

/* ============================================================
   LOGIN VIEW
   ============================================================ */
.login-view{
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  padding:32px; position:relative; overflow:hidden;
}
.login-bg{
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(ellipse 1000px 600px at 80% 20%, rgba(232,208,152,.18), transparent 60%),
    radial-gradient(ellipse 800px 500px at 20% 90%, rgba(201,162,76,.08), transparent 60%);
}
.login-card{
  position:relative; z-index:1;
  background:var(--white); border:1px solid var(--rule);
  border-radius:var(--rad-lg); padding:48px;
  max-width:440px; width:100%;
  box-shadow:var(--shadow-lg);
}
.login-brand{display:flex; align-items:center; gap:14px; margin-bottom:32px}
.login-title{
  font-family:var(--display); font-weight:300;
  font-size:36px; line-height:1.1; letter-spacing:-.02em;
  color:var(--ink); margin-bottom:8px;
}
.login-title em{font-style:italic; font-weight:400; color:var(--gold-deep)}
.login-lede{font-size:14px; color:var(--slate); margin-bottom:32px}

.login-form{display:flex; flex-direction:column; gap:18px}
.field{display:flex; flex-direction:column}
.field span{
  font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--slate); margin-bottom:8px;
}
.field span em{font-style:normal; color:var(--gold-deep); font-weight:500}
.field input{
  background:var(--paper); border:1px solid var(--rule);
  border-radius:var(--rad-sm); padding:14px 16px;
  font-size:15px; color:var(--ink); transition:all .2s;
  width:100%;
}
.field input:focus{outline:0; border-color:var(--gold); background:var(--white); box-shadow:0 0 0 3px rgba(201,162,76,.15)}

.btn-gold{
  background:var(--ink); color:var(--paper);
  border:0; border-radius:var(--rad-sm);
  padding:14px 24px; font-size:14px; font-weight:500; letter-spacing:.04em;
  display:flex; align-items:center; justify-content:center; gap:10px;
  transition:all .25s; margin-top:8px;
}
.btn-gold:hover{background:var(--gold-deep); transform:translateY(-1px); box-shadow:0 6px 16px rgba(139,111,42,.25)}
.btn-gold span{font-family:var(--display); font-size:18px}

.login-error{
  font-size:13px; color:var(--alert); padding:10px 14px;
  background:var(--alert-soft); border-radius:var(--rad-sm);
  display:none;
}
.login-error.show{display:block}

.login-foot{
  display:flex; justify-content:space-between; margin-top:24px;
  font-size:13px; padding-top:24px; border-top:1px solid var(--rule-soft);
}
.login-foot a{color:var(--gold-deep); transition:color .2s}
.login-foot a:hover{color:var(--ink)}
.login-help{font-size:12px; color:var(--slate); margin-top:14px; text-align:center}
.login-help a{color:var(--ink-soft)}

/* ============================================================
   APP VIEW LAYOUT
   ============================================================ */
.app-view{
  display:grid;
  grid-template-columns:var(--sb-w) 1fr;
  height:100vh;
  overflow:hidden;
}

/* ===== SIDEBAR ===== */
.sidebar{
  background:var(--white); border-right:1px solid var(--rule);
  display:flex; flex-direction:column;
  overflow:hidden;
}
.sb-brand{
  display:flex; align-items:center; gap:12px;
  padding:20px 22px; border-bottom:1px solid var(--rule-soft);
  flex-shrink:0;
}
.sb-search{padding:14px 16px; border-bottom:1px solid var(--rule-soft); flex-shrink:0}
.sb-search input{
  width:100%; background:var(--paper); border:1px solid var(--rule);
  border-radius:var(--rad-sm); padding:9px 12px; font-size:13px;
  transition:all .2s;
}
.sb-search input:focus{outline:0; border-color:var(--gold-light); background:var(--white)}

.sb-nav{flex:1; overflow-y:auto; padding:8px 0; scrollbar-width:thin}
.sb-nav::-webkit-scrollbar{width:4px}
.sb-nav::-webkit-scrollbar-thumb{background:var(--rule); border-radius:2px}

.sb-cat{margin:6px 0}
.sb-cat-title{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 22px; cursor:pointer;
  font-size:10px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--slate); font-weight:600;
  transition:color .15s;
}
.sb-cat-title:hover{color:var(--gold-deep)}
.sb-cat-title .arrow{font-size:9px; transition:transform .2s}
.sb-cat.open .sb-cat-title .arrow{transform:rotate(90deg)}
.sb-cat-list{display:none; padding:2px 0 6px}
.sb-cat.open .sb-cat-list{display:block}

.sb-item{
  display:flex; align-items:center; gap:10px;
  padding:8px 22px 8px 38px; font-size:13px; color:var(--ink-soft);
  cursor:pointer; transition:all .15s; position:relative;
}
.sb-item:hover{background:var(--paper-soft); color:var(--ink)}
.sb-item.active{
  background:linear-gradient(90deg, rgba(201,162,76,.08), transparent);
  color:var(--gold-deep); font-weight:500;
}
.sb-item.active::before{
  content:""; position:absolute; left:0; top:6px; bottom:6px; width:2px;
  background:var(--gold);
}
.sb-item .badge{
  margin-left:auto; font-family:var(--mono); font-size:10px;
  background:var(--paper-soft); color:var(--slate);
  padding:1px 6px; border-radius:8px;
}
.sb-item.active .badge{background:var(--gold); color:var(--white)}
.sb-item.locked{color:var(--slate-light); cursor:not-allowed}
.sb-item.locked .badge{background:transparent; color:var(--slate-light); border:1px solid var(--rule)}

.sb-foot{
  border-top:1px solid var(--rule-soft); flex-shrink:0;
  position:relative;
}
.user-card{
  display:flex; align-items:center; gap:12px; padding:14px 18px;
  cursor:pointer; transition:background .15s;
}
.user-card:hover{background:var(--paper-soft)}
.user-avatar{
  width:36px; height:36px; border-radius:50%;
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-deep) 100%);
  color:var(--white); display:flex; align-items:center; justify-content:center;
  font-family:var(--display); font-weight:500; font-size:14px;
  flex-shrink:0;
}
.user-info{flex:1; min-width:0}
.user-name{font-size:13px; font-weight:500; color:var(--ink); line-height:1.2; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.user-role{font-size:11px; color:var(--slate); margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.user-menu-btn{
  background:none; border:0; color:var(--slate); font-size:18px;
  width:24px; height:24px; border-radius:var(--rad-sm); transition:all .15s;
}
.user-menu-btn:hover{background:var(--paper-deep); color:var(--ink)}
.user-menu{
  display:none; position:absolute; bottom:100%; left:8px; right:8px;
  background:var(--white); border:1px solid var(--rule);
  border-radius:var(--rad-md); padding:6px;
  box-shadow:var(--shadow-md); margin-bottom:4px;
}
.user-menu.open{display:block}
.user-menu a{
  display:block; padding:8px 12px; font-size:13px; color:var(--ink-soft);
  border-radius:var(--rad-sm); transition:all .15s;
}
.user-menu a:hover{background:var(--paper-soft); color:var(--ink)}

/* ===== MAIN ===== */
.main{
  display:flex; flex-direction:column;
  background:var(--paper);
  overflow:hidden;
}

.topnav{
  display:flex; align-items:center; gap:16px;
  padding:14px 28px; background:var(--white);
  border-bottom:1px solid var(--rule); flex-shrink:0;
}
.sb-toggle{
  display:none; background:none; border:0; font-size:20px; color:var(--ink);
  width:36px; height:36px; border-radius:var(--rad-sm);
}
.sb-toggle:hover{background:var(--paper-soft)}

.breadcrumb{
  font-family:var(--display); font-size:18px; font-weight:400;
  color:var(--ink); flex:1; letter-spacing:-.005em;
}
.topnav-tools{display:flex; align-items:center; gap:14px}

.ticker{
  display:flex; align-items:center; gap:10px;
  padding:8px 14px; background:var(--paper-soft);
  border:1px solid var(--rule); border-radius:var(--rad-sm);
  font-family:var(--mono); font-size:11px;
}
.ticker-label{color:var(--slate); font-size:9.5px; letter-spacing:.1em}
.ticker-val{color:var(--ink); font-weight:500}
@media(max-width:680px){.ticker{display:none}}

.icon-btn{
  background:transparent; border:1px solid var(--rule);
  width:36px; height:36px; border-radius:var(--rad-sm);
  display:flex; align-items:center; justify-content:center;
  color:var(--ink-soft); transition:all .2s;
}
.icon-btn:hover{background:var(--gold); color:var(--white); border-color:var(--gold)}

.module-host{flex:1; overflow-y:auto; padding:32px}
@media(max-width:720px){.module-host{padding:20px}}

.module-loading{
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:120px 0; color:var(--slate); font-size:13px; gap:14px;
}
.loader-dot{
  width:10px; height:10px; border-radius:50%;
  background:var(--gold); animation:loader 1s infinite ease-in-out;
}
@keyframes loader{0%,100%{transform:scale(.7); opacity:.5} 50%{transform:scale(1.1); opacity:1}}

/* ============================================================
   SHARED MODULE COMPONENTS
   Used by every module — keeps things consistent.
   ============================================================ */

.mod-head{
  display:flex; justify-content:space-between; align-items:flex-end;
  margin-bottom:28px; gap:20px; flex-wrap:wrap;
}
.mod-head-text{flex:1; min-width:280px}
.mod-eyebrow{
  font-size:10.5px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--gold-deep); margin-bottom:10px;
}
.mod-title{
  font-family:var(--display); font-weight:300;
  font-size:36px; line-height:1.1; letter-spacing:-.015em;
  color:var(--ink);
}
.mod-title em{font-style:italic; color:var(--gold-deep); font-weight:400}
.mod-sub{font-size:14px; color:var(--slate); margin-top:8px; max-width:680px}
.mod-actions{display:flex; gap:10px; flex-wrap:wrap}

.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 18px; font-size:13px; font-weight:500; letter-spacing:.02em;
  border-radius:var(--rad-sm); border:0; transition:all .2s;
}
.btn-primary{background:var(--ink); color:var(--paper)}
.btn-primary:hover{background:var(--gold-deep)}
.btn-ghost{background:transparent; color:var(--ink); border:1px solid var(--rule)}
.btn-ghost:hover{background:var(--paper-soft); border-color:var(--gold-light)}
.btn-gold-fill{background:var(--gold); color:var(--white)}
.btn-gold-fill:hover{background:var(--gold-deep)}

/* KPI grid */
.kpi-grid{
  display:grid; grid-template-columns:repeat(auto-fit, minmax(200px,1fr));
  gap:1px; background:var(--rule); border:1px solid var(--rule);
  border-radius:var(--rad-md); overflow:hidden; margin-bottom:32px;
}
.kpi{background:var(--white); padding:24px}
.kpi-label{
  font-size:10.5px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--slate); margin-bottom:12px;
}
.kpi-val{
  font-family:var(--display); font-weight:300;
  font-size:36px; line-height:1; letter-spacing:-.02em;
  color:var(--ink);
}
.kpi-val em{font-style:normal; color:var(--gold-deep); font-weight:400}
.kpi-delta{
  font-family:var(--mono); font-size:11px; margin-top:8px;
  display:inline-flex; align-items:center; gap:4px;
}
.kpi-delta.up{color:var(--verified)}
.kpi-delta.down{color:var(--alert)}

/* Card */
.card{
  background:var(--white); border:1px solid var(--rule);
  border-radius:var(--rad-md); padding:24px;
  margin-bottom:20px;
}
.card-head{display:flex; justify-content:space-between; align-items:center; margin-bottom:18px; gap:16px}
.card-title{font-family:var(--display); font-size:18px; font-weight:500; color:var(--ink); letter-spacing:-.005em}
.card-sub{font-size:12px; color:var(--slate); margin-top:2px}

/* Table */
.tbl{width:100%; border-collapse:collapse; font-size:13px}
.tbl thead th{
  text-align:left; padding:12px 16px;
  font-size:10.5px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--slate); font-weight:600;
  border-bottom:1px solid var(--rule);
  background:var(--paper-soft);
}
.tbl tbody td{
  padding:14px 16px; border-bottom:1px solid var(--rule-soft);
  color:var(--ink-soft);
}
.tbl tbody tr:hover{background:var(--paper-soft)}
.tbl tbody tr:last-child td{border-bottom:0}
.tbl .num{font-family:var(--mono); color:var(--ink); font-variant-numeric:tabular-nums}
.tbl .right{text-align:right}

/* Badges */
.badge{
  display:inline-flex; align-items:center;
  padding:3px 10px; font-size:10.5px; font-weight:500;
  letter-spacing:.06em; text-transform:uppercase;
  border-radius:10px; border:1px solid;
  font-family:var(--body);
}
.badge.ok{background:var(--verified-soft); color:var(--verified); border-color:rgba(74,124,89,.3)}
.badge.warn{background:var(--warn-soft); color:var(--warn); border-color:rgba(199,127,47,.3)}
.badge.alert{background:var(--alert-soft); color:var(--alert); border-color:rgba(178,59,59,.3)}
.badge.neutral{background:var(--paper-soft); color:var(--slate); border-color:var(--rule)}
.badge.gold{background:rgba(232,208,152,.3); color:var(--gold-deep); border-color:var(--gold-light)}

/* Empty state */
.empty{
  text-align:center; padding:60px 20px;
  color:var(--slate); font-size:14px;
}
.empty-art{
  width:64px; height:64px; margin:0 auto 16px;
  border:1px solid var(--gold); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:var(--gold-deep); font-family:var(--display); font-size:24px;
}

/* Two-column layout helper */
.split-2{display:grid; grid-template-columns:1.4fr 1fr; gap:20px}
@media(max-width:980px){.split-2{grid-template-columns:1fr}}
.split-3{display:grid; grid-template-columns:repeat(3,1fr); gap:20px}
@media(max-width:980px){.split-3{grid-template-columns:1fr}}

/* Form elements (re-usable) */
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:16px}
@media(max-width:680px){.form-row{grid-template-columns:1fr}}
.form-group{display:flex; flex-direction:column}
.form-group label{
  font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--slate); margin-bottom:6px;
}
.form-group input,
.form-group select,
.form-group textarea{
  background:var(--paper); border:1px solid var(--rule);
  border-radius:var(--rad-sm); padding:10px 14px;
  font-size:14px; color:var(--ink); transition:all .15s;
  width:100%;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{outline:0; border-color:var(--gold); background:var(--white); box-shadow:0 0 0 3px rgba(201,162,76,.12)}
.form-group textarea{min-height:80px; resize:vertical; font-family:inherit}

/* Progress bar */
.bar{width:100%; height:6px; background:var(--paper-deep); border-radius:3px; overflow:hidden}
.bar-fill{height:100%; background:linear-gradient(90deg, var(--gold) 0%, var(--gold-shine) 100%); transition:width .6s}

/* ============================================================
   AI PANEL
   ============================================================ */
.ai-panel{
  position:fixed; top:0; right:0; bottom:0;
  width:420px; max-width:100vw;
  background:var(--white); border-left:1px solid var(--rule);
  box-shadow:var(--shadow-lg);
  display:none; flex-direction:column;
  z-index:100;
}
.ai-panel.open{display:flex}
.ai-head{
  padding:20px; border-bottom:1px solid var(--rule);
  display:flex; justify-content:space-between; align-items:center;
}
.ai-title{display:flex; align-items:center; gap:12px}
.ai-orb{
  width:32px; height:32px; border-radius:50%;
  background:radial-gradient(circle at 30% 30%, var(--gold-shine), var(--gold) 50%, var(--gold-deep));
  position:relative;
  animation:orb 3s ease-in-out infinite;
}
@keyframes orb{0%,100%{box-shadow:0 0 0 0 rgba(201,162,76,.4)} 50%{box-shadow:0 0 0 8px rgba(201,162,76,0)}}
.ai-name{font-family:var(--display); font-weight:500; font-size:15px; color:var(--ink)}
.ai-status{font-size:10.5px; color:var(--slate); letter-spacing:.06em; margin-top:2px}

.ai-body{flex:1; overflow-y:auto; padding:20px}
.ai-msg{
  padding:12px 16px; border-radius:var(--rad-md);
  font-size:13.5px; margin-bottom:14px; line-height:1.55;
}
.ai-msg-bot{background:var(--paper-soft); color:var(--ink-soft); border:1px solid var(--rule)}
.ai-msg-bot strong{color:var(--gold-deep); font-weight:500}
.ai-msg-user{background:var(--ink); color:var(--paper); margin-left:auto; max-width:85%}
.ai-suggestions{display:flex; flex-direction:column; gap:6px; margin-top:14px}
.ai-suggestions button{
  background:var(--white); border:1px solid var(--rule);
  text-align:left; padding:8px 12px; font-size:12.5px;
  border-radius:var(--rad-sm); color:var(--ink-soft); transition:all .15s;
}
.ai-suggestions button:hover{background:var(--gold); color:var(--white); border-color:var(--gold)}

.ai-input{
  display:flex; gap:8px; padding:14px 16px;
  border-top:1px solid var(--rule);
}
.ai-input input{
  flex:1; background:var(--paper); border:1px solid var(--rule);
  border-radius:var(--rad-sm); padding:10px 14px; font-size:13.5px;
}
.ai-input input:focus{outline:0; border-color:var(--gold); background:var(--white)}
.ai-input button{
  background:var(--ink); color:var(--paper); border:0;
  width:40px; border-radius:var(--rad-sm);
  font-size:18px; transition:background .15s;
}
.ai-input button:hover{background:var(--gold-deep)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:980px){
  .app-view{grid-template-columns:1fr}
  .sb-toggle{display:flex; align-items:center; justify-content:center}
  .sidebar{
    position:fixed; top:0; bottom:0; left:0; width:280px;
    transform:translateX(-100%); transition:transform .25s;
    z-index:200;
  }
  .sidebar.open{transform:translateX(0)}
  .ai-panel{width:100vw}
}

/* Print */
@media print{
  .sidebar,.topnav,.ai-panel{display:none !important}
  .module-host{padding:0}
  body{background:var(--white)}
}


/* ============================================================
   GOLD TICKER · prominent live price widget (added 2026-05-06)
   Deep gold frame + vibrant typography. Anchors the dashboard.
   ============================================================ */
.ticker.gold-frame{
  display:inline-flex;
  align-items:center;
  gap:14px;
  padding:9px 16px 9px 14px;
  background:linear-gradient(135deg, #1A1410 0%, #2A1F0E 100%);
  border:1.5px solid var(--gold);
  border-radius:8px;
  box-shadow:inset 0 1px 0 rgba(242,217,138,.18), 0 2px 12px rgba(139,111,42,.18);
  font-family:var(--body);
  position:relative;
}
.ticker.gold-frame::before{
  content:"";
  position:absolute;
  left:9px;
  top:50%;
  transform:translateY(-50%);
  width:6px; height:6px;
  border-radius:50%;
  background:#7DD179;
  box-shadow:0 0 8px rgba(125,209,121,.7);
  animation:tick-pulse 2.4s ease-in-out infinite;
}
@keyframes tick-pulse {
  0%,100% { opacity:1; transform:translateY(-50%) scale(1); }
  50%     { opacity:.55; transform:translateY(-50%) scale(.85); }
}
.ticker.gold-frame > .ticker-pair{
  display:inline-flex;
  align-items:baseline;
  gap:6px;
  padding-left:14px;  /* leave room for the live-pulse dot */
}
.ticker.gold-frame > .ticker-pair + .ticker-pair{
  padding-left:14px;
  border-left:1px solid rgba(232,208,152,.22);
}
.ticker.gold-frame .ticker-label{
  font-size:10px;
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--gold-light);
}
.ticker.gold-frame .ticker-val{
  font-family:var(--mono);
  font-size:15px;
  font-weight:600;
  color:#F2D98A;
  letter-spacing:.01em;
  font-feature-settings:"tnum" 1;
}
.ticker.gold-frame .ticker-currency{
  font-size:11px;
  font-weight:500;
  color:var(--gold-light);
  margin-right:2px;
}
