
/* ORC Shared Stylesheet — Runtipi-inspired dark design */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root,[data-theme="dark"]{
  --bg:#0e0e10;--surface:#18181b;--surface2:#1f1f23;--surface3:#252529;
  --border:#2a2a30;--border2:#333338;
  --text:#e4e4e7;--muted:#71717a;--faint:#3f3f46;--inv:#18181b;
  --primary:#4f98a3;--primary-h:#227f8b;--primary-hl:rgba(79,152,163,.12);
  --success:#6daa45;--error:#dd6974;--warning:#fdab43;--info:#5591c7;
  --font:'Satoshi',system-ui,sans-serif;
  --r:.5rem;--r-lg:.75rem;--r-xl:1rem;
  --sh:0 4px 16px rgba(0,0,0,.4);--sh-lg:0 12px 40px rgba(0,0,0,.6);
  --sidebar-w:240px;
}
[data-theme="light"]{
  --bg:#f4f4f5;--surface:#ffffff;--surface2:#fafafa;--surface3:#f0f0f2;
  --border:#e4e4e7;--border2:#d4d4d8;
  --text:#18181b;--muted:#71717a;--faint:#a1a1aa;--inv:#ffffff;
}
html{font-family:var(--font);background:var(--bg);color:var(--text);
     -webkit-font-smoothing:antialiased}
body{min-height:100dvh}
img,svg{display:block;max-width:100%}
input,button,select,textarea{font:inherit;color:inherit}
h1,h2,h3,h4{line-height:1.15;text-wrap:balance}
button{cursor:pointer;background:none;border:none}
a{color:inherit;text-decoration:none}

/* Layout */
.layout{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100dvh}
.sidebar{background:var(--surface);border-right:1px solid var(--border);
         display:flex;flex-direction:column;position:sticky;top:0;height:100dvh;overflow-y:auto}
.main{overflow-x:hidden}

/* Sidebar */
.sb-logo{display:flex;align-items:center;gap:.65rem;padding:1.25rem 1rem 1rem;
         border-bottom:1px solid var(--border)}
.sb-brand{font-weight:700;font-size:.95rem;letter-spacing:-.01em}
.sb-brand span{color:var(--primary)}
.sb-nav{flex:1;padding:.75rem .5rem}
.sb-section{font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
            color:var(--muted);padding:.75rem .5rem .35rem}
.sb-item{display:flex;align-items:center;gap:.65rem;padding:.55rem .65rem;
         border-radius:var(--r);color:var(--muted);font-size:.875rem;font-weight:500;
         transition:background .15s,color .15s;margin-bottom:2px;cursor:pointer}
.sb-item:hover{background:var(--surface2);color:var(--text)}
.sb-item.active{background:var(--primary-hl);color:var(--primary)}
.sb-item svg{flex-shrink:0;opacity:.8}
.sb-item.active svg{opacity:1}
.sb-bottom{padding:.75rem .5rem;border-top:1px solid var(--border)}
.sb-user{display:flex;align-items:center;gap:.65rem;padding:.5rem .65rem;border-radius:var(--r)}
.sb-avatar{width:30px;height:30px;border-radius:50%;background:var(--primary-hl);
           display:flex;align-items:center;justify-content:center;flex-shrink:0;
           font-size:.75rem;font-weight:700;color:var(--primary)}
.sb-uname{font-size:.85rem;font-weight:600}
.sb-urole{font-size:.75rem;color:var(--muted)}

/* Top bar */
.topbar{display:flex;align-items:center;justify-content:space-between;
        padding:.875rem 1.5rem;border-bottom:1px solid var(--border);
        background:var(--surface);position:sticky;top:0;z-index:10}
.topbar-title{font-size:1.1rem;font-weight:700}
.topbar-actions{display:flex;align-items:center;gap:.5rem}

/* Page */
.page{padding:1.5rem}
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}
.page-title{font-size:1.35rem;font-weight:700}
.page-sub{font-size:.875rem;color:var(--muted);margin-top:.2rem}

/* Cards */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.25rem}
.card-sm{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:1rem}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.card-title{font-size:.9rem;font-weight:600;color:var(--muted);text-transform:uppercase;
            letter-spacing:.04em}

/* KPI cards */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.25rem}
.kpi-label{font-size:.8rem;font-weight:600;color:var(--muted);text-transform:uppercase;
           letter-spacing:.05em;margin-bottom:.5rem}
.kpi-value{font-size:2rem;font-weight:700;line-height:1}
.kpi-sub{font-size:.8rem;color:var(--muted);margin-top:.35rem}

/* Service tiles */
.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.tile{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
      padding:1.25rem;transition:border-color .18s,box-shadow .18s;cursor:default}
.tile:hover{border-color:var(--border2);box-shadow:var(--sh)}
.tile-icon{width:44px;height:44px;border-radius:var(--r);display:flex;align-items:center;
           justify-content:center;margin-bottom:.875rem;font-size:1.3rem}
.tile-name{font-size:.95rem;font-weight:700;margin-bottom:.2rem}
.tile-desc{font-size:.8rem;color:var(--muted);margin-bottom:.875rem}
.tile-footer{display:flex;align-items:center;justify-content:space-between}
.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .6rem;
       border-radius:9999px;font-size:.75rem;font-weight:600}
