:root{
  --bg:#100b20;
  --bg2:#251543;
  --card:rgba(28,20,51,.72);
  --line:rgba(255,255,255,.12);
  --text:#fffaf0;
  --muted:#bdb5ca;
  --gold:#e8c77a;
  --gold2:#fff0b7;
  --danger:#ff8c9b;
  --ok:#8fe2bf;
  --shadow:0 25px 80px rgba(0,0,0,.38);
}
*{box-sizing:border-box}
html{min-height:100%;background:var(--bg)}
body{
  margin:0;min-height:100vh;color:var(--text);
  font-family:"Noto Sans TC","Microsoft JhengHei",system-ui,sans-serif;
  background:
    radial-gradient(circle at 15% 10%,rgba(116,75,170,.24),transparent 32%),
    radial-gradient(circle at 80% 45%,rgba(232,199,122,.10),transparent 30%),
    linear-gradient(145deg,var(--bg),#171028 55%,#0c0916);
  overflow-x:hidden;
}
button,input,textarea{font:inherit}
button,a{ -webkit-tap-highlight-color:transparent }
a{color:inherit;text-decoration:none}
.hidden{display:none!important}
.ambient{position:fixed;border-radius:50%;filter:blur(80px);pointer-events:none;opacity:.45}
.ambient-a{width:360px;height:360px;background:#64408e;left:-180px;top:18%}
.ambient-b{width:280px;height:280px;background:#7e6130;right:-140px;bottom:8%}
.page-shell,.admin-shell{width:min(1180px,calc(100% - 32px));margin:auto;position:relative;z-index:1}
.topbar{height:88px;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{
  width:44px;height:44px;display:grid;place-items:center;border-radius:50%;
  border:1px solid rgba(232,199,122,.55);color:var(--gold2);
  background:radial-gradient(circle,rgba(232,199,122,.18),transparent 70%);
  box-shadow:0 0 35px rgba(232,199,122,.14)
}
.brand strong,.brand small{display:block}
.brand strong{letter-spacing:.14em}
.brand small{font-size:10px;color:var(--gold);letter-spacing:.24em;margin-top:3px}
.hero-grid{min-height:calc(100vh - 112px);display:grid;grid-template-columns:1.15fr .85fr;gap:70px;align-items:center;padding:30px 0 80px}
.hero-copy h1{font-family:Georgia,"Noto Serif TC",serif;font-weight:500;font-size:clamp(42px,5.5vw,72px);line-height:1.22;margin:16px 0 22px;letter-spacing:.02em}
.eyebrow{color:var(--gold);font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;margin:0}
.lead{color:var(--muted);font-size:17px;line-height:1.85;max-width:650px}
.feature-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px}
.feature-row span{padding:9px 15px;border:1px solid var(--line);border-radius:999px;color:#ded7e7;font-size:13px}
.glass-card{
  background:linear-gradient(145deg,rgba(49,34,78,.82),rgba(22,17,38,.78));
  border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)
}
.login-card{padding:34px}
.card-heading{display:flex;align-items:center;gap:14px;margin-bottom:26px}
.card-heading p{margin:0 0 4px;font-size:20px;font-weight:700}
.card-heading small{color:var(--muted)}
.mini-orb{width:38px;height:38px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#fff7d2,var(--gold) 28%,#66462c 75%);box-shadow:0 0 30px rgba(232,199,122,.35)}
label{display:block;margin:17px 0}
label>span{display:block;font-size:13px;color:#d8d0e1;margin-bottom:8px}
input,textarea{
  width:100%;border:1px solid var(--line);border-radius:14px;background:rgba(8,6,16,.45);
  color:var(--text);padding:14px 15px;outline:none;transition:.2s
}
input:focus,textarea:focus{border-color:rgba(232,199,122,.7);box-shadow:0 0 0 3px rgba(232,199,122,.09)}
textarea{min-height:118px;resize:vertical;line-height:1.7}
.check-line{display:flex;gap:10px;align-items:flex-start}
.check-line input{width:18px;height:18px;margin-top:2px;accent-color:var(--gold)}
.check-line span{line-height:1.55;margin:0}
.primary-btn,.ghost-btn,.icon-btn{
  border:0;cursor:pointer;transition:transform .18s,filter .18s,background .18s
}
.primary-btn{
  width:100%;min-height:52px;border-radius:15px;padding:13px 18px;
  background:linear-gradient(115deg,#d4aa52,#f2dc95 54%,#bd8a39);
  color:#251b10;font-weight:800;display:flex;align-items:center;justify-content:center;gap:14px;
  box-shadow:0 14px 35px rgba(190,137,56,.22)
}
.primary-btn:hover,.ghost-btn:hover,.icon-btn:hover{transform:translateY(-2px);filter:brightness(1.06)}
.primary-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}
.ghost-btn{
  padding:10px 15px;border-radius:12px;color:#eee7f4;background:rgba(255,255,255,.06);
  border:1px solid var(--line)
}
.form-note{font-size:12px;line-height:1.6;color:#9890a5;margin:14px 0 0}
.dashboard{padding:20px 0 60px}
.welcome-panel{padding:28px 34px;display:flex;align-items:center;justify-content:space-between;gap:30px}
.welcome-panel h2{font-size:31px;margin:7px 0 8px}
.welcome-panel>div>p:last-child{color:var(--muted);margin-bottom:0}
.points-orb{
  width:138px;height:138px;border-radius:50%;flex:0 0 138px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;background:radial-gradient(circle at 40% 30%,rgba(255,245,195,.34),rgba(117,77,31,.22) 45%,rgba(11,8,20,.55));
  border:1px solid rgba(232,199,122,.55);box-shadow:inset 0 0 30px rgba(232,199,122,.12),0 0 45px rgba(232,199,122,.12)
}
.points-orb small{color:#d9cfb8}.points-orb strong{font-size:42px;line-height:1.05;color:var(--gold2)}.points-orb span{font-size:9px;letter-spacing:.25em;color:var(--gold)}
.draw-layout{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);gap:24px;margin-top:24px}
.draw-stage{padding:48px;position:relative;overflow:hidden;text-align:center}
.halo{position:absolute;width:260px;height:260px;border-radius:50%;left:50%;top:40px;transform:translateX(-50%);background:radial-gradient(circle,rgba(232,199,122,.16),transparent 67%);filter:blur(5px)}
.wish-symbol{position:relative;font-size:58px;color:var(--gold2);text-shadow:0 0 30px var(--gold);margin:8px 0 24px;animation:float 4s ease-in-out infinite}
@keyframes float{50%{transform:translateY(-8px) rotate(8deg)}}
.draw-stage h2{position:relative;font-family:Georgia,"Noto Serif TC",serif;font-weight:500;font-size:30px;margin:10px 0 22px}
.draw-stage textarea{position:relative;margin-bottom:16px}
.draw-btn{position:relative;max-width:410px;margin:auto}
.status-line{color:#958da3;font-size:12px;margin:14px 0 0}
.history-panel{padding:28px;min-height:420px}
.section-title{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:20px}
.section-title h3{margin:5px 0 0;font-size:22px}
.icon-btn{width:38px;height:38px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.06);color:var(--text);font-size:18px}
.history-list{display:flex;flex-direction:column;gap:10px;max-height:485px;overflow:auto;padding-right:3px}
.history-item{display:grid;grid-template-columns:54px 1fr;gap:12px;padding:10px;border:1px solid rgba(255,255,255,.08);border-radius:15px;background:rgba(255,255,255,.035)}
.history-item img{width:54px;height:54px;border-radius:12px;object-fit:cover;background:#2a213c}
.history-item strong{display:block;font-size:14px;margin:3px 0 5px}.history-item small{color:#978fa3;font-size:11px}
.empty-state{padding:50px 15px;text-align:center;color:#8f879b}
.dashboard-actions{display:flex;justify-content:center;gap:24px;margin:25px 0}
.text-link{color:#aba2b8;font-size:13px}.button-link{border:0;background:transparent;cursor:pointer}
.result-dialog{
  width:min(500px,calc(100% - 28px));border:1px solid rgba(255,255,255,.14);border-radius:28px;
  color:var(--text);background:linear-gradient(160deg,#342050,#171022 68%);
  box-shadow:0 40px 120px rgba(0,0,0,.65);padding:30px;text-align:center
}
.result-dialog::backdrop{background:rgba(3,2,8,.78);backdrop-filter:blur(8px)}
.dialog-close{position:absolute;right:16px;top:13px;border:0;background:transparent;color:#d8d0e1;font-size:30px;cursor:pointer}
.result-image-wrap{height:260px;border-radius:20px;overflow:hidden;background:#21172f;margin-bottom:22px}
.result-image-wrap img{width:100%;height:100%;object-fit:cover}
.result-level{font-size:12px;color:var(--gold);letter-spacing:.16em;margin:0 0 8px}
.result-dialog h2{font-family:Georgia,"Noto Serif TC",serif;font-size:30px;margin:0 0 12px}
.result-message{color:#d2c9d9;line-height:1.8;white-space:pre-line}
.result-meta{display:flex;justify-content:space-between;padding:13px 0;margin:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);color:#aaa1b6;font-size:13px}
.result-dialog>small{display:block;color:#8f879a;line-height:1.6;margin-top:13px}
.toast{
  position:fixed;left:50%;bottom:24px;transform:translate(-50%,30px);z-index:50;
  padding:12px 18px;border-radius:13px;background:#f7edcf;color:#2a2014;font-weight:700;
  opacity:0;pointer-events:none;transition:.25s;box-shadow:0 15px 50px rgba(0,0,0,.35)
}
.toast.show{opacity:1;transform:translate(-50%,0)}
/* admin */
.admin-shell{padding-bottom:60px}.admin-login-wrap{min-height:calc(100vh - 100px);display:grid;place-items:center}
.admin-login-card{width:min(430px,100%)}.admin-title-row{display:flex;justify-content:space-between;align-items:end;margin:30px 0}
.admin-title-row h1{font-family:Georgia,"Noto Serif TC",serif;font-size:40px;font-weight:500;margin:8px 0 0}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.stat-card{padding:22px;border-radius:20px;background:rgba(255,255,255,.055);border:1px solid var(--line)}
.stat-card span{display:block;color:#aaa2b4;font-size:13px}.stat-card strong{display:block;font-size:34px;color:var(--gold2);margin-top:7px}
.admin-grid{display:grid;grid-template-columns:390px 1fr;gap:22px;margin-top:22px}
.editor-card,.list-card{padding:28px}.two-cols{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.toggle-label input{width:24px;height:24px;accent-color:var(--gold)}
.admin-card-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.admin-card-item{display:grid;grid-template-columns:88px 1fr;gap:14px;padding:12px;border:1px solid var(--line);border-radius:17px;background:rgba(255,255,255,.035)}
.admin-card-item img{width:88px;height:100px;border-radius:13px;object-fit:cover;background:#271e35}
.admin-card-info h4{margin:3px 0 4px}.admin-card-info p{margin:0;color:#aaa2b4;font-size:12px;line-height:1.45}
.card-badges{display:flex;gap:6px;margin:8px 0}.badge{font-size:10px;padding:4px 7px;border-radius:999px;background:rgba(232,199,122,.12);color:var(--gold2)}
.badge.off{background:rgba(255,140,155,.12);color:var(--danger)}
.card-actions{display:flex;gap:8px;margin-top:9px}.small-btn{border:1px solid var(--line);background:rgba(255,255,255,.05);color:#ddd5e4;border-radius:8px;padding:6px 10px;cursor:pointer;font-size:11px}
.small-btn.danger{color:var(--danger)}
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:30px;padding-top:55px}.hero-copy{text-align:center}.lead{margin-left:auto;margin-right:auto}.feature-row{justify-content:center}
  .draw-layout,.admin-grid{grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(2,1fr)}
  .history-panel{min-height:auto}.admin-card-list{grid-template-columns:1fr}
}
@media(max-width:600px){
  .page-shell,.admin-shell{width:min(100% - 20px,1180px)}.topbar{height:72px}.brand-mark{width:40px;height:40px}
  .hero-grid{padding:24px 0 48px;min-height:auto}.hero-copy h1{font-size:40px}.lead{font-size:15px}
  .login-card,.draw-stage,.history-panel,.editor-card,.list-card{padding:22px;border-radius:22px}
  .welcome-panel{padding:22px;align-items:flex-start}.welcome-panel h2{font-size:25px}.welcome-panel>div>p:last-child{font-size:13px;line-height:1.6}
  .points-orb{width:104px;height:104px;flex-basis:104px}.points-orb strong{font-size:32px}
  .draw-stage h2{font-size:24px}.result-image-wrap{height:220px}.stat-grid{gap:10px}.stat-card{padding:17px}.stat-card strong{font-size:28px}
  .admin-title-row h1{font-size:31px}.two-cols{grid-template-columns:1fr}.ghost-btn{font-size:12px}
}


/* Cloud V5：會員查詢 */
.member-panel{padding:28px;margin-top:22px}
.member-test-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.danger-outline-btn{
  padding:10px 15px;border-radius:12px;color:var(--danger);
  background:rgba(255,140,155,.06);border:1px solid rgba(255,140,155,.35);
  cursor:pointer;transition:.18s
}
.danger-outline-btn:hover{transform:translateY(-2px);filter:brightness(1.08)}
.member-filter-grid{
  display:grid;grid-template-columns:1fr 1fr 150px 190px auto;
  gap:14px;align-items:end
}
.member-filter-grid label{margin:0}
.member-filter-grid select{
  width:100%;border:1px solid var(--line);border-radius:14px;
  background:rgba(8,6,16,.45);color:var(--text);padding:14px 15px;outline:none
}
.member-check-label{align-self:end}
.member-check-line{min-height:50px;align-items:center;margin:0;padding:0 4px}
.member-filter-actions{display:flex;gap:9px;align-items:center}
.member-filter-actions .primary-btn{min-width:118px}
.member-filter-actions .ghost-btn{white-space:nowrap;min-height:52px}
.member-summary{
  display:flex;justify-content:space-between;gap:18px;align-items:center;
  margin:22px 0 12px;color:#bdb5ca;font-size:13px
}
.member-summary strong{color:var(--gold2);font-size:18px}
#memberQueryTime{margin-left:10px;color:#8f879b}
.member-operation-status{color:var(--gold2);text-align:right}
.member-table-wrap{
  overflow:auto;border:1px solid var(--line);border-radius:16px;
  background:rgba(5,4,10,.22)
}
.member-table{width:100%;border-collapse:collapse;min-width:880px}
.member-table th,.member-table td{
  padding:13px 14px;border-bottom:1px solid rgba(255,255,255,.075);
  text-align:left;font-size:13px;white-space:nowrap
}
.member-table th{
  position:sticky;top:0;background:#241733;color:var(--gold2);
  font-size:12px;letter-spacing:.06em;z-index:1
}
.member-table tbody tr:hover{background:rgba(255,255,255,.035)}
.member-empty{text-align:center!important;color:#8f879b;padding:42px!important}
.member-type-badge,.member-status-badge{
  display:inline-flex;padding:4px 8px;border-radius:999px;font-size:10px;font-weight:700
}
.member-type-badge.real{background:rgba(143,226,191,.12);color:var(--ok)}
.member-type-badge.test{background:rgba(232,199,122,.12);color:var(--gold2)}
.member-status-badge.active{background:rgba(143,226,191,.12);color:var(--ok)}
.member-status-badge.off{background:rgba(255,140,155,.12);color:var(--danger)}
.member-pagination{
  display:flex;justify-content:center;align-items:center;gap:15px;margin-top:15px
}
.member-pagination span{min-width:120px;text-align:center;color:#bdb5ca;font-size:13px}
.member-pagination button:disabled{opacity:.45;cursor:not-allowed;transform:none}

@media(max-width:1100px){
  .member-filter-grid{grid-template-columns:1fr 1fr 140px 180px}
  .member-filter-actions{grid-column:1/-1}
}
@media(max-width:700px){
  .member-panel{padding:20px}
  .member-panel .section-title{align-items:flex-start;flex-direction:column}
  .member-test-actions{width:100%}
  .member-test-actions button{flex:1}
  .member-filter-grid{grid-template-columns:1fr}
  .member-filter-actions{grid-column:auto}
  .member-summary{align-items:flex-start;flex-direction:column}
  .member-operation-status{text-align:left}
}
