/* The AppWT Library — © 1997-2026 AppWT Web & AI Solutions (AppWT LLC) */
:root{
  --navy:#0F2744; --green:#1B4332; --gold:#C4A052; --pearl:#FAFAFA;
  --slate:#334155; --charcoal:#1E2432; --line:#e2e8f0; --muted:#64748b;
  --sidebar-w:280px;
}
*{box-sizing:border-box}
html,body{max-width:100%;overflow-x:hidden}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--slate);background:#f4f5f7;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto}
a{color:var(--green)}

/* ---------- LOGIN ---------- */
.login-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--navy),var(--green));padding:24px}
.login-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.3);padding:40px 36px;width:100%;max-width:400px;text-align:center}
.login-logo{height:64px;width:auto;margin:0 auto 14px;display:block}
.login-card h1{font-size:22px;color:var(--navy);margin:0 0 4px}
.login-sub{color:var(--muted);font-size:13px;margin:0 0 22px}
.login-card form{text-align:left}
.login-card label{display:block;font-size:12px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px}
.login-card input{display:block;width:100%;margin-top:6px;padding:12px 14px;border:1px solid var(--line);border-radius:8px;font-size:15px}
.login-card input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(196,160,82,.18)}
.login-card button{width:100%;margin-top:6px;padding:13px;border:0;border-radius:8px;background:var(--gold);color:var(--navy);font-weight:800;font-size:15px;cursor:pointer;letter-spacing:.3px}
.login-card button:hover{background:#b8954a}
.login-err{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;border-radius:8px;padding:10px 12px;font-size:13px;margin-bottom:16px}
.login-foot{font-size:12px;color:var(--muted);margin:18px 0 0}
.login-legal{color:rgba(255,255,255,.7);font-size:11px;margin-top:22px;text-align:center}

/* ---------- TOPBAR ---------- */
.topbar{position:fixed;top:0;left:0;right:0;height:60px;background:var(--navy);display:flex;align-items:center;gap:14px;padding:0 18px;z-index:50;box-shadow:0 2px 10px rgba(15,39,68,.18)}
.hamburger{display:none;background:none;border:0;color:#fff;font-size:22px;cursor:pointer;padding:4px 8px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand img{height:34px;width:auto}
.brand span{color:#fff;font-weight:800;font-size:16px;letter-spacing:.2px}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:16px}
.who{color:#cbd5e1;font-size:13px}
.who strong{color:#fff}
.logout{color:var(--gold);text-decoration:none;font-weight:700;font-size:13px;border:1px solid rgba(196,160,82,.5);padding:6px 14px;border-radius:7px}
.logout:hover{background:rgba(196,160,82,.15)}

/* ---------- SHELL ---------- */
.shell{display:flex;padding-top:60px;min-height:100vh}
.sidebar{position:fixed;top:60px;bottom:0;left:0;width:var(--sidebar-w);background:#fff;border-right:1px solid var(--line);overflow-y:auto;display:flex;flex-direction:column;z-index:40}
.sidebar nav{flex:1;padding:12px 10px}
.nav-group{margin-bottom:4px}
.nav-head{width:100%;display:flex;align-items:center;gap:10px;background:none;border:0;padding:11px 12px;border-radius:9px;cursor:pointer;color:var(--navy);font-size:14.5px;font-weight:700;text-align:left}
.nav-head:hover{background:#f1f5f9}
.nav-head .nav-label{flex:1}
.nav-head .count{font-size:11px;font-weight:700;color:var(--muted);background:#eef2f7;border-radius:20px;padding:2px 8px}
.nav-head .chev{color:var(--gold);font-size:18px;transition:transform .18s ease}
.nav-group.open .nav-head{background:#f8fafc;color:var(--green)}
.nav-group.open .nav-head .chev{transform:rotate(90deg)}
.nav-items{list-style:none;margin:2px 0 6px;padding:0;max-height:0;overflow:hidden;transition:max-height .22s ease}
.nav-group.open .nav-items{max-height:1400px}
.nav-items li a{display:block;padding:8px 12px 8px 40px;color:var(--slate);text-decoration:none;font-size:13.5px;border-radius:8px;line-height:1.35}
.nav-items li a:hover{background:#f1f5f9;color:var(--navy)}
.nav-items li a.active{background:rgba(27,67,50,.10);color:var(--green);font-weight:700}
.sidebar-foot{padding:14px 18px;border-top:1px solid var(--line);font-size:11px;color:var(--muted);line-height:1.5}

/* icons (simple css badges) */
.ico{width:18px;height:18px;border-radius:5px;flex:0 0 18px;background:var(--gold)}
.ico-wp{background:#21759b}.ico-magento{background:#f46f25}.ico-custom{background:var(--green)}
.ico-server{background:var(--navy)}.ico-training{background:#7c3aed}.ico-resource{background:#0ea5e9}
.ico.big{width:34px;height:34px;border-radius:9px}

/* ---------- CONTENT ---------- */
.content{margin-left:var(--sidebar-w);flex:1;padding:30px 34px 60px;min-width:0}
.panel{max-width:860px}
.welcome h1{font-size:28px;color:var(--navy);margin:0 0 10px}
.lede{font-size:15px;color:var(--slate);line-height:1.7;margin:0 0 26px}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}
.card{background:#fff;border:1px solid var(--line);border-radius:13px;padding:22px 18px;display:flex;flex-direction:column;align-items:flex-start;gap:8px;cursor:pointer;text-align:left;box-shadow:0 2px 10px rgba(15,39,68,.05);transition:transform .12s ease,box-shadow .12s ease}
.card:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(15,39,68,.10)}
.card-t{font-size:16px;font-weight:800;color:var(--navy)}
.card-n{font-size:12px;color:var(--muted)}

.detail .crumb{font-size:11px;letter-spacing:1.2px;text-transform:uppercase;color:var(--gold);font-weight:800;margin-bottom:8px}
.detail-head{display:flex;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:8px}
.detail-head h1{font-size:25px;color:var(--navy);margin:0}
.badge{font-size:11px;font-weight:700;padding:4px 11px;border-radius:20px;background:var(--green);color:#fff;text-transform:uppercase;letter-spacing:.5px}
.tagline{font-size:15px;color:#475569;line-height:1.6;margin:0 0 20px;font-weight:500}
.sec{margin:18px 0}
.sec h3{font-size:11px;letter-spacing:1.2px;text-transform:uppercase;color:var(--gold);font-weight:800;margin:0 0 7px}
.sec p{font-size:14.5px;color:var(--slate);line-height:1.7;margin:0}
.actions{margin-top:26px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;text-decoration:none;padding:12px 24px;border-radius:9px;font-weight:800;font-size:14px;border:0;cursor:pointer}
.btn.dl{background:var(--green);color:#fff}.btn.dl:hover{background:#163728}
.btn.visit{background:var(--navy);color:#fff}.btn.visit:hover{background:#0a1c30}
.muted{color:var(--muted);font-size:13.5px}

/* ---------- RESPONSIVE ---------- */
.backdrop{display:none}
@media(max-width:860px){
  .hamburger{display:block}
  .sidebar{transform:translateX(-100%);transition:transform .2s ease;box-shadow:2px 0 20px rgba(0,0,0,.18)}
  body.nav-open .sidebar{transform:translateX(0)}
  .content{margin-left:0;padding:22px 16px 48px}
  body.nav-open .backdrop{display:block;position:fixed;inset:60px 0 0 0;background:rgba(0,0,0,.4);z-index:35}
}

/* ---------- ACCOUNT / ADMIN pages ---------- */
.page{padding:84px 24px 60px;max-width:960px;margin:0 auto}
.flash-ok{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46;border-radius:9px;padding:12px 16px;margin:0 0 18px;font-size:14px;word-break:break-word}
.flash-err{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;border-radius:9px;padding:12px 16px;margin:0 0 18px;font-size:14px}
.adm-tabs{display:flex;gap:8px;margin-bottom:20px}
.adm-tabs a{padding:9px 20px;border-radius:9px;text-decoration:none;font-weight:700;font-size:14px;color:var(--navy);background:#fff;border:1px solid var(--line)}
.adm-tabs a.on{background:var(--navy);color:#fff;border-color:var(--navy)}
.adm-table{width:100%;border-collapse:collapse;margin:10px 0 6px;background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.adm-table th{background:#f8fafc;text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:10px 12px}
.adm-table td{padding:10px 12px;border-top:1px solid var(--line);font-size:13.5px;vertical-align:middle}
.adm-table em{color:var(--gold);font-style:normal;font-size:11px}
.adm-actions{display:flex;gap:8px;flex-wrap:wrap}
form.inline{display:inline}
.mini{padding:6px 12px;border-radius:7px;border:1px solid var(--line);background:#fff;color:var(--navy);font-weight:700;font-size:12.5px;cursor:pointer}
.mini:hover{background:#f1f5f9}
.mini.danger{border-color:#fecaca;color:#b91c1c}
.mini.danger:hover{background:#fef2f2}
.grid-form{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:10px}
.grid-form label,.stack label{display:block;font-size:12px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.4px}
.grid-form label.wide{grid-column:1/-1}
.grid-form input,.grid-form select,.grid-form textarea,.stack input,.stack textarea{display:block;width:100%;margin-top:6px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;font-size:14px;font-family:inherit;text-transform:none;font-weight:400}
.grid-form button{grid-column:1/-1;justify-self:start}
.stack{display:flex;flex-direction:column;gap:12px;max-width:560px}
.adm-cat{font-size:16px;color:var(--navy);margin:26px 0 8px;border-top:1px solid var(--line);padding-top:18px}
.adm-item{background:#fff;border:1px solid var(--line);border-radius:9px;margin-bottom:8px;padding:4px 14px}
.adm-item summary{cursor:pointer;padding:10px 4px;font-size:14px}
.adm-item .stack{max-width:100%;margin:10px 0}
.row-actions{display:flex;gap:10px;align-items:center}
select:disabled{opacity:.6}
@media(max-width:640px){.grid-form{grid-template-columns:1fr}}
