:root{--color-bg: #0e1117;--color-bg-elevated: #121926;--color-surface: #2a303c;--color-parchment: #e8d8b8;--color-gold: #b88a44;--color-copper: #8a5a36;--color-ice: #8fb7d6;--color-danger: #9c3d3d;--color-success: #4f8a64;--color-text: #e8d8b8;--color-text-muted: #9aa4b2;--color-border: rgba(184, 138, 68, .35);--color-overlay: rgba(14, 17, 23, .72);--font-display: "Cinzel", "Noto Serif SC", serif;--font-body: "Inter", "Noto Sans SC", system-ui, sans-serif;--text-xs: 12px;--text-sm: 14px;--text-base: 16px;--text-lg: 18px;--text-xl: 24px;--text-2xl: 32px;--text-3xl: 44px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--shadow-card: 0 4px 16px rgba(0, 0, 0, .45);--shadow-elevated: 0 8px 32px rgba(0, 0, 0, .55);--z-sidebar: 100;--z-topbar: 110;--z-modal: 1000;--sidebar-width: 240px;--topbar-height: 64px;--content-max: 1200px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background-color:var(--color-bg);color:var(--color-text);font-family:var(--font-body);font-size:var(--text-base);line-height:1.5;-webkit-font-smoothing:antialiased}h1,h2,h3{font-family:var(--font-display);line-height:1.2;letter-spacing:.04em;margin:0 0 var(--space-3);color:var(--color-parchment)}a{color:var(--color-gold);text-decoration:none;transition:color .15s ease}a:hover{color:var(--color-copper)}.theme-medieval-modern{min-height:100%;background:radial-gradient(1200px 600px at 80% -10%,rgba(143,183,214,.06),transparent),var(--color-bg)}.layout-shell{min-height:100vh;display:flex;flex-direction:column}.layout-topbar{position:sticky;top:0;height:var(--topbar-height);background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border);z-index:var(--z-topbar);display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.layout-topbar-inner{width:100%;max-width:var(--content-max);height:100%;display:flex;align-items:center;padding:0 var(--space-6);gap:var(--space-4);margin:0 auto}.layout-body{display:flex;flex:1;align-items:stretch;width:100%;justify-content:center}.layout-container{display:flex;flex:1;align-items:stretch;width:100%;max-width:var(--content-max);position:relative}.layout-main{flex:1;padding:var(--space-8);width:100%;overflow-x:hidden;animation:fadeIn .4s ease-out}.layout-sidebar{width:var(--sidebar-width);flex:0 0 var(--sidebar-width);background:var(--color-bg-elevated);border-right:1px solid var(--color-border);padding:var(--space-4);z-index:var(--z-sidebar);display:flex;flex-direction:column;overflow-y:auto}.layout-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:calc(var(--z-sidebar) - 1);opacity:0;pointer-events:none;transition:opacity .3s ease}.layout-backdrop.active{opacity:1;pointer-events:auto}.topbar-hamburger{display:none;background:transparent;border:none;color:var(--color-gold);cursor:pointer;padding:var(--space-2);align-items:center;justify-content:center;transition:color .15s ease}.topbar-hamburger:hover{color:var(--color-parchment)}.topbar-brand{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;color:var(--color-parchment);letter-spacing:.04em}.topbar-tagline{font-size:var(--text-sm);color:var(--color-text-muted)}@media (max-width: 768px){.topbar-hamburger{display:flex}.layout-sidebar{position:fixed;top:var(--topbar-height);left:0;height:calc(100vh - var(--topbar-height));transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-elevated);z-index:var(--z-sidebar)}.layout-sidebar.open{transform:translate(0)}.layout-main{padding:var(--space-4)}.topbar-tagline{display:none}.layout-topbar-inner{padding:0 var(--space-3)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--color-gold)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.ui-btn{font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;border:1px solid transparent;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2)}.ui-btn-primary{background:var(--color-gold);color:var(--color-bg);border-color:var(--color-gold)}.ui-btn-primary:hover:not(:disabled){background:var(--color-parchment);border-color:var(--color-parchment);box-shadow:0 0 12px #b88a4466}.ui-btn-ghost{background:transparent;color:var(--color-gold);border-color:var(--color-border)}.ui-btn-ghost:hover:not(:disabled){background:#b88a441a;border-color:var(--color-gold);color:var(--color-parchment)}.ui-btn-danger{background:transparent;color:var(--color-danger);border-color:var(--color-danger)}.ui-btn-danger:hover:not(:disabled){background:#9c3d3d1a;box-shadow:0 0 12px #9c3d3d4d}.ui-btn:disabled{opacity:.5;cursor:not-allowed}.ui-input{background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);width:100%;outline:none;font-family:var(--font-body);transition:border-color .2s ease,box-shadow .2s ease}.ui-input:focus{border-color:var(--color-ice);box-shadow:0 0 8px #8fb7d640}.ui-card{background:var(--color-bg-elevated);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:var(--space-6);position:relative;transition:transform .2s ease,box-shadow .2s ease}.ui-card:hover{box-shadow:0 8px 24px #b88a4426}.ui-card:before{content:"";position:absolute;top:6px;left:6px;width:10px;height:10px;border-top:1px solid var(--color-border);border-left:1px solid var(--color-border);pointer-events:none}.ui-card:after{content:"";position:absolute;bottom:6px;right:6px;width:10px;height:10px;border-bottom:1px solid var(--color-border);border-right:1px solid var(--color-border);pointer-events:none}.ui-table-container{width:100%;overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-elevated)}.ui-table{width:100%;border-collapse:collapse;font-family:var(--font-body);font-size:var(--text-sm);text-align:left}.ui-table th{font-family:var(--font-display);color:var(--color-gold);background:#121926cc;padding:var(--space-3) var(--space-4);font-weight:600;border-bottom:1px solid var(--color-gold);letter-spacing:.05em}.ui-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);color:var(--color-text);transition:background .15s ease}.ui-table tbody tr:hover td{background:#b88a440d}.ui-tag{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:600;padding:var(--space-1) var(--space-2);line-height:1;text-transform:uppercase;letter-spacing:.02em;border:1px solid transparent}.ui-tag-gold{background:#b88a4426;color:var(--color-gold);border-color:var(--color-gold)}.ui-tag-success{background:#4f8a6426;color:var(--color-success);border-color:var(--color-success)}.ui-tag-danger{background:#9c3d3d26;color:var(--color-danger);border-color:var(--color-danger)}.ui-tag-ice{background:#8fb7d626;color:var(--color-ice);border-color:var(--color-ice)}.ui-tag-default{background:#9aa4b226;color:var(--color-text-muted);border-color:var(--color-border)}.ui-tabs{display:flex;border-bottom:1px solid var(--color-border);gap:var(--space-2);margin-bottom:var(--space-4)}.ui-tabs-btn{background:transparent;border:none;color:var(--color-text-muted);padding:var(--space-2) var(--space-4);font-family:var(--font-display);font-size:var(--text-sm);cursor:pointer;transition:all .2s ease;border-bottom:2px solid transparent;margin-bottom:-1px}.ui-tabs-btn:hover{color:var(--color-parchment)}.ui-tabs-btn.active{color:var(--color-gold);border-bottom-color:var(--color-gold)}.sidebar-link{display:block;padding:var(--space-2) var(--space-3);margin-bottom:var(--space-1);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--color-text);border-left:3px solid transparent;transition:all .2s ease}.sidebar-link:hover{background:#b88a441a;color:var(--color-parchment);transform:translate(4px)}.sidebar-link.active{color:var(--color-bg);background:var(--color-gold);border-left-color:var(--color-copper)}.ui-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:var(--space-4);animation:fadeIn .3s ease-out}.ui-modal-container{background:var(--color-surface);border:1px solid var(--color-gold);border-radius:var(--radius-lg);box-shadow:var(--shadow-elevated);width:100%;max-width:520px;overflow:hidden;animation:modalSlideUp .3s cubic-bezier(.34,1.56,.64,1)}@keyframes modalSlideUp{0%{transform:translateY(24px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.ui-modal-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.ui-modal-header h3{margin:0;font-size:var(--text-lg);color:var(--color-gold)}.ui-modal-close-btn{background:transparent;border:none;color:var(--color-text-muted);font-size:var(--text-xl);cursor:pointer;transition:color .15s ease}.ui-modal-close-btn:hover{color:var(--color-gold)}.ui-modal-content{padding:var(--space-6);max-height:70vh;overflow-y:auto}.ui-modal-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);background:#12192666;display:flex;justify-content:flex-end;gap:var(--space-3)}.runic-divider{display:flex;align-items:center;justify-content:center;margin:var(--space-6) 0;color:var(--color-border)}.runic-divider:before,.runic-divider:after{content:"";flex:1;height:1px;background:linear-gradient(to right,transparent,var(--color-border),transparent)}.runic-divider span{padding:0 var(--space-3);font-family:var(--font-display);font-size:var(--text-xs);letter-spacing:.2em;color:var(--color-gold)}.announcement-editor-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.announcement-select{padding:var(--space-2) var(--space-3);background:var(--color-bg-elevated);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);outline:none;font-family:var(--font-body);transition:border-color .2s ease,box-shadow .2s ease}.announcement-select:focus{border-color:var(--color-ice);box-shadow:0 0 8px #8fb7d640}@media (max-width: 768px){.announcement-editor-grid{grid-template-columns:1fr}}.home-grid{display:grid;grid-template-columns:2.2fr 1fr;gap:var(--space-6);margin-top:var(--space-6)}.hero-banner{border:1px solid var(--color-gold);border-radius:var(--radius-lg);padding:var(--space-10) var(--space-6);text-align:center;position:relative;overflow:hidden;margin-bottom:var(--space-6);box-shadow:var(--shadow-elevated);min-height:380px;display:flex;flex-direction:column;justify-content:center;align-items:center}.hero-frame-sequence{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;overflow:hidden;background-image:linear-gradient(to bottom,#0e11178c,#0e1117e6),url(/art/home-hero-campfire-knight/sequence/hero-video-frame-01.webp);background-size:cover;background-position:center;background-repeat:no-repeat}.hero-sequence-frame{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center;opacity:0;transition:opacity 95ms linear}.hero-sequence-frame.active{opacity:1}.hero-banner:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;pointer-events:none;background:radial-gradient(circle at 68% 78%,rgba(255,180,86,.16),rgba(184,138,68,.03) 26%,transparent 48%),linear-gradient(100deg,rgba(143,183,214,.08),transparent 28%,rgba(14,17,23,.14) 68%,rgba(14,17,23,.42));opacity:.78}@media (prefers-reduced-motion: no-preference){.hero-rune{animation:heroRunePulse 7s ease-in-out infinite}}@media (max-width: 640px){.hero-banner{min-height:420px;padding:var(--space-6) var(--space-4);align-items:flex-start;text-align:left}.hero-frame-sequence{background-image:linear-gradient(90deg,#0e1117eb,#0e1117b8 48%,#0e111759),linear-gradient(to bottom,#0e111773,#0e1117e6),url(/art/home-hero-campfire-knight/sequence/hero-video-frame-01.webp);background-position:66% center}.hero-sequence-frame{object-position:66% center}.hero-banner:after{background:radial-gradient(circle at 50% 82%,rgba(255,180,86,.16),rgba(184,138,68,.035) 24%,transparent 46%),linear-gradient(90deg,rgba(14,17,23,.24),transparent 46%,rgba(14,17,23,.1))}.hero-banner-content{max-width:100%}.hero-rune{margin-left:0}.hero-title{font-size:var(--text-2xl);letter-spacing:.03em}.hero-subtitle{margin-left:0;margin-right:0;max-width:100%}.hero-subtitle-lead{font-size:var(--text-lg)}.hero-banner .hero-cta-row{flex-direction:column;align-items:stretch;max-width:220px}.hero-banner .ui-btn{width:100%;box-shadow:0 2px 10px #00000073}.hero-banner .ui-btn-ghost{background:#0e1117bd;border-color:#b88a44b3;color:var(--color-parchment)}}.hero-banner-content{position:relative;z-index:4;width:100%;max-width:800px}.hero-banner:before{content:"";position:absolute;top:8px;left:8px;right:8px;bottom:8px;border:1px dashed rgba(184,138,68,.2);pointer-events:none;z-index:4}.hero-title{font-family:var(--font-display);font-size:var(--text-3xl);color:var(--color-parchment);text-shadow:0 2px 8px rgba(0,0,0,.95),0 0 12px rgba(184,138,68,.4);margin:0 0 var(--space-2) 0;letter-spacing:.06em}.hero-subtitle{font-size:var(--text-base);color:var(--color-text);max-width:650px;margin:0 auto var(--space-4) auto;text-shadow:0 2px 6px rgba(0,0,0,.95)}.hero-subtitle-lead{font-family:var(--font-display);font-size:var(--text-xl);color:var(--color-gold);letter-spacing:.08em;margin-bottom:var(--space-2);text-shadow:0 2px 6px rgba(0,0,0,.95)}.hero-rune{display:block;margin:0 auto var(--space-3) auto;opacity:.7}@keyframes heroRunePulse{0%,to{opacity:.52;transform:translateY(0) scale(1);filter:drop-shadow(0 0 0 rgba(184,138,68,0))}50%{opacity:.82;transform:translateY(-1px) scale(1.025);filter:drop-shadow(0 0 10px rgba(184,138,68,.28))}}@media (prefers-reduced-motion: reduce){.hero-rune,.hero-banner:after{animation:none;transform:none}.hero-sequence-frame{transition:none}}.hero-cta-row{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center}.home-meta{color:var(--color-text-muted);font-size:var(--text-sm);margin:0}.home-changelog-line{color:var(--color-text);font-size:var(--text-sm);line-height:1.6;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.home-section-title{font-family:var(--font-display);font-size:var(--text-xl);color:var(--color-gold);border-bottom:1px solid var(--color-border);padding-bottom:var(--space-2);margin-bottom:var(--space-4);display:flex;align-items:center;gap:var(--space-2)}.quick-link-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) 0;border-bottom:1px dashed var(--color-border)}.quick-link-item:last-child{border-bottom:none}@media (max-width: 1024px){.home-grid{grid-template-columns:1fr}}.ui-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-8);color:var(--color-text-muted);border:1px dashed var(--color-border);border-radius:var(--radius-md);text-align:center}.announcement-list{display:flex;flex-direction:column;gap:var(--space-4)}.announcement-item-head{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-2)}.announcement-cover-thumb{width:100%;max-height:200px;object-fit:cover;border-radius:var(--radius-sm);margin-bottom:var(--space-3);border:1px solid var(--color-border)}.announcement-cover-detail{width:100%;max-height:360px;object-fit:cover;border-radius:var(--radius-sm);margin-bottom:var(--space-4);border:1px solid var(--color-gold)}.announcement-title-link{font-family:var(--font-display);font-size:var(--text-lg);color:var(--color-parchment);text-decoration:none;transition:color .15s ease}.announcement-title-link:hover{color:var(--color-gold)}.announcement-pager{display:flex;align-items:center;gap:var(--space-4);margin-top:var(--space-6)}.announcement-meta-detail{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-4)}.recovery-field{display:flex;flex-direction:column;gap:var(--space-2);max-width:420px}.recovery-info-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--color-border)}.recovery-info-row:last-child{border-bottom:none}.recovery-info-label{width:96px;flex-shrink:0;color:var(--color-text-muted);font-size:var(--text-sm)}.recovery-qr-img{max-width:200px;border-radius:var(--radius-sm);border:1px solid var(--color-border)}.example-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-3) 0;border-bottom:1px solid var(--color-border)}.example-form{display:flex;gap:var(--space-3);align-items:flex-end;flex-wrap:wrap;margin-bottom:var(--space-6)}.example-field{display:flex;flex-direction:column;gap:var(--space-1)}.example-label{font-size:var(--text-xs);color:var(--color-text-muted)}.sidebar-heading{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-muted);padding:var(--space-2) var(--space-3);margin-bottom:var(--space-2);font-family:var(--font-display)}.module-admin-bar{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap;margin-bottom:var(--space-4);padding:var(--space-2) var(--space-3);border:1px dashed var(--color-gold);border-radius:var(--radius-md);background:linear-gradient(0deg,#b88a440f,#b88a440f),var(--color-bg-elevated)}.module-admin-bar-badge{flex-shrink:0;font-size:var(--text-xs);font-weight:600;letter-spacing:.06em;color:var(--color-bg);background:var(--color-gold);border-radius:var(--radius-sm);padding:2px var(--space-2)}.module-admin-bar-text{flex:1 1 auto;min-width:160px;font-size:var(--text-sm);color:var(--color-text-muted)}.module-admin-bar-link{flex-shrink:0}