.badge-green{background:rgba(109,170,69,.12);color:var(--success)}
.badge-red{background:rgba(221,105,116,.12);color:var(--error)}
.badge-yellow{background:rgba(253,171,67,.12);color:var(--warning)}
.badge-blue{background:rgba(79,152,163,.12);color:var(--primary)}
.badge-gray{background:var(--surface2);color:var(--muted)}
.status-dot{width:7px;height:7px;border-radius:50%;display:inline-block}
.dot-green{background:var(--success)}
.dot-red{background:var(--error)}
.dot-yellow{background:var(--warning)}
.dot-gray{background:var(--faint)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1rem;
     border-radius:var(--r);font-size:.875rem;font-weight:600;cursor:pointer;
     border:1px solid transparent;transition:all .15s}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-h)}
.btn-ghost{background:transparent;border-color:var(--border);color:var(--text)}
.btn-ghost:hover{background:var(--surface2)}
.btn-danger{background:rgba(221,105,116,.12);border-color:rgba(221,105,116,.25);color:var(--error)}
.btn-danger:hover{background:rgba(221,105,116,.2)}
.btn-sm{padding:.35rem .7rem;font-size:.8rem}

/* Tables */
.table-wrap{overflow-x:auto;border-radius:var(--r-lg);border:1px solid var(--border)}
table{width:100%;border-collapse:collapse}
th{background:var(--surface2);font-size:.78rem;font-weight:600;text-transform:uppercase;
   letter-spacing:.05em;color:var(--muted);padding:.75rem 1rem;text-align:left}
td{padding:.7rem 1rem;font-size:.875rem;border-top:1px solid var(--border)}
tr:first-child td{border-top:none}
tr:hover td{background:var(--surface2)}

/* Forms */
.form-group{margin-bottom:1.25rem}
.form-label{display:block;font-size:.85rem;font-weight:500;margin-bottom:.4rem}
.form-input{width:100%;background:var(--bg);border:1px solid var(--border);
            border-radius:var(--r);padding:.6rem .85rem;font-size:.9rem;
            transition:border-color .18s}
.form-input:focus{outline:none;border-color:var(--primary)}
.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2371717a' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
             background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.25rem}

/* Progress bars */
.prog-bar{background:var(--surface2);border-radius:9999px;height:6px;overflow:hidden}
.prog-fill{height:100%;border-radius:9999px;transition:width .5s ease;background:var(--primary)}
.prog-warn{background:var(--warning)}
.prog-danger{background:var(--error)}

/* Alerts */
.alert{padding:.75rem 1rem;border-radius:var(--r);font-size:.875rem;margin-bottom:1rem}
.alert-success{background:rgba(109,170,69,.1);border:1px solid rgba(109,170,69,.25);color:var(--success)}
.alert-error{background:rgba(221,105,116,.1);border:1px solid rgba(221,105,116,.25);color:var(--error)}
.alert-info{background:rgba(79,152,163,.1);border:1px solid rgba(79,152,163,.25);color:var(--primary)}
.alert-warning{background:rgba(253,171,67,.1);border:1px solid rgba(253,171,67,.25);color:var(--warning)}

/* Modal */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:100;
          display:none;align-items:center;justify-content:center;padding:1.5rem}
.modal-bg.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);
       padding:1.75rem;width:100%;max-width:520px;box-shadow:var(--sh-lg)}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}
.modal-title{font-size:1.1rem;font-weight:700}
.modal-close{color:var(--muted);padding:.25rem;border-radius:var(--r)}
.modal-close:hover{color:var(--text);background:var(--surface2)}
.modal-footer{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}

/* Code blocks */
.code-block{background:var(--bg);border:1px solid var(--border);border-radius:var(--r);
            padding:1rem;font-family:'Courier New',monospace;font-size:.8rem;
            color:#a8d8e8;overflow-x:auto;white-space:pre-wrap;word-break:break-all}

/* Tabs */
.tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:1.5rem;gap:.25rem}
.tab{padding:.55rem 1rem;font-size:.875rem;font-weight:500;color:var(--muted);
     border-bottom:2px solid transparent;cursor:pointer;transition:all .15s;margin-bottom:-1px}
.tab.active{color:var(--primary);border-bottom-color:var(--primary)}
.tab:hover{color:var(--text)}
.tab-panel{display:none}
.tab-panel.active{display:block}

/* Spinner */
.spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--border);
         border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Misc */
.divider{height:1px;background:var(--border);margin:1.25rem 0}
.text-muted{color:var(--muted)}
.text-sm{font-size:.85rem}
.text-xs{font-size:.78rem}
.mono{font-family:'Courier New',monospace;font-size:.82rem}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}
.flex{display:flex}.items-center{align-items:center}.gap-2{gap:.5rem}.gap-3{gap:.75rem}
.ml-auto{margin-left:auto}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}
.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}

/* Responsive */
@media(max-width:768px){
  .layout{grid-template-columns:1fr}
  .sidebar{display:none}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
}

/* Scrollbar */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--faint);border-radius:9999px}
