/* ═══════════════════════════════════════════════
   DOTFINS — SHARED DESIGN SYSTEM
   ═══════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700;800&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;1,400&family=DM+Mono:wght@400;500&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --ink:#2C2C2C;
  --ink2:#3A3A3A;
  --ink3:#4A4A4A;
  --slate:#555555;
  --muted:#888888;
  --border:#DDDDDD;
  --surface:#F5F5F5;
  --surface2:#EBEBEB;
  --white:#FFFFFF;
  --blue:#2B2B2B;
  --blue2:#444444;
  --blue3:#EEEEEE;
  --green:#1A8C5B;
  --green2:#E4F5EE;
  --red:#D93025;
  --red2:#FDE8E6;
  --gold:#9A7000;
  --gold2:#FBF5E0;
  --purple:#5B3FBF;
  --purple2:#EDE8FF;
  --teal:#0E7490;
  --teal2:#E0F4FA;
  --accent:#4A4A4A;
  --accent2:#F0F0F0;
  --r:14px;
  --r2:10px;
  --shadow:0 2px 12px rgba(0,0,0,0.07);
  --shadow2:0 8px 40px rgba(0,0,0,0.10);
  --shadow3:0 20px 80px rgba(0,0,0,0.13);
}
html{scroll-behavior:smooth;font-size:16px;}
body{font-family:'DM Sans',sans-serif;color:var(--ink);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased;}

/* ── NAV ── */
.orident-nav{
  position:fixed;top:0;width:100%;z-index:500;
  background:rgba(255,255,255,0.96);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 5%;height:68px;
}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;}
.nav-logo-mark{
  width:42px;height:42px;border-radius:12px;
  background:linear-gradient(135deg,#2A2A2A,#1A1A1A);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  box-shadow:0 3px 12px rgba(0,0,0,0.25);
}
.nav-logo-mark svg{width:34px;height:34px;}
.nav-logo-text{font-family:'Sora',sans-serif;font-weight:700;font-size:17px;color:var(--ink);}
.nav-logo-text span{color:#555;}
.nav-links{display:flex;align-items:center;gap:2px;list-style:none;}
.nav-links a{color:var(--slate);text-decoration:none;font-size:13px;font-weight:500;padding:7px 11px;border-radius:7px;transition:all .2s;white-space:nowrap;}
.nav-links a:hover,.nav-links a.active{background:var(--surface);color:var(--ink);}
.nav-right{display:flex;align-items:center;gap:10px;}
.btn-ghost{background:none;border:1.5px solid var(--border);color:var(--ink);padding:9px 20px;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;transition:all .2s;display:inline-flex;align-items:center;}
.btn-ghost:hover{border-color:var(--ink);color:var(--ink);}
.btn-primary{background:#3A3A3A;color:white;padding:9px 22px;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700;cursor:pointer;text-decoration:none;border:none;transition:all .2s;display:inline-flex;align-items:center;gap:6px;}
.btn-primary:hover{background:#333;transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,0,0,0.25);}
.btn-green{background:var(--green);color:white;padding:9px 22px;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700;cursor:pointer;text-decoration:none;border:none;transition:all .2s;}
.btn-green:hover{background:#156B47;transform:translateY(-1px);}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600;}
.badge-up{background:var(--green2);color:var(--green);}
.badge-down{background:var(--red2);color:var(--red);}
.badge-blue{background:var(--surface2);color:var(--ink2);}
.badge-gold{background:var(--gold2);color:var(--gold);}
.badge-purple{background:var(--purple2);color:var(--purple);}

/* ── CARDS ── */
.card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:24px;box-shadow:var(--shadow);}
.card:hover{box-shadow:var(--shadow2);}

/* ── TICKER TAPE ── */
.ticker-wrap{background:#3A3A3A;overflow:hidden;padding:10px 0;position:relative;}
.ticker-inner{display:flex;gap:0;white-space:nowrap;animation:ticker 60s linear infinite;}
.ticker-inner:hover{animation-play-state:paused;}
.ticker-item{display:inline-flex;align-items:center;gap:8px;padding:0 28px;font-family:'DM Mono',monospace;font-size:12px;color:rgba(255,255,255,0.75);}
.ticker-item .sym{color:white;font-weight:500;}
.ticker-item .up{color:#00C27A;}
.ticker-item .dn{color:#F03A47;}
.ticker-sep{color:rgba(255,255,255,0.2);padding:0 4px;}
@keyframes ticker{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* ── INPUTS ── */
.form-group{margin-bottom:18px;}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--ink2);letter-spacing:0.3px;margin-bottom:7px;text-transform:uppercase;}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:13px 16px;border:1.5px solid var(--border);border-radius:var(--r2);font-family:'DM Sans',sans-serif;font-size:14px;color:var(--ink);background:var(--white);outline:none;transition:border-color .2s,box-shadow .2s;}
.form-group input:focus,.form-group select:focus{border-color:var(--ink);box-shadow:0 0 0 3px rgba(0,0,0,0.08);}
.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234A5C74' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;}

/* ── ALERTS / TOASTS ── */
#toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none;}
.toast{background:#3A3A3A;color:white;padding:14px 18px;border-radius:10px;font-size:13px;font-weight:500;box-shadow:0 8px 32px rgba(0,0,0,0.25);display:flex;align-items:center;gap:10px;pointer-events:all;max-width:320px;animation:toast-in .3s ease;border-left:4px solid #888;}
.toast.success{border-left-color:var(--green);}
.toast.error{border-left-color:var(--red);}
.toast-close{margin-left:auto;background:none;border:none;color:rgba(255,255,255,0.4);cursor:pointer;font-size:16px;}
@keyframes toast-in{from{opacity:0;transform:translateX(30px);}to{opacity:1;transform:translateX(0);}}

/* ── TABLES ── */
.data-table{width:100%;border-collapse:collapse;}
.data-table th{font-size:11px;font-weight:700;color:var(--muted);letter-spacing:0.8px;text-transform:uppercase;padding:12px 16px;border-bottom:1px solid var(--border);text-align:left;background:var(--surface);}
.data-table td{padding:14px 16px;border-bottom:1px solid var(--border);font-size:14px;color:var(--ink);}
.data-table tr:hover td{background:var(--surface);}
.data-table tr:last-child td{border-bottom:none;}

/* ── SPARKLINE ── */
.sparkline{display:inline-block;vertical-align:middle;}

/* ── MODAL ── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(11,17,32,0.6);backdrop-filter:blur(4px);z-index:8000;align-items:center;justify-content:center;}
.modal-overlay.open{display:flex;}
.modal-box{background:white;border-radius:var(--r);box-shadow:var(--shadow3);width:90%;max-width:480px;max-height:90vh;overflow-y:auto;position:relative;}
.modal-head{padding:24px 28px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.modal-head h3{font-family:'Sora',sans-serif;font-size:18px;font-weight:700;color:var(--ink);}
.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--muted);padding:4px;}
.modal-body{padding:28px;}

/* ── SIDEBAR ── */
.app-layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh;padding-top:68px;}
.sidebar{background:var(--white);border-right:1px solid var(--border);padding:24px 0;position:sticky;top:68px;height:calc(100vh - 68px);overflow-y:auto;}
.sidebar-section{padding:0 16px;margin-bottom:8px;}
.sidebar-label{font-size:10px;font-weight:700;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;padding:16px 12px 8px;}
.sidebar-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;color:var(--slate);text-decoration:none;font-size:14px;font-weight:500;transition:all .2s;margin-bottom:2px;cursor:pointer;}
.sidebar-item:hover{background:var(--surface);color:var(--ink);}
.sidebar-item.active{background:var(--surface2);color:var(--ink);font-weight:600;}
.sidebar-item .icon{width:18px;text-align:center;font-size:16px;}
.sidebar-badge{margin-left:auto;background:var(--red);color:white;border-radius:10px;padding:2px 7px;font-size:10px;font-weight:700;}

/* ── RESPONSIVE ── */
@media(max-width:1024px){.app-layout{grid-template-columns:1fr;}}
@media(max-width:768px){.orident-nav .nav-links{display:none;}.orident-nav .btn-ghost{display:none;}}
