:root{color-scheme:dark;--bg: #0c0f14;--bg-deep: #080a0e;--surface: #12161d;--surface-2: #161b23;--surface-3: #1c222b;--sidebar: #0f1318;--line: rgba(255, 255, 255, .07);--line-strong: rgba(255, 255, 255, .14);--text: #eef2f7;--muted: #9aa4b2;--muted-2: #6c7686;--accent: #3b82f6;--accent-strong: #2563eb;--accent-blue: #3b82f6;--accent-soft: rgba(59, 130, 246, .14);--success: #4ade80;--warning: #f5c451;--danger: #f87171;--radius: 10px;--radius-sm: 8px;--radius-icon: 9px;--shadow: 0 10px 30px rgba(0, 0, 0, .32);--font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:var(--font);overflow-x:hidden}button,input,textarea,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}a{color:inherit}.admin-dashboard{min-height:100vh;background:var(--bg);color:var(--text)}.admin-shell{min-height:100vh;display:grid;grid-template-columns:1fr}.admin-sidebar{display:none;background:var(--sidebar);border-right:1px solid var(--line);padding:14px 10px;min-height:100vh;position:sticky;top:0;align-self:start}.side-brand{display:flex;align-items:center;gap:10px;min-height:40px;margin-bottom:16px;padding:4px 6px}.side-brand-icon,.brand-icon,.page-heading-icon,.module-icon-box,.auth-icon{display:grid;place-items:center;border-radius:var(--radius-icon);background:var(--accent-soft);color:#93b8ff;border:1px solid rgba(59,130,246,.22)}.side-brand-icon{width:32px;height:32px}.side-brand strong{display:block;font-size:.98rem;font-weight:700}.side-brand small{display:block;color:var(--muted);font-size:.7rem;margin-top:1px}.side-group{display:grid;gap:2px;margin-top:16px}.side-group>span{color:var(--muted-2);font-size:.66rem;letter-spacing:.12em;font-weight:700;padding:0 9px 6px}.side-link{width:100%;min-height:36px;display:flex;align-items:center;gap:10px;border:0;border-radius:var(--radius-sm);padding:8px 9px;background:transparent;color:#bcc4d0;text-align:left;font-size:.88rem;transition:background .12s ease,color .12s ease}.side-link:hover{background:#ffffff0a;color:#fff}.side-link--active{background:var(--accent-soft);color:#fff;box-shadow:inset 2px 0 0 var(--accent)}.admin-main{min-width:0;padding:max(12px,env(safe-area-inset-top)) 12px max(24px,env(safe-area-inset-bottom))}.admin-topbar{min-height:54px;margin:0 auto 16px;max-width:980px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}.guild-switcher{min-width:0;display:flex;align-items:center;gap:10px;color:var(--text)}.guild-avatar,.user-chip>span,.server-avatar,.browser-guild-avatar,.browser-avatar-fallback{width:34px;height:34px;border-radius:var(--radius-icon);display:grid;place-items:center;flex:0 0 auto;overflow:hidden;background:var(--accent);color:#06101f;font-weight:800;font-size:.74rem}.guild-avatar img,.server-avatar img,.user-chip>span img{width:100%;height:100%;object-fit:cover}.guild-switcher strong{display:block;max-width:42vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:650}.guild-switcher small,.user-chip small{display:block;color:var(--muted);font-size:.7rem;margin-top:1px}.admin-top-actions{display:flex;align-items:center;gap:8px;min-width:0}.icon-button,.topbar-mini-button{border:1px solid var(--line);border-radius:var(--radius-sm);min-width:36px;height:36px;padding:0 10px;background:var(--surface-2);color:var(--text);display:inline-flex;align-items:center;justify-content:center;gap:7px;transition:border-color .12s ease,background .12s ease}.icon-button:hover,.topbar-mini-button:hover{border-color:var(--line-strong);background:var(--surface-3)}.icon-button--wide span{font-size:.8rem}.user-chip{display:none;align-items:center;gap:8px}.user-chip>span{width:32px;height:32px;background:var(--surface-3);color:#cdd6e3}.spin{animation:spin .8s linear infinite}.panel-page{width:min(100%,980px);margin:0 auto;animation:page-in .2s ease both}.page-heading{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;margin-bottom:16px}.page-heading-icon{width:44px;height:44px;border-radius:var(--radius-icon);color:#93b8ff;background:var(--accent-soft);border-color:#3b82f638}.page-heading h1{margin:0;font-size:clamp(1.3rem,4vw,1.7rem);letter-spacing:-.02em;line-height:1.1;font-weight:700}.page-heading p{margin:4px 0 0;color:var(--muted);font-size:.88rem;line-height:1.35;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.help-button{width:32px;height:32px;border:1px solid var(--line);border-radius:var(--radius-sm);display:grid;place-items:center;background:var(--surface-2);color:#aeb7c5}.help-button:hover{background:var(--surface-3);color:#fff}.admin-module-list,.settings-list,.server-grid,.browser-server-list{display:grid;gap:10px}.admin-module-card,.setting-row,.server-card,.browser-server-card,.preview-window,.auth-card,.invite-panel,.browser-guide-card,.browser-section,.module-empty{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}.admin-module-card{width:100%;min-height:72px;padding:13px 14px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:13px;color:var(--text);text-align:left;animation:card-in .22s ease both;transition:background .13s ease,border-color .13s ease}.admin-module-card:hover{border-color:var(--line-strong);background:var(--surface-2)}.module-icon-box{width:42px;height:42px;border-radius:var(--radius-icon);color:#cdd9e8;background:var(--surface-3);border-color:var(--line)}.admin-module-card:nth-child(4n+1) .module-icon-box{background:#4ade8021;color:#a7f3c6;border-color:#4ade8033}.admin-module-card:nth-child(4n+2) .module-icon-box{background:#3b82f624;color:#a9c8ff;border-color:#3b82f638}.admin-module-card:nth-child(4n+3) .module-icon-box{background:#78b4ff21;color:#cfe3ff;border-color:#78b4ff33}.admin-module-card:nth-child(4n+4) .module-icon-box{background:#f5c45124;color:#ffe6ad;border-color:#f5c45133}.module-text{min-width:0;display:grid;gap:3px}.module-text strong{font-size:.98rem;font-weight:650;line-height:1.15}.module-text small{color:var(--muted);font-size:.82rem;line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical}.admin-module-card>svg{color:#6c7686}.admin-module-card--placeholder{opacity:.7}.admin-module-card--ready{border-color:#4ade8038}.admin-module-card--partial{border-color:#f5c45133}.admin-module-card--off{opacity:.62}.mobile-back{width:fit-content;margin-bottom:14px;border:1px solid var(--line);color:#c7cdd8;background:var(--surface-2);border-radius:var(--radius-sm);padding:8px 12px;font-size:.85rem}.mobile-back:hover{border-color:var(--line-strong)}.state-badge,.mini-badge{display:inline-flex;align-items:center;gap:5px;width:fit-content;border-radius:var(--radius-sm);border:1px solid var(--line);padding:5px 9px;color:var(--muted);background:var(--surface-2);font-size:.72rem;font-weight:700}.state-badge--ready{color:var(--success);border-color:#4ade804d;background:#4ade8014}.state-badge--partial,.state-badge--pending,.state-badge--changed,.mini-badge--pending{color:var(--warning);border-color:#f5c4514d;background:#f5c45114}.state-badge--off{color:var(--danger);border-color:#f8717147;background:#f8717114}.settings-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:0 0 14px}.setting-row{display:grid;gap:11px;padding:14px;transition:border-color .13s ease,background .13s ease}.setting-row--changed{border-color:#f5c45166;background:var(--surface-2)}.setting-row-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.setting-row-head strong{display:block;font-size:.95rem;font-weight:650}.setting-row-head small,.field-description{display:block;color:var(--muted);margin-top:4px;line-height:1.35;font-size:.82rem}input,select,textarea{width:100%;border:1px solid var(--line-strong);border-radius:var(--radius-sm);background:var(--bg-deep);color:var(--text);padding:10px 11px;outline:none;transition:border-color .12s ease}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}textarea{min-height:110px;resize:vertical}.switch-row{width:fit-content;display:inline-flex;align-items:center;gap:9px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-2);padding:7px 11px}.switch-row input{width:18px;height:18px;accent-color:var(--accent)}.field-current{color:var(--muted-2);font-size:.76rem}.module-empty{min-height:170px;display:grid;place-items:center;text-align:center;gap:8px;padding:22px;color:var(--muted)}.module-empty strong{color:var(--text)}.save-dock{position:fixed;left:50%;bottom:max(10px,env(safe-area-inset-bottom));transform:translate(-50%);width:min(640px,calc(100vw - 18px));z-index:50;border:1px solid var(--line-strong);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);padding:11px;display:grid;gap:9px}.save-dock span{color:var(--muted);font-size:.85rem}.button-row{display:flex;gap:9px;flex-wrap:wrap}.save-dock .button-row{display:grid;grid-template-columns:1fr 1fr}.primary-button,.ghost-button,.ghost-link{border:1px solid var(--line);border-radius:var(--radius-sm);padding:10px 14px;color:var(--text);background:var(--surface-2);text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:.88rem;transition:border-color .13s ease,background .13s ease}.primary-button:hover,.ghost-button:hover,.ghost-link:hover{border-color:var(--line-strong);background:var(--surface-3)}.primary-button{border-color:var(--accent-strong);background:var(--accent);color:#fff;font-weight:700}.primary-button:hover{background:var(--accent-strong)}.ghost-button--small,.primary-button--small{padding:8px 10px;font-size:.8rem}.status-pill,.browser-status-line{display:block;width:fit-content;max-width:100%;border:1px solid rgba(59,130,246,.24);border-radius:var(--radius-sm);background:var(--accent-soft);color:#cfe0ff;padding:9px 12px;margin:0 auto 14px;font-size:.85rem}.status-pill--error,.status-pill--denied{border-color:#f8717147;background:#f8717114;color:#ffc6c6}.auth-card{width:min(100%,500px);margin:16vh auto 0;padding:24px;text-align:center}.auth-icon{width:52px;height:52px;margin:0 auto 12px}.auth-card h2{margin:0 0 8px;font-size:1.3rem;font-weight:700}.auth-card p{color:var(--muted);line-height:1.45;font-size:.9rem}.auth-card .primary-button,.auth-card .ghost-button{margin:12px auto 0}.auth-card--danger{border-color:#f871713d}.browser-page{width:min(100% - 24px,1180px);min-height:100vh;margin:0 auto;padding:max(14px,env(safe-area-inset-top)) 0 70px}.browser-topbar{position:sticky;top:max(8px,env(safe-area-inset-top));z-index:30;min-height:54px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:8px 12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}.browser-brand{border:0;background:transparent;color:var(--text);display:inline-flex;align-items:center;gap:10px;font-size:1rem;font-weight:650}.browser-brand span{width:30px;height:30px;display:grid;place-items:center;border-radius:var(--radius-icon);background:var(--accent);color:#06101f}.browser-login-button{border:1px solid var(--accent-strong);border-radius:var(--radius-sm);background:var(--accent);color:#fff;min-height:40px;padding:0 16px;font-weight:700;font-size:.88rem;display:inline-flex;align-items:center;gap:9px}.browser-login-button:hover{background:var(--accent-strong)}.browser-login-button img{width:24px;height:24px;border-radius:var(--radius-icon)}.browser-hero{display:grid;grid-template-columns:minmax(0,1fr);align-items:center;gap:28px;padding:clamp(28px,6vw,56px) 8px;position:relative}.browser-hero-copy{max-width:620px;position:relative;z-index:1}.eyebrow{margin:0 0 12px;color:#7fb0ff;text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;font-weight:800}.browser-hero h1{margin:0;font-size:clamp(2rem,6vw,3.4rem);line-height:1.05;letter-spacing:-.03em;font-weight:750}.browser-hero p{max-width:600px;margin:16px 0 0;color:var(--muted);font-size:clamp(1rem,2vw,1.15rem);line-height:1.45;font-weight:450}.browser-hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}.browser-hero-preview{display:none}.preview-window{min-height:280px;display:grid;grid-template-columns:120px 1fr;overflow:hidden}.preview-sidebar{background:var(--surface-2);padding:18px;display:grid;align-content:start;gap:10px}.preview-sidebar span,.preview-pill,.preview-card,.preview-grid span{display:block;border-radius:var(--radius-sm);background:#ffffff14}.preview-sidebar span{height:12px}.preview-main{padding:22px;display:grid;gap:13px;align-content:start}.preview-pill{width:42%;height:18px}.preview-card{height:64px}.preview-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.preview-grid span{height:48px}.browser-guide-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;padding:28px 0}.browser-guide-card{padding:18px}.browser-guide-card span{font-size:1.4rem}.browser-guide-card h2{margin:10px 0 6px;font-size:1.05rem;font-weight:650}.browser-guide-card p,.browser-section p{color:var(--muted);line-height:1.5;font-size:.88rem}.browser-flow-grid{display:grid;gap:12px}.browser-flow-section{padding:24px 0}.browser-flow-section h2{font-weight:700;letter-spacing:-.02em}.browser-section{padding:22px}.browser-server-topbar,.server-picker-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:22px 0 16px;flex-wrap:wrap}.server-picker-head h1,.browser-server-topbar h1{margin:0;font-size:clamp(1.5rem,4vw,2.2rem);letter-spacing:-.025em;font-weight:700}.server-picker-head p,.browser-server-topbar p{margin:6px 0 0;color:var(--muted);font-size:.9rem}.server-section{margin-top:22px}.server-section h2{margin:0 0 12px;font-size:1.05rem;font-weight:650}.panel-title-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}.server-card,.browser-server-card{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:13px;padding:14px;color:var(--text);text-align:left;transition:border-color .13s ease,background .13s ease}.server-card:hover{border-color:var(--line-strong);background:var(--surface-2)}.server-card--disabled,.browser-server-card--disabled,.server-section--muted .server-card{filter:grayscale(.3);opacity:.7}.server-card strong,.browser-server-card strong{display:block;font-weight:650}.server-card small,.browser-server-card small{color:var(--muted);font-size:.82rem}.invite-panel{max-width:540px;margin:12vh auto 0;padding:24px;text-align:center}.invite-orb{font-size:2.6rem}.reveal-card{opacity:0;transform:translateY(12px);transition:opacity .36s ease,transform .36s ease}.reveal-card--visible{opacity:1;transform:translateY(0)}@keyframes card-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes page-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 420px){.admin-main{padding-left:8px;padding-right:8px}.guild-switcher strong{max-width:34vw}.icon-button--wide span,.user-chip{display:none}.page-heading{grid-template-columns:auto minmax(0,1fr) auto;gap:11px}.page-heading-icon{width:42px;height:42px}.admin-module-card{min-height:66px;padding:12px}.module-icon-box{width:40px;height:40px}.settings-actions{grid-template-columns:1fr}}@media (min-width: 760px){.admin-shell{grid-template-columns:230px minmax(0,1fr)}.admin-sidebar{display:block}.admin-main{padding:18px 24px 64px}.admin-topbar,.panel-page{max-width:1040px}.user-chip{display:inline-flex}.admin-module-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.settings-list{grid-template-columns:repeat(2,minmax(0,1fr))}.setting-row--textarea{grid-column:1 / -1}.browser-hero{grid-template-columns:minmax(0,.95fr) minmax(320px,.75fr)}.browser-hero-preview{display:block;position:relative;z-index:1}.browser-flow-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.browser-server-list,.server-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1140px){.admin-shell{grid-template-columns:250px minmax(0,1fr)}.panel-page,.admin-topbar{max-width:1080px}.admin-module-list{grid-template-columns:repeat(2,minmax(0,1fr))}}
