:root{
  --blush:#FAF4EF; --card:#FFFCFA; --ink:#1C1A18; --ink-soft:#75685D;
  --rose:#B28A6B; --rose-deep:#96714F; --rose-pale:#EBDDD0; --line:#E9DCD0;
  --green:#1E6B4F; --red:#9A3B3B; --shadow:0 8px 24px rgba(120,92,66,.10);
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Manrope',system-ui,sans-serif;background:var(--blush);color:var(--ink);min-height:100vh}

/* watermark */
.watermark{position:fixed;inset:0;display:grid;place-items:center;pointer-events:none;z-index:0}
.watermark img{width:min(75vmin,640px);height:auto;opacity:.08}

/* header */
header{position:relative;z-index:2;background:linear-gradient(180deg,#FFFCFA 0%,#F8EFE8 100%);border-bottom:1px solid var(--line)}
.gold-strip{height:4px;background:linear-gradient(90deg,#96714F,#D6B695 30%,#B28A6B 55%,#D6B695 80%,#96714F)}
.hwrap{max-width:1180px;margin:0 auto;padding:12px 22px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.logo-lockup{display:flex;align-items:center;gap:14px;text-decoration:none}
.logo-lockup img{height:60px;width:auto;display:block}
.portal-tag{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--rose-deep);font-weight:700;border-left:1px solid var(--line);padding-left:14px;line-height:1.6}
.hspacer{flex:1}
.user-chip{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:6px 8px 6px 6px}
.avatar{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:800;font-size:14px;background:var(--rose-deep)}
.user-chip .uname{font-size:13px;font-weight:700;line-height:1.1}
.user-chip .urole{font-size:11px;color:var(--rose-deep);font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.btn-link{display:inline-block;text-decoration:none;font-weight:700;font-size:13px;color:var(--ink-soft);padding:8px 14px;border:1px solid var(--line);border-radius:999px;background:#fff}
.btn-link:hover{color:var(--rose-deep);border-color:var(--rose)}

/* greeting */
.greet{max-width:1180px;margin:22px auto 6px;padding:0 22px;position:relative;z-index:2}
.greet h2{font-family:'Jost',sans-serif;font-weight:400;font-size:30px;letter-spacing:.02em}
.greet h2 em{font-style:normal;color:var(--rose-deep)}
.greet p{color:var(--ink-soft);font-size:14px;margin-top:4px}

/* grid + cards */
.grid{max-width:1180px;margin:20px auto 30px;padding:0 22px 10px;position:relative;z-index:2;display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:18px}
.tool{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);transition:transform .18s,box-shadow .18s;display:flex;flex-direction:column;text-decoration:none;color:inherit}
.tool:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(120,92,66,.18)}
.tool .bar{height:5px;background:linear-gradient(90deg,#D6B695,#B28A6B,#96714F)}
.tool .body{padding:18px 18px 14px;flex:1}
.ticon{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-size:22px;background:linear-gradient(135deg,#F7EDE3,#EDDCCB);border:1px solid var(--rose-pale);margin-bottom:12px}
.tool h3{font-family:'Jost',sans-serif;font-weight:500;font-size:17px;letter-spacing:.03em;margin-bottom:4px}
.tool .desc{font-size:12.5px;color:var(--ink-soft);line-height:1.5}
.tool .foot{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;padding:10px 18px;border-top:1px dashed var(--line);font-size:12px}
.badge{font-weight:800;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;border-radius:999px}
.live{background:#E7F3ED;color:var(--green)}
.soon{background:#F4E9DD;color:#8F6A3C}
.open{font-weight:700;color:var(--rose-deep)}
.role-tag{font-size:11px;color:var(--ink-soft)}
.role-tag b{color:var(--rose-deep)}
.tool.admin-card{background:linear-gradient(160deg,#241E19,#4A3A2C);border-color:#3a2d1d}
.tool.admin-card h3{color:#EFDFCD}.tool.admin-card .desc{color:#C9B49C}
.tool.admin-card .ticon{background:rgba(214,182,149,.15);border-color:rgba(214,182,149,.3)}
.tool.admin-card .foot{border-top-color:rgba(214,182,149,.25)}.tool.admin-card .open{color:#D6B695}

footer{position:relative;z-index:2;border-top:1px solid var(--line);padding:16px 22px 26px;text-align:center;font-size:12px;color:var(--ink-soft)}
footer b{color:var(--rose-deep)}

/* ---- login page ---- */
.login-wrap{position:relative;z-index:2;min-height:100vh;display:grid;place-items:center;padding:20px}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);width:100%;max-width:380px;padding:34px 30px;text-align:center}
.login-card img{height:84px;margin-bottom:6px}
.login-card .tag{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--rose-deep);font-weight:700;margin-bottom:22px}
.field{text-align:left;margin-bottom:14px}
.field label{display:block;font-size:12px;font-weight:700;color:var(--ink-soft);margin-bottom:6px;letter-spacing:.04em}
.field input{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font-size:14px;font-family:inherit;background:#fff}
.field input:focus{outline:none;border-color:var(--rose)}
.btn-gold{width:100%;border:0;cursor:pointer;font-family:inherit;font-weight:800;font-size:14px;letter-spacing:.04em;color:#fff;padding:13px;border-radius:10px;background:linear-gradient(135deg,#C8A37E,#96714F)}
.btn-gold:hover{filter:brightness(1.05)}
.login-err{background:#FBEAEA;color:var(--red);border:1px solid #EBC9C9;border-radius:8px;padding:10px;font-size:13px;margin-bottom:14px}

/* ---- admin ---- */
.wrap{max-width:1180px;margin:0 auto;padding:22px;position:relative;z-index:2}
.tabs{display:flex;gap:8px;margin:18px 0;flex-wrap:wrap}
.tabs button{border:1px solid var(--line);background:#fff;cursor:pointer;font-family:inherit;font-weight:700;font-size:13px;padding:9px 18px;border-radius:999px;color:var(--ink-soft)}
.tabs button.active{background:linear-gradient(135deg,#C8A37E,#96714F);color:#fff;border-color:transparent}
.panel{display:none}.panel.active{display:block}
.box{background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:20px;margin-bottom:18px}
.box h3{font-family:'Jost',sans-serif;font-weight:500;font-size:18px;margin-bottom:14px;color:var(--rose-deep)}
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--line)}
th{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft)}
.pill{font-size:10.5px;font-weight:800;text-transform:uppercase;padding:3px 9px;border-radius:999px}
.pill.owner{background:#F0E4D2;color:#8F6A3C}.pill.admin{background:#E7EDF3;color:#3A5A8F}.pill.staff{background:#E9F0EB;color:var(--green)}
.pill.off{background:#F3E3E3;color:var(--red)}
input[type=text],input[type=password],select{padding:9px 11px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:13px;background:#fff}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:end;margin-bottom:10px}
.row .field{margin:0}
.mini{border:0;cursor:pointer;font-family:inherit;font-weight:700;font-size:12px;color:#fff;padding:9px 14px;border-radius:8px;background:linear-gradient(135deg,#C8A37E,#96714F)}
.mini.ghost{background:#fff;color:var(--ink-soft);border:1px solid var(--line)}
.msg{background:#E7F3ED;color:var(--green);border:1px solid #C7E3D3;border-radius:8px;padding:10px 14px;font-size:13px;margin-bottom:14px}
.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.access-item{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:10px;padding:10px}
.access-item .ti{font-size:18px}.access-item .tn{font-weight:700;font-size:13px;flex:1}
@media(max-width:640px){.greet h2{font-size:24px}.portal-tag{display:none}.access-grid{grid-template-columns:1fr}}
