/* ============================================================
   Project Dashboard — "Control Room"
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Sarabun:wght@400;500;600;700&family=Space+Grotesk:wght@500;600;700&family=JetBrains+Mono:wght@500;600&display=swap');

:root {
  --ink-0: #101116; --ink-1: #16181F; --ink-2: #1D2029; --ink-3: #262A35;
  --line: #2A2E3A; --line-soft: #20232C;
  --fg: #ECEEF2; --fg-2: #9DA3B4; --fg-3: #646A7C;
  --mint: #5EE3A0; --mint-dk: #2BB87A; --mint-bg: rgba(94,227,160,0.10); --mint-line: rgba(94,227,160,0.28);
  --amber: #F5C56B; --amber-bg: rgba(245,197,107,0.10);
  --rose: #F4796B; --rose-bg: rgba(244,121,107,0.10);
  --violet: #A78BFA; --violet-bg: rgba(167,139,250,0.10);
  --r-sm: 8px; --r: 12px; --r-lg: 16px;
  --font-display: 'Space Grotesk','Sarabun',sans-serif;
  --font-body: 'Sarabun',-apple-system,BlinkMacSystemFont,sans-serif;
  --font-mono: 'JetBrains Mono',ui-monospace,monospace;
}
* { box-sizing: border-box; }
body { margin: 0; font-family: var(--font-body); background: var(--ink-0); color: var(--fg); line-height: 1.6; font-size: 15px; -webkit-font-smoothing: antialiased; }
body::before { content: ''; position: fixed; inset: 0; background-image: radial-gradient(circle at 1px 1px, rgba(255,255,255,0.025) 1px, transparent 0); background-size: 22px 22px; pointer-events: none; z-index: 0; }
a { color: var(--mint); text-decoration: none; }
a:hover { color: var(--mint-dk); }
h1,h2,h3 { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.01em; margin: 0; }
h1 { font-size: 26px; }
.mono { font-family: var(--font-mono); }

.topbar { position: sticky; top: 0; z-index: 50; background: rgba(16,17,22,0.82); backdrop-filter: blur(14px); border-bottom: 1px solid var(--line-soft); }
.topbar-inner { max-width: 1180px; margin: 0 auto; padding: 0 24px; height: 62px; display: flex; align-items: center; gap: 28px; }
.brand { font-family: var(--font-display); font-weight: 700; font-size: 16px; color: var(--fg); display: flex; align-items: center; gap: 9px; letter-spacing: -0.02em; }
.brand:hover { color: var(--fg); }
.brand-ico { width: 26px; height: 26px; border-radius: 7px; background: var(--mint); color: var(--ink-0); display: grid; place-items: center; font-size: 15px; font-weight: 700; }
.topnav { display: flex; gap: 4px; flex: 1; }
.topnav a { color: var(--fg-2); font-size: 14px; font-weight: 500; padding: 7px 13px; border-radius: var(--r-sm); transition: background .15s,color .15s; }
.topnav a:hover { color: var(--fg); background: var(--ink-2); }
.topnav a.active { color: var(--fg); background: var(--ink-2); }
.user-menu { display: flex; align-items: center; gap: 10px; }
.avatar { width: 32px; height: 32px; border-radius: 50%; object-fit: cover; border: 1px solid var(--line); }
.avatar-text { background: var(--mint-bg); color: var(--mint); display: grid; place-items: center; font-weight: 600; font-size: 13px; border: 1px solid var(--mint-line); }
.user-name { font-size: 13px; color: var(--fg-2); font-weight: 500; }
.logout-link { color: var(--fg-3); font-size: 17px; padding: 6px 8px; border-radius: var(--r-sm); line-height: 1; transition: color .15s,background .15s; }
.logout-link:hover { color: var(--rose); background: var(--ink-2); }
.container { position: relative; z-index: 1; max-width: 1180px; margin: 0 auto; padding: 32px 24px 80px; }

.page-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; gap: 16px; flex-wrap: wrap; }
.page-head h1 { display: flex; align-items: center; gap: 12px; }
.count-badge { font-family: var(--font-mono); font-size: 14px; font-weight: 500; color: var(--mint); background: var(--mint-bg); padding: 3px 11px; border-radius: 20px; border: 1px solid var(--mint-line); }

.btn { display: inline-flex; align-items: center; gap: 7px; padding: 9px 16px; font-size: 13px; font-weight: 600; font-family: var(--font-body); border: 1px solid var(--line); background: var(--ink-1); color: var(--fg); border-radius: var(--r-sm); cursor: pointer; transition: all .15s; line-height: 1.2; }
.btn:hover { background: var(--ink-2); border-color: var(--ink-3); color: var(--fg); }
.btn:active { transform: scale(0.98); }
.btn-primary { background: var(--mint); border-color: var(--mint); color: #06281A; }
.btn-primary:hover { background: #6FEBAC; border-color: #6FEBAC; color: #06281A; }
.btn-danger { background: var(--rose-bg); border-color: transparent; color: var(--rose); }
.btn-danger:hover { background: rgba(244,121,107,0.18); color: var(--rose); }
.btn-sm { padding: 6px 12px; font-size: 12px; }

.stat-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; margin-bottom: 32px; }
.stat-card { position: relative; overflow: hidden; background: var(--ink-1); border: 1px solid var(--line-soft); border-radius: var(--r); padding: 15px 18px; }
.stat-card::after { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--fg-3); opacity: 0.5; }
.stat-card.accent-mint::after { background: var(--mint); opacity: 1; }
.stat-label { font-size: 12px; color: var(--fg-2); display: block; margin-bottom: 8px; text-transform: uppercase; letter-spacing: 0.06em; font-weight: 600; }
.stat-num { font-family: var(--font-mono); font-size: 27px; font-weight: 600; color: var(--fg); line-height: 1; }
.stat-warn::after { background: var(--amber); opacity: 1; }
.stat-warn .stat-num { color: var(--amber); }

.filter-bar { display: flex; gap: 10px; margin-bottom: 28px; flex-wrap: wrap; }
.filter-bar input[type=text] { flex: 1; min-width: 200px; }
input,select,textarea { font: inherit; font-family: var(--font-body); padding: 9px 13px; border: 1px solid var(--line); border-radius: var(--r-sm); background: var(--ink-1); color: var(--fg); transition: border-color .15s,box-shadow .15s; }
input::placeholder,textarea::placeholder { color: var(--fg-3); }
input:focus,select:focus,textarea:focus { outline: none; border-color: var(--mint-line); box-shadow: 0 0 0 3px var(--mint-bg); }
select { cursor: pointer; }
textarea { resize: vertical; width: 100%; line-height: 1.6; }
label { color: var(--fg-2); }

.card-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(270px,1fr)); gap: 16px; }
.project-card { background: var(--ink-1); border: 1px solid var(--line-soft); border-radius: var(--r); overflow: hidden; display: flex; flex-direction: column; transition: border-color .18s,transform .18s; }
.project-card:hover { border-color: var(--ink-3); transform: translateY(-2px); }
.card-cover { position: relative; height: 170px; background: var(--ink-2) repeating-linear-gradient(135deg, transparent 0 11px, rgba(255,255,255,0.014) 11px 22px); display: grid; place-items: center; overflow: hidden; }
.card-cover img { width: 100%; height: 100%; object-fit: cover; }
.cover-empty { color: var(--fg-3); font-size: 13px; font-family: var(--font-mono); }
.status-pill { position: absolute; top: 10px; right: 10px; font-size: 11px; font-weight: 600; padding: 4px 10px; border-radius: 20px; backdrop-filter: blur(8px); display: inline-flex; align-items: center; gap: 5px; }
.status-pill::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.st-online { background: var(--mint-bg); color: var(--mint); border: 1px solid var(--mint-line); }
.st-dev { background: var(--amber-bg); color: var(--amber); border: 1px solid rgba(245,197,107,0.28); }
.st-archived { background: rgba(100,106,124,0.12); color: var(--fg-2); border: 1px solid var(--line); }
.card-body { padding: 15px 17px; display: flex; flex-direction: column; gap: 9px; flex: 1; }
.card-title-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.card-title { font-family: var(--font-display); font-size: 15px; font-weight: 600; color: var(--fg); letter-spacing: -0.01em; }
.card-title:hover { color: var(--mint); }
.public-dot { color: var(--mint); font-size: 9px; }
.card-cat { font-size: 11px; color: var(--fg-2); font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; display: inline-block; width: fit-content; }
.expiry-flags { display: flex; gap: 6px; flex-wrap: wrap; }
.exp-flag { font-family: var(--font-mono); font-size: 11px; font-weight: 500; padding: 3px 9px; border-radius: 6px; display: inline-flex; align-items: center; gap: 5px; }
.exp-flag::before { content: '●'; font-size: 7px; }
.exp-ok { background: var(--mint-bg); color: var(--mint); }
.exp-warning { background: var(--amber-bg); color: var(--amber); }
.exp-critical { background: var(--rose-bg); color: var(--rose); }
.exp-expired { background: var(--rose-bg); color: var(--rose); }
.quick-links { display: flex; flex-wrap: wrap; gap: 7px; margin-top: auto; padding-top: 4px; }
.qlink { font-size: 12px; font-weight: 500; background: var(--ink-2); color: var(--fg-2); padding: 5px 11px; border-radius: 7px; border: 1px solid transparent; display: inline-flex; align-items: center; gap: 5px; transition: all .15s; }
.qlink:hover { color: var(--mint); border-color: var(--mint-line); background: var(--mint-bg); }

.form-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 24px; gap: 16px; flex-wrap: wrap; }
.form-actions { display: flex; gap: 10px; }
.project-form { max-width: 900px; }
.form-section { background: var(--ink-1); border: 1px solid var(--line-soft); border-radius: var(--r); padding: 24px; margin-bottom: 18px; }
.section-title { font-family: var(--font-display); font-size: 13px; color: var(--fg-2); margin: 0 0 18px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.07em; display: flex; align-items: center; gap: 9px; }
.section-title::before { content: ''; width: 7px; height: 7px; border-radius: 2px; background: var(--mint); }
.field { display: flex; flex-direction: column; gap: 7px; margin-bottom: 16px; }
.field > span { font-size: 12px; color: var(--fg-2); font-weight: 600; }
.field-hint { font-size: 12px; color: var(--fg-3); margin: 8px 0 0; }
code { font-family: var(--font-mono); font-size: 12px; background: var(--ink-2); color: var(--mint); padding: 2px 7px; border-radius: 5px; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px; }
.repeat-row { display: grid; gap: 9px; margin-bottom: 9px; align-items: center; }
.link-row { grid-template-columns: 150px 1fr 1fr 32px; }
.cred-row { grid-template-columns: 1fr 1fr 1fr 1fr 32px; }
.row-del { border: 1px solid var(--line); background: var(--ink-1); color: var(--fg-3); cursor: pointer; font-size: 13px; border-radius: var(--r-sm); height: 38px; transition: all .15s; }
.row-del:hover { color: var(--rose); border-color: var(--rose); background: var(--rose-bg); }
.toggle-field { display: flex; gap: 13px; align-items: flex-start; padding: 16px; background: var(--mint-bg); border: 1px solid var(--mint-line); border-radius: var(--r); margin-bottom: 16px; cursor: pointer; }
.toggle-field input { margin-top: 3px; accent-color: var(--mint); width: 17px; height: 17px; }
.toggle-text strong { display: block; font-size: 14px; color: var(--fg); margin-bottom: 2px; }
.toggle-text small { font-size: 12px; color: var(--fg-2); line-height: 1.5; }

.image-gallery { display: grid; grid-template-columns: repeat(auto-fill,minmax(150px,1fr)); gap: 12px; margin-bottom: 18px; }
.gallery-item { border: 1px solid var(--line); border-radius: var(--r-sm); overflow: hidden; position: relative; background: var(--ink-2); }
.gallery-item.is-cover { border: 2px solid var(--mint); }
.gallery-item img { width: 100%; height: 110px; object-fit: cover; display: block; }
.cover-badge { position: absolute; top: 7px; left: 7px; font-size: 10px; font-weight: 600; background: var(--mint); color: #06281A; padding: 3px 9px; border-radius: 6px; }
.gallery-actions { display: flex; justify-content: space-between; align-items: center; padding: 8px 10px; font-size: 11px; color: var(--fg-2); }
.gallery-btns a { margin-left: 9px; color: var(--fg-2); }
.gallery-btns a:hover { color: var(--mint); }
.gallery-btns a.del:hover { color: var(--rose); }
.upload-zone { border: 1.5px dashed var(--line); border-radius: var(--r); padding: 28px; text-align: center; transition: border-color .15s; }
.upload-zone:hover { border-color: var(--mint-line); }
.upload-zone p { font-size: 13px; color: var(--fg-2); margin: 0 0 12px; }
#uploadStatus { font-size: 12px; color: var(--fg-2); margin-top: 10px; font-family: var(--font-mono); }

.data-table { width: 100%; border-collapse: collapse; background: var(--ink-1); border: 1px solid var(--line-soft); border-radius: var(--r); overflow: hidden; }
.data-table th { text-align: left; font-size: 11px; color: var(--fg-2); font-weight: 600; padding: 13px 16px; background: var(--ink-2); text-transform: uppercase; letter-spacing: 0.06em; }
.data-table td { padding: 14px 16px; font-size: 13px; border-top: 1px solid var(--line-soft); color: var(--fg); }
.data-table tr:hover td { background: var(--ink-1); }
.table-actions a,.table-actions .link-btn { margin-right: 12px; color: var(--fg-2); font-weight: 500; }
.table-actions a:hover { color: var(--mint); }
.table-actions .del,.link-btn.del { color: var(--fg-2); }
.table-actions .del:hover,.link-btn.del:hover { color: var(--rose); }
.link-btn { border: none; background: none; cursor: pointer; font: inherit; font-family: var(--font-body); padding: 0; }
.text-muted { color: var(--fg-3); }
.text-success { color: var(--mint); }
.text-danger { color: var(--rose); }
.role-badge { font-family: var(--font-mono); font-size: 11px; font-weight: 600; padding: 3px 10px; border-radius: 6px; }
.role-admin { background: var(--violet-bg); color: var(--violet); }
.role-editor { background: var(--ink-2); color: var(--fg-2); }
.inline-form { display: flex; gap: 10px; flex-wrap: wrap; }
.legend { display: flex; gap: 12px; margin-top: 18px; flex-wrap: wrap; }
.empty-state { text-align: center; padding: 72px 24px; }
.empty-state p { color: var(--fg-2); margin-bottom: 20px; }
.alert { padding: 13px 17px; border-radius: var(--r-sm); margin-bottom: 18px; font-size: 14px; font-weight: 500; border: 1px solid transparent; }
.alert-success { background: var(--mint-bg); color: var(--mint); border-color: var(--mint-line); }
.alert-danger { background: var(--rose-bg); color: var(--rose); border-color: rgba(244,121,107,0.28); }
.alert-warning { background: var(--amber-bg); color: var(--amber); border-color: rgba(245,197,107,0.28); }
.site-footer { position: relative; z-index: 1; text-align: center; color: var(--fg-3); font-size: 12px; padding: 36px 0; font-family: var(--font-mono); }

.login-body { display: grid; place-items: center; min-height: 100vh; }
.login-card { position: relative; z-index: 1; background: var(--ink-1); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 44px 38px; width: 372px; text-align: center; }
.login-logo .ico { display: inline-grid; place-items: center; width: 52px; height: 52px; background: var(--mint); color: var(--ink-0); border-radius: 14px; font-size: 26px; font-weight: 700; margin-bottom: 18px; }
.login-title { font-size: 22px; margin: 0 0 6px; }
.login-sub { font-size: 14px; color: var(--fg-2); margin: 0 0 32px; }
.btn-google { display: flex; align-items: center; justify-content: center; gap: 11px; width: 100%; height: 48px; border: 1px solid var(--line); border-radius: var(--r-sm); background: var(--ink-2); color: var(--fg); font-weight: 600; font-size: 14px; transition: all .15s; }
.btn-google:hover { background: var(--ink-3); color: var(--fg); border-color: var(--ink-3); }
.login-note { font-size: 12px; color: var(--fg-3); margin: 28px 0 0; line-height: 1.6; }

.public-body { background: var(--ink-0); }
.public-wrap { position: relative; z-index: 1; max-width: 1100px; margin: 0 auto; padding: 0 24px 64px; }
.public-hero { text-align: center; padding: 84px 0 56px; position: relative; }
.hero-eyebrow { display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-mono); font-size: 12px; font-weight: 500; color: var(--mint); background: var(--mint-bg); border: 1px solid var(--mint-line); padding: 6px 14px; border-radius: 20px; margin-bottom: 24px; }
.hero-eyebrow .pulse { width: 7px; height: 7px; border-radius: 50%; background: var(--mint); animation: pulse 2s infinite; }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.35; } }
.public-hero h1 { font-size: clamp(38px,6vw,60px); line-height: 1.05; letter-spacing: -0.03em; margin: 0 0 18px; color: var(--fg); }
.public-hero h1 .accent { color: var(--mint); }
.public-hero p { font-size: 17px; color: var(--fg-2); max-width: 480px; margin: 0 auto; }
.public-meta { display: flex; justify-content: center; gap: 0; margin-top: 44px; padding-top: 36px; border-top: 1px solid var(--line-soft); }
.meta-item { padding: 0 36px; }
.meta-item + .meta-item { border-left: 1px solid var(--line-soft); }
.meta-item { text-align: center; }
.meta-num { font-family: var(--font-mono); font-size: 30px; font-weight: 600; color: var(--fg); display: block; }
.meta-label { font-size: 12px; color: var(--fg-2); text-transform: uppercase; letter-spacing: 0.06em; font-weight: 600; margin-top: 4px; }
.public-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(310px,1fr)); gap: 18px; }
.public-card { background: var(--ink-1); border: 1px solid var(--line-soft); border-radius: var(--r-lg); overflow: hidden; transition: border-color .2s,transform .2s; }
.public-card:hover { border-color: var(--ink-3); transform: translateY(-3px); }
.public-cover { position: relative; height: 220px; background: var(--ink-2) repeating-linear-gradient(135deg, transparent 0 13px, rgba(255,255,255,0.014) 13px 26px); display: grid; place-items: center; overflow: hidden; }
.public-cover img { width: 100%; height: 100%; object-fit: cover; }
.public-cover .cover-empty { font-family: var(--font-display); font-size: 52px; font-weight: 700; color: var(--ink-3); }
.view-badge { position: absolute; top: 12px; right: 12px; font-family: var(--font-mono); font-size: 12px; font-weight: 500; background: rgba(16,17,22,0.7); backdrop-filter: blur(8px); padding: 5px 11px; border-radius: 20px; color: var(--fg); display: inline-flex; align-items: center; gap: 6px; border: 1px solid var(--line); }
.view-badge .ti { color: var(--mint); font-size: 13px; }
.public-card-body { padding: 20px 22px; }
.public-card-body h2 { font-size: 18px; margin: 0 0 8px; letter-spacing: -0.01em; }
.public-card-body p { font-size: 14px; color: var(--fg-2); margin: 0 0 18px; line-height: 1.6; min-height: 44px; }
.visit-btn { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; background: var(--ink-2); color: var(--fg); padding: 10px 18px; border-radius: var(--r-sm); border: 1px solid var(--line); transition: all .15s; }
.visit-btn:hover { background: var(--mint); color: #06281A; border-color: var(--mint); }
.visit-btn .ti { font-size: 15px; }
.public-empty { text-align: center; color: var(--fg-2); padding: 80px 24px; border: 1.5px dashed var(--line); border-radius: var(--r-lg); font-family: var(--font-mono); font-size: 14px; }
.public-footer { text-align: center; color: var(--fg-3); font-size: 12px; margin-top: 56px; font-family: var(--font-mono); }

@media (max-width: 760px) {
  .stat-grid { grid-template-columns: repeat(2,1fr); }
  .grid-2,.grid-3 { grid-template-columns: 1fr; }
  .cred-row,.link-row { grid-template-columns: 1fr; }
  .topnav { display: none; }
  .public-meta { gap: 28px; flex-wrap: wrap; }
  .container { padding: 24px 18px 60px; }
}
@media (prefers-reduced-motion: reduce) { * { animation: none !important; transition: none !important; } }

.cover-initial { font-family: var(--font-display); font-size: 40px; font-weight: 700; color: var(--ink-3); user-select: none; }
.public-cover .cover-initial { font-size: 56px; }
