:root{color-scheme:light;--bg-1: #EBE3D6;--bg-2: #D9CFC0;--bg-3: #C4B8A8;--paper: #F2EDE2;--paper-2: #FAF6EC;--surface: #E5DCCC;--surface-2: #DED4C0;--line: #C9BCA7;--line-soft: #DDD2BB;--line-dark: #A89B85;--ink: #3A332B;--ink-2: #5C5247;--ink-3: #7A6F61;--muted: #8A7E6E;--muted-2: #A89B85;--terracotta: #B17A5C;--terracotta-dark: #8E5B40;--terracotta-soft: rgba(177, 122, 92, .12);--terracotta-medium: rgba(177, 122, 92, .2);--sage: #8C9787;--sage-dark: #6E7C6A;--sage-soft: rgba(140, 151, 135, .15);--dusty-rose: #C8A8A0;--navy-dust: #6B7280;--olive: #8B8A5B;--clay: #A45F4E;--bone: #E8DFCB;--success: #6B8E5A;--success-soft: rgba(107, 142, 90, .12);--warn: #B68A4D;--warn-soft: rgba(182, 138, 77, .12);--error: #A04A3D;--error-soft: rgba(160, 74, 61, .12);--info: #6B7280;--shadow-sm: 0 2px 6px rgba(58, 51, 43, .04);--shadow-md: 0 6px 20px rgba(58, 51, 43, .08);--shadow-lg: 0 16px 40px rgba(58, 51, 43, .12);--shadow-inset: inset 0 1px 0 rgba(255, 255, 255, .5);--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 20px;--r-2xl: 28px;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--s-8: 32px;--s-10: 40px;--s-12: 48px;--s-16: 64px;--serif: "Source Han Serif SC", "Noto Serif SC", "Songti SC", Georgia, serif;--sans: -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;--mono: "SF Mono", "JetBrains Mono", Menlo, Consolas, monospace}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;font-family:var(--sans);color:var(--ink);background:var(--bg-1);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px;line-height:1.5;overflow:hidden}button,input,select,textarea{font:inherit;color:inherit}a{color:inherit;text-decoration:none}h1,h2,h3,h4,h5,p{margin:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--line-dark)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{to{opacity:0;visibility:hidden}}@keyframes slideUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes slideRight{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes drift{0%,to{transform:translate(0) scale(1)}33%{transform:translate(15px,-10px) scale(1.05)}66%{transform:translate(-10px,12px) scale(.97)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}@keyframes lineGrow{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@keyframes underline{0%{transform:scaleX(0);transform-origin:left}to{transform:scaleX(1);transform-origin:left}}.boot-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-1);z-index:9999;display:flex;align-items:center;justify-content:center;animation:fadeOut .8s ease 1.4s forwards}.boot-content{text-align:center}.boot-mark{font-family:var(--serif);font-size:56px;font-weight:600;color:var(--ink);letter-spacing:.2em;opacity:0;animation:slideUp .9s ease .2s forwards}.boot-line{width:80px;height:1px;background:var(--terracotta);margin:20px auto;opacity:0;animation:lineGrow .6s ease .6s forwards;transform-origin:center}.boot-sub{font-size:11px;color:var(--muted);letter-spacing:.3em;text-transform:uppercase;opacity:0;animation:slideUp .6s ease .8s forwards}.boot-dots{margin-top:24px;display:flex;gap:6px;justify-content:center;opacity:0;animation:slideUp .5s ease 1s forwards}.boot-dot{width:6px;height:6px;border-radius:50%;background:var(--terracotta);animation:pulse 1.2s ease infinite}.boot-dot:nth-child(2){animation-delay:.2s}.boot-dot:nth-child(3){animation-delay:.4s}.app-shell{display:grid;grid-template-columns:280px 1fr;height:100vh;opacity:0;animation:fadeIn .6s ease 1.6s forwards}.app-main{overflow-y:auto;background:var(--bg-1);position:relative}.bg-decoration{position:fixed;pointer-events:none;z-index:0}.bg-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.35;pointer-events:none;animation:drift 12s ease-in-out infinite}.bg-blob.b1{width:360px;height:360px;background:var(--terracotta);top:-120px;left:-100px}.bg-blob.b2{width:300px;height:300px;background:var(--sage);bottom:-80px;right:-100px;animation-delay:3s}.bg-blob.b3{width:220px;height:220px;background:var(--dusty-rose);top:40%;right:20%;animation-delay:6s}.sidebar{background:var(--bg-2);border-right:1px solid var(--line);display:flex;flex-direction:column;overflow-y:auto;position:relative}.sidebar:after{content:"";position:absolute;top:32px;bottom:32px;right:0;width:1px;background:linear-gradient(to bottom,transparent,var(--ink-3) 15%,var(--ink-3) 85%,transparent);opacity:.3}.sidebar-brand{padding:28px 28px 24px;border-bottom:1px solid var(--line-soft)}.brand-name{font-family:var(--serif);font-size:24px;font-weight:600;color:var(--ink);letter-spacing:.08em;line-height:1.2}.brand-tag{font-size:10px;color:var(--muted);margin-top:6px;letter-spacing:.3em;text-transform:uppercase}.lang-switcher{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--ink-muted, #8a8a8a);margin-left:8px}.lang-btn{background:none;border:none;padding:3px 6px;cursor:pointer;color:inherit;font-size:inherit;border-radius:4px;transition:all .15s ease;font-family:inherit}.lang-btn:hover{background:var(--terracotta-soft, #f0e6dd);color:var(--terracotta-dark, #8a4a2a)}.lang-btn.active{color:var(--terracotta-dark, #8a4a2a);font-weight:600}.lang-sep{color:var(--ink-muted, #ccc);-webkit-user-select:none;user-select:none}.nav-section{padding:16px 12px 8px}.nav-section-label{font-size:10px;color:var(--muted);padding:8px 16px 6px;letter-spacing:.25em;text-transform:uppercase;font-weight:600}.nav-list{display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:var(--r-md);color:var(--ink-2);font-size:14px;font-weight:500;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);border:1px solid transparent;background:transparent;width:100%;text-align:left;-webkit-user-select:none;user-select:none;font-family:inherit;text-decoration:none}.nav-item:hover{background:var(--surface);color:var(--ink);transform:translate(2px)}.nav-item.active{background:var(--bg-3);color:var(--ink);border-color:var(--line-dark)}.nav-item.active:before{content:"";position:absolute;left:0;width:3px;height:24px;background:var(--terracotta);border-radius:0 2px 2px 0}.nav-icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:16px;color:var(--terracotta);flex-shrink:0}.nav-label{flex:1}.nav-arrow{margin-left:auto;font-size:14px;color:var(--muted);transition:transform .3s ease}.nav-toggle.expanded .nav-arrow{transform:rotate(90deg)}.nav-sub{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1);margin-left:18px;border-left:1px solid var(--line-soft);padding-left:4px}.nav-toggle.expanded+.nav-sub{max-height:320px}.nav-sub-item{display:flex;align-items:center;gap:8px;padding:7px 16px;color:var(--muted);font-size:13px;cursor:pointer;border-radius:var(--r-sm);margin:1px 0;transition:all .2s ease;text-decoration:none;position:relative}.nav-sub-item:before{content:"";position:absolute;left:-5px;top:50%;width:6px;height:1px;background:var(--line)}.nav-sub-item:hover{color:var(--ink);background:var(--surface);transform:translate(2px)}.nav-sub-item.active{color:var(--terracotta-dark);background:var(--terracotta-soft);font-weight:600}.sidebar-footer{margin-top:auto;padding:16px 12px;border-top:1px solid var(--line-soft)}.user-card{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);transition:all .2s ease;cursor:pointer}.user-card:hover{border-color:var(--terracotta-medium);box-shadow:var(--shadow-sm)}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--terracotta),var(--sage));color:var(--paper);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:14px;font-weight:600;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-size:13px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:11px;color:var(--muted);margin-top:2px}.page{padding:var(--s-12) var(--s-16);min-height:100%;max-width:1400px;margin:0 auto;position:relative}.page-topbar{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:var(--s-12);padding-bottom:var(--s-5);border-bottom:1px solid var(--line-soft);position:relative}.page-eyebrow{font-size:11px;color:var(--terracotta-dark);letter-spacing:.25em;text-transform:uppercase;margin-bottom:10px;font-weight:600}.page-eyebrow:before{content:"— "}.page-title{font-family:var(--serif);font-size:38px;font-weight:600;color:var(--ink);line-height:1.15;letter-spacing:-.01em}.page-sub{color:var(--ink-2);font-size:14px;margin-top:10px;line-height:1.65;max-width:620px}.breadcrumb{font-size:12px;color:var(--muted);padding:8px 14px;background:var(--paper);border:1px solid var(--line);border-radius:100px;display:flex;align-items:center;gap:6px;white-space:nowrap}.breadcrumb strong{color:var(--ink);font-weight:600}.home-hero{position:relative;padding:80px 0 60px;text-align:center}.home-eyebrow{font-size:12px;color:var(--terracotta-dark);letter-spacing:.3em;text-transform:uppercase;margin-bottom:24px;font-weight:600;opacity:0;animation:slideUp .7s ease .2s forwards}.home-title{font-family:var(--serif);font-size:64px;line-height:1.1;color:var(--ink);letter-spacing:-.02em;font-weight:600;max-width:880px;margin:0 auto 24px;opacity:0;animation:slideUp .9s ease .4s forwards}.home-title em{font-style:italic;color:var(--terracotta);position:relative}.home-sub{color:var(--ink-2);font-size:17px;line-height:1.6;max-width:620px;margin:0 auto 40px;opacity:0;animation:slideUp .9s ease .6s forwards}.home-cta{display:flex;gap:12px;justify-content:center;opacity:0;animation:slideUp .9s ease .8s forwards}.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border-radius:100px;border:1px solid var(--line);background:var(--paper);color:var(--ink);font-size:14px;font-weight:500;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);font-family:inherit;text-decoration:none}.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);border-color:var(--line-dark)}.btn-primary{background:var(--terracotta);color:var(--paper);border-color:var(--terracotta)}.btn-primary:hover{background:var(--terracotta-dark);border-color:var(--terracotta-dark)}.btn-ghost{background:transparent;border-color:transparent;color:var(--ink-2)}.btn-ghost:hover{background:var(--surface);color:var(--ink)}.btn-lg{padding:14px 32px;font-size:15px}.btn-block{width:100%;justify-content:center}.deco-divider{display:flex;align-items:center;justify-content:center;margin:60px auto 40px;max-width:200px;color:var(--ink-3);position:relative}.deco-divider:before,.deco-divider:after{content:"";flex:1;height:1px;background:var(--line)}.deco-divider span{font-family:var(--serif);font-size:16px;letter-spacing:.4em;padding:0 16px;color:var(--terracotta)}.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}.feature-card{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-xl);padding:32px 28px;text-align:left;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;text-decoration:none;display:block;opacity:0;animation:slideUp .7s ease forwards}.feature-card:nth-child(1){animation-delay:.2s}.feature-card:nth-child(2){animation-delay:.35s}.feature-card:nth-child(3){animation-delay:.5s}.feature-card:nth-child(4){animation-delay:.65s}.feature-card:nth-child(5){animation-delay:.8s}.feature-card:nth-child(6){animation-delay:.95s}.feature-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--terracotta);transform:scaleX(0);transform-origin:left;transition:transform .4s ease}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--line)}.feature-card:hover:before{transform:scaleX(1)}.feature-icon{width:48px;height:48px;border-radius:var(--r-md);background:var(--terracotta-soft);color:var(--terracotta-dark);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:22px;margin-bottom:20px}.feature-title{font-family:var(--serif);font-size:20px;font-weight:600;color:var(--ink);margin-bottom:8px;letter-spacing:.02em}.feature-desc{color:var(--ink-2);font-size:13px;line-height:1.6}label{display:flex;flex-direction:column;gap:6px;color:var(--ink);font-size:12px;font-weight:500;line-height:1.4}label small{color:var(--muted);font-size:11px;font-weight:400;line-height:1.4}input,select,textarea{width:100%;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);padding:10px 14px;font-size:13px;color:var(--ink);outline:none;transition:all .2s ease;font-family:inherit}input,select{height:38px}textarea{min-height:100px;resize:vertical;line-height:1.6}input:focus,select:focus,textarea:focus{border-color:var(--terracotta);box-shadow:0 0 0 3px var(--terracotta-soft)}input:disabled,select:disabled,textarea:disabled{background:var(--surface);color:var(--muted);cursor:not-allowed}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' fill='none' stroke='%238A7E6E' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.check-row{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--paper);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.check-row:hover{border-color:var(--terracotta)}.check-row input[type=checkbox]{width:14px;height:14px;margin:0;accent-color:var(--terracotta)}.check-group{display:flex;gap:8px;flex-wrap:wrap}.nine-dim-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:var(--s-8)}.dim-field{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-lg);padding:16px 18px;transition:all .2s ease;cursor:pointer}.dim-field:hover{border-color:var(--terracotta);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.dim-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.15em;margin-bottom:6px;font-weight:600}.dim-value{font-size:14px;color:var(--ink);font-weight:500}.dim-field select,.dim-field input{border:none;background:transparent;padding:0;height:24px;font-size:14px;font-weight:500}.dim-field select:focus,.dim-field input:focus{box-shadow:none}.tabs{display:flex;gap:4px;padding:4px;background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--r-lg);margin-bottom:var(--s-5);width:fit-content}.tab{padding:8px 18px;border-radius:var(--r-md);border:none;background:transparent;color:var(--ink-3);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit}.tab:hover{color:var(--ink)}.tab.active{background:var(--paper);color:var(--ink);box-shadow:var(--shadow-sm);font-weight:600}.result-box{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-xl);padding:28px 32px;position:relative}.result-box:before{content:"";position:absolute;top:0;left:32px;right:32px;height:1px;background:var(--terracotta);opacity:.3}.result-title{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--ink);margin-bottom:14px;display:flex;align-items:center;gap:10px}.result-title:before{content:"✦";color:var(--terracotta)}.result-content{color:var(--ink-2);line-height:1.85;font-size:14px;white-space:pre-wrap;font-family:var(--serif);max-height:480px;overflow-y:auto;padding-right:12px}.result-actions{display:flex;gap:10px;margin-top:24px;padding-top:20px;border-top:1px dashed var(--line);flex-wrap:wrap}.result-actions .btn{flex:1;min-width:180px;justify-content:center}.storyboard{display:flex;flex-direction:column;gap:12px}.shot-card{display:grid;grid-template-columns:56px 1fr;gap:16px;padding:16px 20px;background:var(--surface);border:1px solid var(--line-soft);border-left:3px solid var(--terracotta);border-radius:var(--r-lg);transition:all .2s ease}.shot-card:hover{background:var(--paper);border-color:var(--terracotta-medium)}.shot-num{display:grid;place-items:center;background:var(--terracotta);color:var(--paper);border-radius:var(--r-md);font-family:var(--serif);font-weight:700;font-size:14px;text-align:center;line-height:1.2}.shot-body{display:flex;flex-direction:column;gap:4px;font-size:13px;line-height:1.6}.shot-body strong{color:var(--terracotta-dark);font-size:14px}.shot-body span{color:var(--ink-2)}.shot-body em{color:var(--muted);font-style:normal;margin-right:6px}.code-block{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px 24px;font-family:var(--mono);font-size:12px;line-height:1.6;color:var(--ink-2);overflow:auto;max-height:480px;white-space:pre}.workshop-grid{display:grid;grid-template-columns:1fr 340px;gap:20px}.workshop-main{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-xl);padding:24px;display:flex;flex-direction:column;gap:14px}.workshop-side{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-xl);padding:20px;display:flex;flex-direction:column;gap:14px;align-self:start;position:sticky;top:24px}.prompt-input{min-height:120px;font-family:var(--serif);font-size:14px;line-height:1.7;letter-spacing:.02em}.preview-area{aspect-ratio:1;background:var(--surface);border:1px dashed var(--line);border-radius:var(--r-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--muted);font-size:13px;text-align:center;padding:20px;overflow:hidden;position:relative}.preview-area img,.preview-area video{max-width:100%;max-height:100%;object-fit:contain;border-radius:var(--r-md)}.preview-area .preview-icon{font-family:var(--serif);font-size:32px;color:var(--line-dark)}.preview-area .preview-label{font-size:12px;color:var(--muted);letter-spacing:.1em}.preview-area .preview-success{position:absolute;top:12px;right:12px;font-size:11px;color:var(--success);background:var(--success-soft);padding:4px 10px;border-radius:100px}.side-section{border-bottom:1px solid var(--line-soft);padding-bottom:14px}.side-section:last-child{border-bottom:none;padding-bottom:0}.side-title{font-size:11px;color:var(--muted);letter-spacing:.15em;text-transform:uppercase;margin-bottom:10px;font-weight:600}.warning-box{background:var(--warn-soft);border:1px solid var(--warn);border-left-width:3px;border-radius:var(--r-md);padding:10px 14px;font-size:12px;color:var(--ink-2);line-height:1.5}.error-box{background:var(--error-soft);border:1px solid var(--error);border-left-width:3px;border-radius:var(--r-md);padding:10px 14px;font-size:12px;color:var(--ink-2);line-height:1.5;word-break:break-all}.notice-box{background:var(--terracotta-soft);border:1px dashed var(--terracotta);border-radius:var(--r-md);padding:10px 14px;font-size:12px;color:var(--terracotta-dark);line-height:1.5}.media-picker{border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);padding:10px;display:flex;flex-direction:column;gap:8px}.media-picker.disabled{opacity:.5;pointer-events:none}.media-picker-head{display:flex;justify-content:space-between;align-items:center}.media-picker-label{font-size:12px;color:var(--ink-2);font-weight:500}.media-picker-tabs{display:flex;gap:2px;background:var(--paper);border-radius:var(--r-sm);padding:2px}.mp-tab{flex:1;border:none;background:transparent;font-size:11px;padding:4px 8px;border-radius:4px;cursor:pointer;color:var(--muted);font-weight:500;transition:all .15s ease}.mp-tab:hover{color:var(--ink)}.mp-tab.active{background:var(--terracotta);color:var(--paper);font-weight:600}.mp-input{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-sm);padding:6px 10px;font-size:12px;height:30px}.mp-preview{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-sm);padding:4px;max-height:120px;display:flex;align-items:center;justify-content:center}.mp-preview img,.mp-preview video{max-width:100%;max-height:110px;border-radius:4px}.mp-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;max-height:110px;overflow-y:auto}.mp-empty{font-size:11px;color:var(--muted);text-align:center;padding:12px;grid-column:1 / -1}.mp-item{border:1px solid var(--line);border-radius:4px;padding:0;background:var(--paper);cursor:pointer;overflow:hidden;aspect-ratio:1;transition:all .15s ease}.mp-item:hover,.mp-item.active{border-color:var(--terracotta)}.mp-item img{width:100%;height:100%;object-fit:cover}.mp-clear{border:none;background:transparent;color:var(--muted);font-size:14px;cursor:pointer;padding:0;width:18px;height:18px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.mp-clear:hover{background:var(--error);color:var(--paper)}.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.gallery-item{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-lg);overflow:hidden;transition:all .3s ease;cursor:pointer}.gallery-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.gallery-thumb{aspect-ratio:1;background:linear-gradient(135deg,var(--bg-2),var(--bg-3));position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}.gallery-thumb img,.gallery-thumb video{width:100%;height:100%;object-fit:cover}.gallery-thumb-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,transparent 60%,rgba(58,51,43,.4))}.gallery-thumb-badge{position:absolute;top:8px;right:8px;font-size:10px;background:#3a332bb3;color:var(--paper);padding:3px 8px;border-radius:100px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);font-weight:500}.gallery-thumb-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;background:#ffffffe6;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ink);font-size:14px;z-index:1;box-shadow:var(--shadow-md)}.gallery-meta{padding:14px 18px;border-top:1px solid var(--line-soft)}.gallery-title{font-size:14px;font-weight:600;color:var(--ink)}.gallery-sub{font-size:11px;color:var(--muted);margin-top:4px;letter-spacing:.05em}.keys-page{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:1100px}.keys-card{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-xl);padding:28px}.keys-card-title{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--ink);margin-bottom:6px;display:flex;align-items:center;gap:10px}.keys-card-title:before{content:"";display:inline-block;width:4px;height:16px;background:var(--terracotta);border-radius:2px}.keys-card-sub{font-size:12px;color:var(--muted);margin-bottom:20px;line-height:1.5}.form-grid{display:flex;flex-direction:column;gap:12px}.form-actions{display:flex;gap:8px;align-items:center;margin-top:4px}.form-toggle{background:transparent;border:none;color:var(--terracotta-dark);font-size:12px;cursor:pointer;text-decoration:underline;text-underline-offset:2px;padding:0;font-family:inherit}.account-card{display:flex;justify-content:space-between;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:14px 16px;margin-bottom:20px}.account-email{font-size:14px;font-weight:600;color:var(--ink)}.account-role{font-size:11px;color:var(--muted);margin-top:2px;letter-spacing:.1em;text-transform:uppercase}.key-section{margin-bottom:16px}.key-section:last-child{margin-bottom:0}.key-section-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.15em;margin-bottom:8px;font-weight:600}.key-section-label:before{content:"◆ ";color:var(--terracotta)}.key-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.key-list li{display:flex;justify-content:space-between;align-items:center;background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-md);padding:10px 14px;transition:all .2s ease}.key-list li:hover{border-color:var(--terracotta-medium)}.key-info-main{display:flex;flex-direction:column;gap:2px}.key-name{font-size:13px;font-weight:600;color:var(--ink)}.key-meta{font-size:11px;color:var(--muted)}.key-list .btn-danger{font-size:11px;padding:4px 10px;border-radius:var(--r-sm);background:transparent;border:1px solid var(--line);color:var(--error);cursor:pointer;font-family:inherit;transition:all .2s ease}.key-list .btn-danger:hover{background:var(--error-soft);border-color:var(--error)}.key-empty{font-size:12px;color:var(--muted);text-align:center;padding:24px;background:var(--surface);border:1px dashed var(--line);border-radius:var(--r-md)}.add-key-row{display:grid;grid-template-columns:1fr 1.5fr 1fr auto;gap:6px;background:var(--surface);padding:10px;border-radius:var(--r-md);margin-bottom:12px}.add-key-row input,.add-key-row select{height:32px;font-size:12px;padding:4px 10px}.add-key-row button{height:32px;font-size:12px;padding:4px 12px}.key-hint{font-size:11px;color:var(--muted);line-height:1.5;margin-top:16px;padding:12px 14px;background:var(--surface);border-left:2px solid var(--terracotta);border-radius:0 var(--r-sm) var(--r-sm) 0}.route-fade-enter{opacity:0;transform:translateY(12px)}.route-fade-enter-active{opacity:1;transform:translateY(0);transition:all .4s ease}.page-transition{animation:slideUp .4s ease}@media(max-width:1280px){.page{padding:var(--s-10) var(--s-8)}.feature-grid,.nine-dim-grid,.gallery-grid{grid-template-columns:repeat(2,1fr)}.home-title{font-size:52px}.workshop-grid{grid-template-columns:1fr 300px}.keys-page{grid-template-columns:1fr}}@media(max-width:1024px){.app-shell{grid-template-columns:220px 1fr}.page{padding:var(--s-8) var(--s-6)}.home-title{font-size:44px}.feature-grid,.nine-dim-grid,.gallery-grid,.workshop-grid{grid-template-columns:1fr}.workshop-side{position:static}}@media(max-width:768px){.app-shell{grid-template-columns:1fr}.sidebar{display:none}.home-title{font-size:32px}.page-title{font-size:26px}.keys-page{grid-template-columns:1fr}}.empty-state{padding:var(--s-12) var(--s-6);text-align:center;color:var(--muted);font-size:13px;background:var(--surface);border:1px dashed var(--line);border-radius:var(--r-lg)}.alert{padding:12px 16px;border-radius:var(--r-md);font-size:13px;margin-bottom:var(--s-4);display:flex;align-items:center;gap:10px}.alert-error{background:var(--error-soft);border:1px solid var(--error);color:var(--ink);border-left-width:3px}.btn-sm{padding:6px 14px;font-size:12px;height:auto}.data-table{width:100%;border-collapse:collapse;font-size:13px;background:var(--paper)}.data-table th,.data-table td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--line-soft)}.data-table th{background:var(--surface);font-weight:600;color:var(--ink-2);font-size:12px;letter-spacing:.05em;text-transform:uppercase}.data-table tbody tr:hover{background:var(--surface)}.data-table code{font-family:var(--mono);font-size:12px;color:var(--ink-2);background:var(--surface);padding:2px 6px;border-radius:var(--r-sm)}.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-4);margin-bottom:var(--s-6)}@media(max-width:768px){.stat-row{grid-template-columns:repeat(2,1fr)}}.stat-card{background:var(--paper);border-radius:var(--r-lg);padding:var(--s-5);box-shadow:var(--shadow-sm);border:1px solid var(--line-soft);transition:all .2s ease}.stat-card:hover{border-color:var(--line);box-shadow:var(--shadow-md)}.stat-label{font-size:12px;color:var(--muted);margin-bottom:10px;letter-spacing:.05em;text-transform:uppercase;font-weight:600}.stat-value{font-size:28px;font-weight:700;color:var(--ink);line-height:1.1}.stat-unit{font-size:14px;color:var(--muted);margin-left:4px;font-weight:400}.stat-trend{font-size:12px;margin-top:6px;font-weight:500}.stat-warning .stat-value{color:var(--warn)}.stat-critical .stat-value{color:var(--error)}.chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-4);margin-bottom:var(--s-6)}@media(max-width:768px){.chart-grid{grid-template-columns:1fr}}.chart-card{background:var(--paper);border-radius:var(--r-lg);padding:var(--s-5);box-shadow:var(--shadow-sm);border:1px solid var(--line-soft)}.chart-title{font-family:var(--serif);font-size:15px;font-weight:600;color:var(--ink);margin:0 0 var(--s-4) 0;letter-spacing:.02em;display:flex;align-items:center;gap:8px}.chart-title:before{content:"";display:inline-block;width:3px;height:14px;background:var(--terracotta);border-radius:2px}.status-2xx{color:var(--success);font-weight:600}.status-4xx{color:var(--warn);font-weight:600}.status-5xx{color:var(--error);font-weight:600}
