/* ==========================================================================
   OLIAC PHOTO LINK — industrial dark/green theme
   ========================================================================== */
:root{
  --ink:#0c0f0d;
  --panel:#141816;
  --panel-2:#1b201d;
  --line:#2a312d;
  --line-2:#374039;
  --fg:#e6ebe7;
  --muted:#8c958f;
  --green:#1f7a4d;
  --green-bright:#2fa968;
  --green-deep:#11402a;
  --green-tint:rgba(47,169,104,.12);
  --danger:#c0492f;
  --danger-bright:#e0654a;
  --warn:#caa24a;
  --radius:14px;
  --radius-lg:22px;
  --shadow:0 8px 30px rgba(0,0,0,.45);
  --mono:ui-monospace,"SFMono-Regular",Menlo,Consolas,"Liberation Mono",monospace;
  --sans:"Segoe UI",system-ui,-apple-system,Roboto,"Helvetica Neue",Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:
    radial-gradient(1200px 600px at 80% -10%, #10241a 0%, transparent 60%),
    var(--ink);
  color:var(--fg);
  font-family:var(--sans);
  font-size:15px;
  line-height:1.55;
  min-height:100vh;
}
a{color:var(--green-bright);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{margin:0 0 .4em;font-weight:700;letter-spacing:.2px}
img{max-width:100%}

/* ---- layout ---- */
.wrap{max-width:1180px;margin:0 auto;padding:0 20px}
.main{padding:28px 0 70px}
.section-title{display:flex;align-items:center;gap:12px;margin:6px 0 22px}
.section-title h1{font-size:24px;margin:0}
.section-title .sub{color:var(--muted);font-size:13px}

/* ---- header ---- */
.topbar{
  position:sticky;top:0;z-index:40;
  background:rgba(12,15,13,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.topbar .wrap{display:flex;align-items:center;gap:18px;height:70px}
.brand img{height:40px;display:block}
.topbar nav{display:flex;gap:6px;margin-left:8px}
.topbar nav a{
  color:var(--muted);padding:8px 14px;border-radius:10px;font-weight:600;
  font-size:14px;text-decoration:none;transition:.15s;
}
.topbar nav a:hover{color:var(--fg);background:var(--panel-2)}
.topbar nav a.active{color:var(--fg);background:var(--green-tint);box-shadow:inset 0 0 0 1px var(--green)}
.topbar .spacer{flex:1}

.diskmeter{min-width:188px}
.diskmeter .dm-row{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);margin-bottom:4px}
.diskmeter .dm-row b{color:var(--fg);font-family:var(--mono)}
.dm-bar{height:7px;border-radius:5px;background:var(--panel-2);overflow:hidden;box-shadow:inset 0 0 0 1px var(--line)}
.dm-fill{height:100%;background:linear-gradient(90deg,var(--green),var(--green-bright))}
.dm-fill.hot{background:linear-gradient(90deg,#8a3a26,var(--danger-bright))}

.userchip{display:flex;align-items:center;gap:10px}
.userchip .who{font-size:13px;line-height:1.2}
.userchip .who b{display:block;color:var(--fg)}
.userchip .who span{color:var(--muted);font-size:11px}
.badge-admin{font-size:10px;font-weight:700;letter-spacing:.5px;color:#0c0f0d;
  background:var(--green-bright);padding:2px 7px;border-radius:6px}
.badge-viewer{background:var(--muted);color:#0c0f0d}

/* viewer lookup page */
.lookup-wrap{display:flex;justify-content:center;padding:40px 0}
.lookup-card{max-width:480px;width:100%;text-align:center}
.lookup-card h1{margin:6px 0 4px;font-size:22px}
.lookup-card p.muted{margin:0 0 18px}
.lookup-ico{width:54px;height:54px;margin:0 auto 6px;color:var(--green-bright)}
.lookup-ico svg{width:100%;height:100%}
.lookup-form{display:flex;gap:10px;align-items:stretch}
.lookup-form input{flex:1;text-align:center;font-size:16px;letter-spacing:.5px}
.lookup-form .btn{flex:none}
@media (max-width:480px){.lookup-form{flex-direction:column}}
.lookup-matches{margin-top:18px;text-align:left;border-top:1px solid var(--line);padding-top:14px}
.lookup-matches-h{font-size:13px;color:var(--muted);margin-bottom:10px}
.lookup-match{display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:9px 12px;border:1px solid var(--line);border-radius:10px;margin-bottom:8px;
  background:var(--panel-2);transition:border-color .12s,transform .12s}
.lookup-match:hover{border-color:var(--green);transform:translateY(-1px)}
.lookup-match .muted{font-family:var(--mono);font-size:12px}

.langtoggle{display:flex;border:1px solid var(--line);border-radius:9px;overflow:hidden}
.langtoggle a{padding:6px 10px;font-size:12px;font-weight:700;color:var(--muted)}
.langtoggle a.on{background:var(--green);color:#fff}
.langtoggle a:hover{text-decoration:none;color:var(--fg)}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font:inherit;font-weight:700;cursor:pointer;border:1px solid var(--line-2);
  background:var(--panel-2);color:var(--fg);padding:10px 18px;border-radius:11px;
  transition:.15s;text-decoration:none;line-height:1;
}
.btn:hover{border-color:var(--green);text-decoration:none}
.btn:focus-visible{outline:2px solid var(--green-bright);outline-offset:2px}
.btn-primary{background:linear-gradient(180deg,var(--green-bright),var(--green));border-color:transparent;color:#fff}
.btn-primary:hover{filter:brightness(1.07);border-color:transparent}
.btn-danger{background:transparent;border-color:#5e2c20;color:var(--danger-bright)}
.btn-danger:hover{background:rgba(192,73,47,.12);border-color:var(--danger)}
.btn-ghost{background:transparent}
.btn-sm{padding:6px 11px;font-size:12.5px;border-radius:9px}
.btn[disabled]{opacity:.5;cursor:not-allowed}

/* ---- cards / panels ---- */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.panel + .panel{margin-top:18px}
.grid{display:grid;gap:18px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}

/* dashboard action cards */
.actiongrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:8px}
.action{
  position:relative;display:block;border-radius:var(--radius-lg);
  background:linear-gradient(180deg,var(--panel-2),var(--panel));
  border:1px solid var(--line);padding:30px 26px;min-height:172px;
  transition:.18s;overflow:hidden;text-decoration:none;color:var(--fg);
}
.action:hover{transform:translateY(-3px);border-color:var(--green);box-shadow:var(--shadow);text-decoration:none}
.action .ico{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;
  background:var(--green-tint);box-shadow:inset 0 0 0 1px var(--green);margin-bottom:18px}
.action .ico svg{width:26px;height:26px;stroke:var(--green-bright)}
.action h3{font-size:20px;margin:0 0 4px}
.action p{color:var(--muted);font-size:13px;margin:0}
.action .arrow{position:absolute;right:22px;bottom:22px;color:var(--muted);transition:.18s}
.action:hover .arrow{color:var(--green-bright);transform:translateX(3px)}

/* ---- forms ---- */
label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin:0 0 6px}
.req:after{content:" *";color:var(--green-bright)}
input[type=text],input[type=password],input[type=date],input[type=search],select,textarea{
  width:100%;background:var(--ink);color:var(--fg);border:1px solid var(--line-2);
  border-radius:10px;padding:11px 13px;font:inherit;transition:.15s;
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-tint)}
textarea{resize:vertical;min-height:84px}
.field{margin-bottom:16px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.hint{font-size:12px;color:var(--muted);margin-top:5px}
.mono{font-family:var(--mono)}

/* dropzone */
.dropzone{
  border:2px dashed var(--line-2);border-radius:var(--radius);
  background:var(--ink);padding:34px 20px;text-align:center;cursor:pointer;transition:.15s;
}
.dropzone:hover,.dropzone.drag{border-color:var(--green);background:var(--green-tint)}
.dropzone .dz-ico{width:46px;height:46px;margin:0 auto 12px;color:var(--green-bright)}
.dropzone b{color:var(--fg)}
.dz-list{margin-top:14px;display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.dz-chip{font-size:12px;font-family:var(--mono);background:var(--panel-2);
  border:1px solid var(--line);border-radius:8px;padding:5px 9px;color:var(--fg);
  display:inline-flex;align-items:center;gap:8px;max-width:100%}
.dz-chip .dz-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}
.dz-chip .dz-size{color:var(--muted);flex:none}
.hint.hint-warn{color:var(--warn);font-weight:600}

/* ---- chassis tag (signature element) ---- */
.chassis{
  display:inline-flex;align-items:center;font-family:var(--mono);font-size:13px;
  font-weight:600;color:var(--fg);background:var(--panel-2);
  border:1px solid var(--line-2);border-left:3px solid var(--green-bright);
  border-radius:7px;padding:4px 10px 4px 9px;letter-spacing:.3px;
}
.chassis.big{font-size:16px;padding:7px 14px 7px 12px}

/* ---- tables ---- */
.tablewrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius)}
table{width:100%;border-collapse:collapse;font-size:14px}
thead th{
  text-align:left;font-size:11.5px;letter-spacing:.6px;text-transform:uppercase;
  color:var(--muted);background:var(--panel-2);padding:12px 14px;border-bottom:1px solid var(--line);white-space:nowrap;
}
tbody td{padding:12px 14px;border-bottom:1px solid var(--line)}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:rgba(255,255,255,.02)}
.t-right{text-align:right}
.t-center{text-align:center}

/* ---- pills / status ---- */
.pill{display:inline-block;font-size:11px;font-weight:700;border-radius:20px;padding:3px 10px;letter-spacing:.3px}
.pill-photo{background:var(--green-tint);color:var(--green-bright);box-shadow:inset 0 0 0 1px var(--green)}
.pill-video{background:rgba(202,162,74,.14);color:var(--warn);box-shadow:inset 0 0 0 1px #6a571f}
.pill-mistake{background:rgba(192,73,47,.16);color:var(--danger-bright);box-shadow:inset 0 0 0 1px #5e2c20}
.pill-blocked{background:rgba(192,73,47,.16);color:var(--danger-bright)}
.pill-ok{background:var(--green-tint);color:var(--green-bright)}

/* ---- gallery ---- */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px}
.gcard{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.gcard .thumb{aspect-ratio:4/3;background:var(--ink);display:block;object-fit:cover;width:100%}
.gcard .gmeta{padding:9px 11px;font-size:12px;color:var(--muted);display:flex;justify-content:space-between;align-items:center;gap:8px}
.gcard .gmeta .fn{font-family:var(--mono);color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ---- alerts ---- */
.alert{border-radius:11px;padding:13px 16px;font-size:14px;margin-bottom:18px;border:1px solid}
.alert-ok{background:var(--green-tint);border-color:var(--green);color:#bdeacd}
.alert-err{background:rgba(192,73,47,.12);border-color:#5e2c20;color:var(--danger-bright)}
.alert-warn{background:rgba(202,162,74,.1);border-color:#6a571f;color:#e7cf8f}
.alert b{color:#fff}

/* ---- login ---- */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}
.login-card{width:100%;max-width:400px;background:var(--panel);border:1px solid var(--line);
  border-radius:20px;padding:34px 30px;box-shadow:var(--shadow)}
.login-card .logo{display:flex;justify-content:center;margin-bottom:8px}
.login-card .logo img{height:54px}
.login-card .tag{text-align:center;color:var(--muted);font-size:13px;margin-bottom:26px}

/* ---- misc ---- */
.toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:18px}
.toolbar .spacer{flex:1}
.muted{color:var(--muted)}
.empty{text-align:center;color:var(--muted);padding:46px 20px}
.empty svg{width:44px;height:44px;opacity:.5;margin-bottom:10px}
.pager{display:flex;gap:6px;justify-content:center;margin-top:22px;flex-wrap:wrap}
.pager a,.pager span{padding:7px 12px;border-radius:9px;border:1px solid var(--line);font-size:13px;color:var(--muted)}
.pager a:hover{border-color:var(--green);color:var(--fg);text-decoration:none}
.pager .cur{background:var(--green);border-color:var(--green);color:#fff}
.stat{display:flex;flex-direction:column;gap:3px}
.stat .v{font-size:26px;font-weight:800;font-family:var(--mono)}
.stat .k{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.checkcell input{width:16px;height:16px;accent-color:var(--green-bright)}
.footer{color:var(--muted);font-size:12px;text-align:center;padding:22px 0 8px}

/* ---- responsive ---- */
@media(max-width:820px){
  .actiongrid,.grid-3{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .topbar .wrap{height:auto;flex-wrap:wrap;padding-top:12px;padding-bottom:12px;gap:12px}
  .topbar nav{order:3;width:100%;margin-left:0;overflow-x:auto}
  .diskmeter{min-width:140px}
  .brand img{height:34px}
}
@media(max-width:480px){
  .userchip .who{display:none}
  .diskmeter{display:none}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}

/* ---------- gallery lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;
  background:rgba(7,9,8,.94);backdrop-filter:blur(3px)}
.lightbox[hidden]{display:none}
.lb-stage{max-width:92vw;max-height:80vh;display:flex;align-items:center;justify-content:center}
.lb-media{max-width:92vw;max-height:80vh;width:auto;height:auto;object-fit:contain;
  border-radius:10px;box-shadow:0 12px 50px rgba(0,0,0,.6);background:#000}
.lb-btn{position:absolute;background:rgba(20,24,22,.78);color:var(--fg);border:1px solid var(--line-2);
  cursor:pointer;border-radius:12px;line-height:1;transition:background .12s,border-color .12s}
.lb-btn:hover{background:var(--green-deep);border-color:var(--green)}
.lb-close{top:16px;right:16px;width:42px;height:42px;font-size:26px}
.lb-prev,.lb-next{top:50%;transform:translateY(-50%);width:52px;height:64px;font-size:34px;font-weight:700}
.lb-prev{left:14px}
.lb-next{right:14px}
.lb-bar{position:absolute;left:0;right:0;bottom:18px;display:flex;align-items:center;justify-content:center;
  gap:16px;flex-wrap:wrap;padding:0 16px}
.lb-count{font-family:var(--mono);font-size:13px;color:var(--fg);background:rgba(20,24,22,.78);
  border:1px solid var(--line);border-radius:8px;padding:7px 12px;max-width:70vw;overflow:hidden;
  text-overflow:ellipsis;white-space:nowrap}
@media (max-width:560px){
  .lb-prev,.lb-next{width:42px;height:54px;font-size:28px}
  .lb-close{width:38px;height:38px;font-size:23px;top:10px;right:10px}
  .lb-media{max-height:70vh}
}
