:root{
  --turq-1:#063a3e; --turq-2:#0a565c; --turq-3:#0e8a92;
  --ink:#0b2326; --line:rgba(255,255,255,.18);
  --glass:rgba(255,255,255,.10); --glass-2:rgba(255,255,255,.18);
  --txt:#ffffff; --muted:rgba(255,255,255,.78); --black:#000;
  --ok:#4ade80; --warn:#fbbf24; --err:#f87171;
  --radius:18px; --shadow:0 10px 40px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;min-height:100%;font-family:'Segoe UI',Roboto,system-ui,-apple-system,sans-serif;color:var(--txt)}
body{
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(14,138,146,.55), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(10,86,92,.6), transparent 60%),
    linear-gradient(135deg,#042b2e 0%, #063a3e 40%, #07494f 100%);
  background-attachment:fixed;
}
a{color:#bff7fb;text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:1200px;margin:0 auto;padding:20px}
.glass{background:var(--glass);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
header.site{position:sticky;top:0;z-index:50;background:rgba(4,30,32,.55);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line)}
.headwrap{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 20px;max-width:1200px;margin:0 auto;flex-wrap:wrap}
.logo{display:flex;align-items:center;gap:12px;font-weight:800;letter-spacing:.5px;color:#fff;min-width:0}
.logo:hover{text-decoration:none}
.logo svg{width:34px;height:34px;flex:0 0 auto}
.logo .brand{font-size:18px;display:block;line-height:1.1}
.logo .sub{font-weight:500;opacity:.85;font-size:11px;letter-spacing:1.2px;display:block;line-height:1.2;margin-top:2px}
.logo img{max-height:46px;border-radius:8px}
@media (max-width:560px){.logo .sub{font-size:10px;letter-spacing:.6px}.logo .brand{font-size:16px}.logo svg,.logo img{width:30px;height:30px;max-height:34px}}
nav.top{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
nav.top a{color:#fff;background:var(--glass-2);padding:8px 14px;border:1px solid var(--line);border-radius:999px;font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
nav.top a:hover{text-decoration:none;background:rgba(255,255,255,.18)}
nav.top .greet{padding:6px 10px;font-size:12px;color:var(--muted);background:transparent;border:none}
nav.top a.logout{background:rgba(127,29,29,.55);border-color:rgba(248,113,113,.4)}
@media (max-width:560px){
  .headwrap{padding:10px 12px;gap:8px}
  nav.top{width:100%;justify-content:space-between;gap:6px;order:3}
  nav.top a{flex:1 1 0;justify-content:center;padding:9px 8px;font-size:13px;text-align:center}
  nav.top a span.lbl{display:inline}
  nav.top .greet{display:none}
}
.hero{padding:48px 20px 28px;text-align:center;position:relative}
.hero .hero-headline{
  position:relative;
  display:block;
  max-width:980px;
  margin:0 auto;
  padding:34px clamp(20px,4vw,56px);
  border-radius:24px;
  border:1px solid var(--line);
  background:
    radial-gradient(1200px 200px at 50% -20%, rgba(191,247,251,.18), transparent 60%),
    radial-gradient(60% 90% at 0% 0%, rgba(14,138,146,.45), transparent 60%),
    radial-gradient(60% 90% at 100% 100%, rgba(74,222,128,.28), transparent 65%),
    linear-gradient(135deg, rgba(6,58,62,.85), rgba(10,86,92,.75) 55%, rgba(14,138,146,.7));
  background-size:200% 200%, 220% 220%, 220% 220%, 100% 100%;
  animation:heroShift 18s ease-in-out infinite;
  box-shadow:0 18px 60px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.08);
  overflow:hidden;
  isolation:isolate;
}
.hero .hero-headline::before{
  /* Soft moving glow that adapts to the surrounding space */
  content:"";position:absolute;inset:-40%;z-index:-1;
  background:conic-gradient(from 0deg, rgba(191,247,251,.0), rgba(191,247,251,.18), rgba(74,222,128,.16), rgba(14,138,146,.20), rgba(191,247,251,.0));
  filter:blur(40px);
  animation:heroSpin 22s linear infinite;
  opacity:.85;
}
.hero .hero-headline::after{
  /* Subtle grain/sheen line for depth */
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.55), transparent);
  opacity:.5;
}
.hero h1{
  position:relative;
  font-size:clamp(22px,3.4vw,34px);line-height:1.3;margin:0 auto;max-width:880px;font-weight:800;
  letter-spacing:.2px;
  text-shadow:0 2px 18px rgba(0,0,0,.35);
}
.hero p.lead{margin-top:18px;color:var(--muted);max-width:780px;margin-left:auto;margin-right:auto}
@keyframes heroShift{
  0%,100%{background-position: 0% 50%, 0% 0%, 100% 100%, 0 0}
  50%   {background-position:100% 50%,100% 50%,  0% 50%, 0 0}
}
@keyframes heroSpin{ to { transform:rotate(1turn) } }
@media (prefers-reduced-motion: reduce){
  .hero .hero-headline,.hero .hero-headline::before{animation:none}
}
@media (max-width:560px){
  .hero{padding:28px 12px 18px}
  .hero .hero-headline{padding:24px 18px;border-radius:20px}
}
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin:24px 0}
.step{padding:18px;border-radius:14px}
.step .n{display:inline-flex;width:32px;height:32px;align-items:center;justify-content:center;border-radius:50%;background:#fff;color:#063a3e;font-weight:800;margin-bottom:8px}
.search{padding:22px;display:grid;grid-template-columns:repeat(4,1fr);gap:12px;align-items:end}
@media (max-width:780px){.search{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.search{grid-template-columns:1fr}}
label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px;font-weight:600}
select,input,textarea,button{font-family:inherit;font-size:14px}
select,input,textarea{
  width:100%;padding:11px 12px;border-radius:10px;border:1px solid var(--line);
  background:rgba(255,255,255,.92);color:#0b2326;outline:none
}
select:focus,input:focus,textarea:focus{border-color:#fff;box-shadow:0 0 0 3px rgba(255,255,255,.25)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;border-radius:10px;border:1px solid var(--line);
  background:#fff;color:#063a3e;font-weight:700;cursor:pointer;transition:.15s;text-decoration:none}
.btn:hover{transform:translateY(-1px)}
.btn.ghost{background:transparent;color:#fff}
.btn.dark{background:#000;color:#fff}
.btn.danger{background:#7f1d1d;color:#fff;border-color:transparent}
.btn.warn{background:#a16207;color:#fff;border-color:transparent}
.btn.sm{padding:6px 10px;font-size:12px}
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-top:18px}
.card{padding:10px;border-radius:14px}
.card .ph{position:relative;aspect-ratio:3/4;border-radius:10px;overflow:hidden;background:#000;display:block}
.card .ph img{width:100%;height:100%;object-fit:cover;display:block;transition:opacity .25s ease}
.card .ph img.loading{opacity:.0}
.card .ph .skel{position:absolute;inset:0;background:linear-gradient(110deg,#0b2326 8%,#143539 18%,#0b2326 33%);background-size:200% 100%;animation:shine 1.2s linear infinite}
@keyframes shine{to{background-position-x:-200%}}
.card .ref{display:flex;justify-content:space-between;align-items:center;padding:10px 4px 4px;font-size:13px;gap:8px}
.card .ref b{font-family:'Courier New',monospace;letter-spacing:1px;background:#000;color:#fff;padding:2px 8px;border-radius:6px}
.card .ref .lbl{color:var(--muted);font-weight:600;font-size:12px}
.modal{position:fixed;inset:0;background:rgba(0,0,0,.65);display:none;align-items:flex-start;justify-content:center;padding:16px;z-index:80;overflow-y:auto;-webkit-overflow-scrolling:touch}
.modal.show{display:flex}
.modal .box{max-width:780px;width:100%;max-height:calc(100vh - 32px);overflow-y:auto;padding:22px;margin:auto;-webkit-overflow-scrolling:touch}
.modal h2{margin:0 0 4px}
.muted{color:var(--muted)}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.tbl{width:100%;border-collapse:collapse}
.tbl th,.tbl td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--line);font-size:14px}
.tbl th{color:var(--muted);font-weight:600}
.totals{display:flex;justify-content:space-between;align-items:center;padding:14px 4px 0;font-weight:800;font-size:18px}
.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700;background:#fff;color:#063a3e}
.badge.ok{background:#bbf7d0;color:#064e2a}
.badge.no{background:#fecaca;color:#7f1d1d}
.badge.warn{background:#fde68a;color:#78350f}
.footer{margin-top:40px;padding:28px 20px;text-align:center;color:var(--muted);border-top:1px solid var(--line);background:rgba(0,0,0,.25)}
.flash{padding:12px 14px;border-radius:10px;margin:14px 0;background:rgba(255,255,255,.15);border:1px solid var(--line)}
.flash.err{background:rgba(248,113,113,.2)}
.flash.ok{background:rgba(74,222,128,.18)}
/* ----- Order modal ----- */
.instruction{background:rgba(255,235,150,.18);border:1px dashed rgba(255,235,150,.6);color:#fff8c5;padding:10px 12px;border-radius:10px;margin:10px 0;font-size:14px;font-weight:600}
.pick{display:block;padding:14px;margin-bottom:10px;cursor:pointer;border-radius:12px;border:2px solid transparent;background:rgba(255,255,255,.08);transition:.15s}
.pick:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.45);transform:translateY(-1px)}
.pick.selected{background:rgba(74,222,128,.18);border-color:#4ade80;box-shadow:0 0 0 3px rgba(74,222,128,.15)}
.pick input[type=checkbox]{width:20px;height:20px;accent-color:#0e8a92;margin-right:8px;vertical-align:middle}
.qty{display:inline-flex;align-items:center;gap:4px;background:#fff;border-radius:8px;padding:2px;border:1px solid var(--line)}
.qty button{background:#063a3e;color:#fff;border:none;width:28px;height:28px;border-radius:6px;font-weight:800;cursor:pointer;font-size:16px;line-height:1}
.qty button:disabled{opacity:.4;cursor:not-allowed}
.qty input{width:48px;text-align:center;background:transparent;border:none;color:#063a3e;font-weight:800;padding:4px}
.section-title{display:flex;align-items:center;gap:8px;margin:18px 0 8px;font-size:16px;font-weight:800;flex-wrap:wrap}
.section-title .pill{background:#0e8a92;color:#fff;font-size:11px;padding:3px 8px;border-radius:999px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
textarea{min-height:90px;resize:vertical;font-family:inherit}
/* ----- Bank details list (mobile-friendly) ----- */
.bank-list{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:8px}
@media (max-width:640px){.bank-list{grid-template-columns:1fr}}
.bank-list .row-item{background:rgba(255,255,255,.10);border:1px solid var(--line);border-radius:10px;padding:10px 12px;display:flex;flex-direction:column;gap:2px}
.bank-list .row-item .k{color:var(--muted);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.bank-list .row-item .v{font-weight:700;word-break:break-word;font-size:15px}
.bank-list .row-item.full{grid-column:1 / -1;background:rgba(74,222,128,.15);border-color:#4ade80}
/* ----- ADMIN ----- */
.admin-wrap{display:grid;grid-template-columns:240px 1fr;gap:18px;padding:18px}
@media (max-width:900px){.admin-wrap{grid-template-columns:1fr}}
.side{padding:14px;height:fit-content;position:sticky;top:80px}
.side a{display:block;padding:10px 12px;border-radius:10px;color:#fff;margin-bottom:4px;font-weight:600;font-size:14px}
.side a.active,.side a:hover{background:var(--glass-2);text-decoration:none}
/* Sidebar mobile toggle (hidden on desktop) */
.side-toggle{display:none}
@media (max-width:900px){
  .side-toggle{
    display:inline-flex;align-items:center;gap:10px;width:100%;
    padding:12px 16px;border-radius:14px;cursor:pointer;
    background:var(--glass);border:1px solid var(--line);color:#fff;
    font-weight:700;font-size:14px;letter-spacing:.3px;
    backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
    box-shadow:var(--shadow);transition:background .2s, transform .15s;
  }
  .side-toggle:hover{background:var(--glass-2)}
  .side-toggle:active{transform:scale(.99)}
  .side-toggle .lbl{flex:1;text-align:left}
  .side-toggle .chev{display:inline-block;transition:transform .25s;font-size:18px;line-height:1}
  .side-toggle.is-open .chev{transform:rotate(180deg)}
  .side{position:relative;top:0;overflow:hidden;
    transition:max-height .3s ease, padding .3s ease, opacity .25s ease, margin .3s ease;}
  .side[data-collapsed="true"]{
    max-height:0;padding-top:0;padding-bottom:0;margin:0;opacity:0;
    border:0;pointer-events:none;
  }
  .side[data-collapsed="false"]{ max-height:1200px;opacity:1; }
}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:16px}
.stat{padding:18px;border-radius:14px;text-align:left;cursor:pointer;transition:.15s;border:1px solid var(--line);color:#fff}
.stat:hover{transform:translateY(-2px);background:var(--glass-2);text-decoration:none}
.stat .n{font-size:28px;font-weight:800}
.stat .l{color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:1px}
.stat.revenue{background:linear-gradient(135deg,rgba(74,222,128,.25),rgba(14,138,146,.25));border-color:#4ade80}
.section{padding:18px;margin-bottom:16px;position:relative}
.section h2{margin:0 0 12px;font-size:18px}
/* Collapsible admin sections — toggle button only visible on mobile */
.sec-toggle{display:none;position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:50%;
  background:var(--glass-2);border:1px solid var(--line);color:#fff;font-size:20px;font-weight:800;
  cursor:pointer;align-items:center;justify-content:center;line-height:1;transition:.2s;padding:0;z-index:5}
.sec-toggle:hover{background:rgba(255,255,255,.18)}
.sec-toggle .icn{display:inline-block;transition:transform .25s}
.section.collapsed .sec-toggle .icn{transform:rotate(-90deg)}
.section.collapsed > :not(h1):not(h2):not(.sec-toggle){display:none !important}
.section.collapsed{padding-bottom:14px}
@media (max-width:900px){
  .sec-toggle{display:inline-flex}
  .section{padding-right:60px}
}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:700px){.grid2{grid-template-columns:1fr}}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media (max-width:700px){.grid3{grid-template-columns:1fr}}
.thumb{width:60px;height:80px;object-fit:cover;border-radius:6px;background:#000}
.login-wrap{min-height:80vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login-box{max-width:420px;width:100%;padding:28px}
.kbd{font-family:monospace;background:#000;color:#fff;padding:2px 8px;border-radius:6px}
.scroll-x{overflow-x:auto}
hr.sep{border:none;border-top:1px solid var(--line);margin:14px 0}
.item-row{display:flex;gap:8px;align-items:center;margin-bottom:8px;padding:8px;background:rgba(255,255,255,.06);border-radius:8px;border:1px solid var(--line);flex-wrap:wrap}
.item-row input{flex:1;min-width:120px}
.btn.add{background:#0e8a92;color:#fff;border-color:transparent}
.btn.remove{background:#7f1d1d;color:#fff;border-color:transparent;padding:8px 12px}
.upload-progress{height:8px;background:rgba(0,0,0,.3);border-radius:99px;overflow:hidden;margin-top:8px;display:none}
.upload-progress .bar{height:100%;background:linear-gradient(90deg,#0e8a92,#4ade80);width:0;transition:width .25s}
.upload-log{max-height:160px;overflow:auto;font-family:monospace;font-size:12px;padding:8px;border-radius:8px;background:rgba(0,0,0,.3);margin-top:8px;display:none}
/* Toast */
#toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(40px);opacity:0;background:#063a3e;color:#fff;padding:12px 18px;border-radius:10px;border:1px solid var(--line);z-index:200;transition:.25s;font-weight:600;max-width:90vw;text-align:center}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast.err{background:#7f1d1d}
#toast.ok{background:#065f46}
/* Confirm dialog */
.confirm-dlg{position:fixed;inset:0;background:rgba(0,0,0,.7);display:none;align-items:center;justify-content:center;z-index:300;padding:20px}
.confirm-dlg.show{display:flex}
.confirm-dlg .box{background:#063a3e;border:1px solid var(--line);border-radius:14px;padding:22px;max-width:420px;width:100%;color:#fff;box-shadow:var(--shadow)}