@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;600;700&display=swap";:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;width:100%;min-height:100vh;overflow-x:hidden;overflow-y:auto}body{min-height:100vh}#root{width:100%;min-height:100vh}.app-container{display:flex;flex-direction:column;width:100%;height:100vh;position:relative;overflow:hidden}:root{--primary-start: #28a745;--primary-end: #1f7a38}.header{background:#1a1a1a;color:#fff;padding:15px 20px;border-bottom:1px solid #444;display:flex;align-items:center;justify-content:flex-start;gap:12px;flex-wrap:nowrap}.keychain-progress{position:sticky;top:0;z-index:50;background:#1f2a38;color:#cfe6ff;padding:8px 14px;border-bottom:1px solid #2a3b52;font-weight:700;text-align:center}.header-left{display:none}.header-title{margin:0;font-size:clamp(1rem,2vw,1.2rem);text-align:left;flex:0 1 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-counter{font-size:.9rem;color:#ddd;white-space:normal}.header-remaining{font-size:.85rem;color:#a9c1ff}.header-right{display:flex;align-items:center;justify-content:flex-end;gap:10px;min-width:0;margin-left:auto}.header-actions{display:flex;gap:8px;align-items:center}.header-action-link{color:#cfd6e4;text-decoration:none;font-weight:700;border:1px solid #2f3542;padding:6px 10px;border-radius:6px;background:#232833}.header-action-icon{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;padding:0}.header-action-icon svg{width:18px;height:18px}.header-action-link:hover{background:#2b313d}.header-action-logout{color:#ffb3b3;border-color:#5a2b2b;background:#2a1a1a}.footer-bar{background:#1a1a1a;color:#888;padding:10px 20px;border-top:1px solid #444;display:flex;align-items:center;justify-content:space-between;font-size:.9rem;gap:12px;flex-wrap:wrap}.footer-left,.footer-right{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.footer-link{color:#ccc;text-decoration:none}.footer-btn{background:#2a2a2a;color:#ccc;border:1px solid #444;padding:8px 12px;border-radius:4px;cursor:pointer;font-weight:600;text-decoration:none}.main-content{flex:1;display:flex;position:relative;width:100%;overflow:hidden;min-height:0}.scene-container{flex:1;position:relative;width:100%;height:100%;min-width:0;min-height:0;--bg-0: #0b0f16;--bg-1: #111723;--bg-2: #161f2b;background:radial-gradient(1200px 500px at 50% -10%,#ffffff1a,#ffffff08 35%,#fff0 70%),radial-gradient(900px 700px at 50% 45%,#bebedc1a,#bebedc0a 38%,#0000 70%),radial-gradient(1400px 900px at 55% 35%,#28325a47,#28325a1a 45%,#0000 75%),linear-gradient(180deg,var(--bg-2) 0%,var(--bg-1) 35%,var(--bg-0) 100%)}.catalog-container{width:0;max-width:0;border-left:1px solid #444;background:#1a1a1a;height:100%;overflow-y:auto;transition:transform .3s ease-in-out,width .3s ease-in-out,max-width .3s ease-in-out,opacity .3s ease-in-out;z-index:15;opacity:0;pointer-events:none}.catalog-backdrop{position:fixed;inset:0;background:transparent;border:none;padding:0;margin:0;cursor:pointer;z-index:20}.catalog-container.open,.catalog-container.locked-open{width:300px;max-width:90vw;opacity:1;pointer-events:auto;transform:translate(0)}.catalog-wrapper{padding:20px;color:#fff}.catalog-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.catalog-tabs{display:flex;gap:6px;padding:6px;border-radius:999px;border:1px solid #2a2a2a;background:#1a1f2b;margin:8px 0 14px}.catalog-tab{flex:1 1 0;border:none;border-radius:999px;padding:8px 12px;font-weight:700;color:#b8c0cc;background:transparent;cursor:pointer}.catalog-tab.active{color:#fff;background:#2a313d;box-shadow:inset 0 0 0 1px #5fa7ff66}.name-inline{margin-top:10px;margin-bottom:10px}.catalog-top-controls{display:flex;align-items:center;gap:12px;margin-top:10px;margin-bottom:10px;flex-wrap:wrap}.catalog-top-controls .name-inline{margin:0}.preset-picker{position:relative;min-width:140px}.preset-trigger{display:inline-flex;align-items:center;gap:8px;width:100%;padding:6px 10px;border-radius:10px;border:1px solid #d7dee8;background:#fff;color:#1f2733;cursor:pointer;min-height:32px}.preset-trigger.open{border-color:#3a7bd573;box-shadow:0 0 0 2px #3a7bd52e}.preset-avatar{width:28px;height:28px;border-radius:50%;background:#eef2f7;border:1px solid #d7dee8;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;flex:0 0 28px}.preset-avatar img{width:100%;height:100%;object-fit:cover;display:block}.preset-avatar.custom{background:#e1e6ee;border-color:#c7d0dd}.preset-dot{width:10px;height:10px;border-radius:50%;background:#9aa4b5;display:block}.preset-label{font-weight:600;color:#1f2733;white-space:nowrap}.preset-caret{margin-left:auto;width:6px;height:6px;border-right:2px solid #6c7a90;border-bottom:2px solid #6c7a90;transform:rotate(45deg)}.preset-menu{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border:1px solid #d7dee8;border-radius:12px;padding:6px;box-shadow:0 16px 30px #1f27332e;display:flex;flex-direction:column;gap:4px;z-index:30}.preset-option{display:flex;align-items:center;gap:10px;padding:6px;border-radius:10px;border:1px solid transparent;background:transparent;cursor:pointer;text-align:left}.preset-option:hover{background:#f1f5fb}.preset-option.selected{background:#e6efff;border-color:#c9d9f5}.name-inline label{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:#f5f5f5}.name-inline input{background:#2a2a2a;color:#fff;border:1px solid #444;border-radius:8px;padding:8px 10px;min-width:140px}.catalog-accordion{display:flex;flex-direction:column;gap:10px;margin-top:10px}.catalog-section{display:flex;flex-direction:column;gap:10px}.catalog-sticky-tabs{position:sticky;top:8px;z-index:6;display:flex;gap:6px;padding:0;border-radius:12px;background:transparent;border:0;opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity .2s ease,transform .2s ease;margin-bottom:0;height:0;overflow:hidden}.catalog-sticky-tabs.show{opacity:1;pointer-events:auto;transform:translateY(0);padding:6px;background:#1a1f2b;border:1px solid #2a2a2a;margin-bottom:8px;height:auto;overflow:visible}.catalog-sticky-tab{flex:1 1 0;border:none;border-radius:10px;padding:6px 8px;font-size:.85rem;font-weight:700;color:#b8c0cc;background:transparent;cursor:pointer}.catalog-sticky-tab.active{color:#fff;background:#2a313d;box-shadow:inset 0 0 0 1px #5fa7ff73}.catalog-segmented{display:flex;gap:6px;padding:6px;border-radius:12px;border:1px solid #2a2a2a;background:#1a1f2b}.catalog-segmented-btn{flex:1 1 0;border:none;border-radius:10px;padding:8px 10px;font-weight:700;color:#b8c0cc;background:transparent;cursor:pointer}.catalog-segmented-btn.active{color:#fff;background:#2a313d;box-shadow:inset 0 0 0 1px #5fa7ff73}.catalog-top-wrap{position:sticky;bottom:16px;display:flex;justify-content:flex-end;padding:0 4px;opacity:0;pointer-events:none;transform:translateY(6px);transition:opacity .2s ease,transform .2s ease;height:0;margin:0;overflow:hidden}.catalog-top-wrap.show{opacity:1;pointer-events:auto;transform:translateY(0);height:auto;margin-top:8px;overflow:visible}.catalog-top-button{width:38px;height:38px;border-radius:999px;border:none;background:transparent;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:none;padding:0}.catalog-top-button img{width:50px;height:50px}.catalog-panel{background:#1f1f1f;border:1px solid #2a2a2a;border-radius:10px;overflow:visible}.catalog-panel-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:#2a2a2a;color:#f5f5f5;border:none;cursor:pointer;font-weight:700}.catalog-panel-header .caret{border:solid #f5f5f5;border-width:0 2px 2px 0;display:inline-block;padding:4px;transform:rotate(45deg);transition:transform .2s ease}.catalog-panel-header .caret.open{transform:rotate(-135deg)}.catalog-panel-body{padding:12px 14px 16px}.special-controls{display:flex;flex-direction:column;gap:12px}.special-hint{margin:0;color:#aab2bf;font-size:12px}.scale-controls{display:flex;flex-direction:column;gap:12px}.scale-hint{margin:0;color:#aab2bf;font-size:12px}.scale-presets{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.scale-preset{background:#1a1f27;border:1px solid #2a2f38;border-radius:8px;color:#f5f5f5;padding:8px 10px;text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:2px}.scale-preset small{color:#9aa4b2;font-size:11px}.scale-preset.active{border-color:#5fa7ff;box-shadow:0 0 0 2px #5fa7ff33;background:#243a5e}.scale-custom{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border-radius:8px;border:1px solid #2a2f38;background:#151a21}.scale-custom.active{border-color:#5fa7ff;box-shadow:0 0 0 2px #5fa7ff26}.scale-custom-label{font-weight:700;color:#f5f5f5}.scale-input{display:inline-flex;align-items:center;gap:6px;background:#0f1318;border:1px solid #2a2f38;border-radius:6px;padding:4px 6px}.scale-input input{width:60px;background:transparent;border:none;color:#f5f5f5;font-weight:700;text-align:right}.scale-input input:focus{outline:none}.scale-unit{color:#aab2bf;font-size:12px}.special-toggle{display:flex;align-items:center;gap:8px;font-weight:700;color:#f0f0f0}.special-row{display:flex;flex-direction:column;gap:8px}.special-label{font-size:.85rem;color:#b4bdcc;font-weight:600}.special-toggle-group{display:flex;gap:12px;flex-wrap:wrap}.special-toggle-group label{display:flex;gap:6px;align-items:center;font-weight:600;color:#d5d9e3}.special-select{width:100%;background:#0c0f14;border:1px solid #2a2f3b;color:#f5f5f5;border-radius:6px;padding:6px 8px}.special-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.special-stack{display:flex;flex-direction:column;gap:10px}.special-control{display:flex;flex-direction:column;align-items:stretch;gap:6px;background:#151a22;border:1px solid #232a36;padding:8px;border-radius:8px}.special-control input[type=range]{width:100%}.special-control input[type=number]{width:70px;background:#0c0f14;border:1px solid #2a2f3b;color:#f5f5f5;border-radius:6px;padding:4px 6px}.special-button{background:linear-gradient(135deg,var(--primary-start),var(--primary-end));border:1px solid transparent;color:#fff;padding:8px 12px;border-radius:8px;font-weight:600;cursor:pointer}.special-button:hover{filter:brightness(.95)}.catalog-group{margin-bottom:14px;padding:10px;border-radius:8px;background:#1f1f1f;border:1px solid #2a2a2a}.catalog-group-title{margin-bottom:8px;display:flex;align-items:center;gap:8px}.catalog-group-hint{font-size:12px;color:#aaa}.catalog-choices-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px}.catalog-dropdown-wrapper{display:flex;flex-direction:column;gap:10px}.catalog-dropdown-row{display:flex;align-items:center;gap:8px}.catalog-dropdown{width:100%;background:#161a21;color:#f5f5f5;border:1px solid #2a2f38;border-radius:8px;padding:10px 12px;font-weight:700}.catalog-clear{background:#222834;border:1px solid #343c4a;color:#ff7b7b;border-radius:8px;padding:8px 10px;line-height:1;cursor:pointer;font-size:16px}.catalog-clear:hover{background:#2b3240}.dropdown-colors{display:flex;flex-direction:column;gap:8px}.dropdown-color{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;color:#e5eaf2;font-weight:600}.dropdown-color input[type=color]{width:40px;height:32px;border:1px solid #444;border-radius:6px;background:#0c0f14;cursor:pointer}.catalog-choice{display:flex;align-items:center;gap:8px}.catalog-choice>button{flex:1;min-width:0}.choice-color-row{display:flex;flex-wrap:wrap;gap:6px}.choice-color-label{display:inline-flex;align-items:center;gap:6px;color:#f5f5f5;font-weight:600;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;padding:6px 8px}.choice-color-label input[type=color]{width:32px;height:26px;padding:0;border:1px solid #444;border-radius:4px;background:#0c0f14;cursor:pointer}.choice-inline-colors{display:flex;flex-direction:column;gap:8px;margin-left:auto;align-items:flex-end}.choice-inline-colors input[type=color]{width:28px;height:24px;padding:0;border:1px solid #444;border-radius:4px;background:#0c0f14;cursor:pointer}.color-grid-picker{display:flex;flex-direction:column;gap:6px;position:relative}.color-grid-trigger{width:30px;height:30px;padding:0;border:1px solid #2d2d2d;border-radius:6px;background:#0c0f14;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.color-grid-picker.open .color-grid-trigger{border-color:#5fa7ff;box-shadow:0 0 0 2px #5fa7ff33}.color-grid-dot{width:16px;height:16px;border-radius:50%;border:1px solid #ffffff}.color-grid-panel{--grid-size: 24px;--grid-gap: 6px;--grid-cols: 5;--panel-pad: 6px;box-sizing:border-box;width:calc((var(--grid-cols) * var(--grid-size)) + ((var(--grid-cols) - 1) * var(--grid-gap)) + (var(--panel-pad) * 2));z-index:1000;background:#0f1318;border:1px solid #2a2f38;border-radius:10px;padding:var(--panel-pad);box-shadow:0 12px 24px #00000059}.color-grid-label{font-size:12px;color:#d8dde6;font-weight:600}.color-grid{display:grid;grid-template-columns:repeat(var(--grid-cols),var(--grid-size));grid-auto-rows:var(--grid-size);gap:var(--grid-gap);align-items:center;justify-content:start}.color-swatch{width:var(--grid-size, 24px);height:var(--grid-size, 24px);border-radius:6px;border:1px solid #dddddd;cursor:pointer;padding:0}.color-swatch.selected{border-color:#fff;box-shadow:0 0 0 2px #5fa7ff73}.color-swatch-picker{border:1px dashed #4a5568;background:#11161d;color:#d8dde6;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;line-height:1;overflow:visible;position:relative}.color-grid-native{position:absolute;inset:0;opacity:0;cursor:pointer}.color-grid-input-row{display:flex;align-items:center;gap:6px;width:100%;box-sizing:border-box;margin-top:3px}.color-grid-input{flex:1;min-width:0;background:#151a21;border:1px solid #2a2f38;border-radius:6px;padding:4px 6px;color:#f5f5f5;font-family:inherit;font-size:12px}.color-grid-custom{margin-top:8px;width:100%}.color-grid-custom .react-colorful{width:100%;height:140px}.color-grid-ok{background:#2b6cb0;color:#fff;border:1px solid #2f78c4;border-radius:6px;padding:4px 10px;font-size:12px;cursor:pointer}.color-grid-ok:hover{background:#2f78c4}.color-grid-panel.compact{--grid-size: 20px}.color-grid-picker.compact .color-grid-trigger{width:28px;height:28px}.color-grid-picker.compact .color-grid-dot{width:12px;height:12px}.color-grid-panel.compact .color-grid-input{font-size:11px;padding:3px 5px}.body-controls{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:10px}.body-control{display:inline-flex;align-items:center;gap:6px;color:#f5f5f5;font-weight:600}.body-control select,.body-control input[type=color]{background:#2a2a2a;color:#fff;border:1px solid #444;border-radius:6px;padding:6px 8px;cursor:pointer}.body-control-buttons{display:flex;gap:6px;flex-wrap:wrap}.body-control-buttons button{background:#2a2a2a;color:#fff;border:1px solid #444;padding:8px 12px;border-radius:6px;cursor:pointer;font-weight:600}.body-control-buttons button:disabled{color:#777;cursor:not-allowed}.segment-list{display:flex;flex-direction:column;gap:10px}.segment-card{background:#1f242c;border:1px solid #2a313d;border-radius:12px;overflow:hidden}.segment-card-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;cursor:pointer;gap:8px}.segment-card-title{font-weight:0;color:#f5f5f5}.segment-card-actions{display:flex;align-items:center;gap:8px}.segment-caret{border:solid #f5f5f5;border-width:0 2px 2px 0;display:inline-block;padding:4px;transform:rotate(45deg);transition:transform .2s ease}.segment-caret.open{transform:rotate(-135deg)}.segment-card-body{padding:10px 12px 14px;background:#161a21;border-top:1px solid #2a313d;overflow:visible}.text-gen-controls{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.text-color-row{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:#f5f5f5}.text-gen-controls input{flex:1 1 160px;min-width:140px;padding:8px 10px;border-radius:8px;border:1px solid #2f2f2f;background:#1a1a1a;color:#f5f5f5}.text-gen-controls button{padding:8px 12px;border-radius:8px;border:1px solid #1f7a38;background:linear-gradient(135deg,var(--primary-start),var(--primary-end));color:#fff;font-weight:700;cursor:pointer}.text-gen-controls .color-grid-trigger{width:28px;height:24px;padding:0;border:1px solid #2d2d2d;border-radius:6px;background:#0c0f14;box-shadow:none}.save-share{display:flex;flex-direction:column;gap:10px}.save-share-name{display:flex;flex-direction:column;gap:6px;font-weight:600;color:#f5f5f5}.save-share-name input{padding:8px 10px;border-radius:8px;border:1px solid #2f2f2f;background:#1a1a1a;color:#f5f5f5}.save-share-actions{display:flex;align-items:center;gap:10px}.save-share-btn{padding:8px 12px;border-radius:8px;border:1px solid #1f7a38;background:linear-gradient(135deg,var(--primary-start),var(--primary-end));color:#fff;font-weight:700;cursor:pointer;margin-left:auto}.save-share-btn:disabled{opacity:.6;cursor:not-allowed}.save-share-link{display:flex;align-items:center;gap:8px}.save-share-link input{flex:1 1 auto;min-width:0;padding:6px 8px;border-radius:8px;border:1px solid #2f2f2f;background:#141821;color:#f5f5f5}.save-share-link button{padding:6px 10px;border-radius:8px;border:1px solid #2f2f2f;background:#1d2430;color:#f5f5f5;font-weight:600;cursor:pointer}.save-share-error{color:#d96b6b;font-size:12px;font-weight:600}.save-share-visibility{display:inline-flex;align-items:center;gap:6px;font-weight:600;color:#f5f5f5}.save-share-visibility select{padding:6px 8px;border-radius:8px;border:1px solid #2f2f2f;background:#1a1a1a;color:#f5f5f5;font-weight:600}.segment-add{background:linear-gradient(135deg,var(--primary-start),var(--primary-end));color:#fff;border:none;padding:10px 12px;border-radius:10px;cursor:pointer;font-weight:700;width:100%;text-align:center}.controls-overlay{position:absolute;top:20px;right:20px;z-index:20;display:flex;gap:12px;flex-direction:column;align-items:flex-end}.history-controls{display:flex;gap:4px;align-items:center}.quick-actions{display:flex;gap:10px;align-items:center;justify-content:flex-end;flex-wrap:wrap;background:#00000059;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:10px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.random-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;padding:10px 14px;border-radius:8px;cursor:pointer;font-weight:700;box-shadow:0 4px 12px #00000059;transition:transform .1s ease,box-shadow .1s ease}.random-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.random-btn:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 8px 18px #2563eb59}.export-loading{display:flex;align-items:center;gap:8px;color:#f5f5f5;font-size:.9rem}.export-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#4caf50;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.catalog-toggle{display:none;align-items:center;justify-content:center;background:#2a2a2a;color:#f5f5f5;border:1px solid #444;padding:10px 16px;border-radius:8px;cursor:pointer;font-weight:700;box-shadow:0 4px 12px #00000059}.catalog-toggle:hover{background:#333}.undo-button,.redo-button{display:flex;align-items:center;justify-content:center;width:44px;height:44px;margin-top:13px;background:transparent;color:inherit;border:none;padding:0;border-radius:8px;cursor:pointer;font-weight:700;box-shadow:none}.undo-button:disabled,.redo-button:disabled{opacity:.5;cursor:not-allowed}.undo-button-icon{width:100%;height:100%;display:block}.download-dropdown{position:relative;min-width:150px;border-radius:8px;overflow:visible}.download-toggle{position:relative;isolation:isolate;width:80%;display:flex;justify-content:space-between;align-items:center;background:transparent;color:#fff;border:none;padding:12px 14px;border-radius:8px;overflow:hidden;background-clip:padding-box;clip-path:inset(0 round 8px);cursor:pointer;font-weight:700;box-shadow:0 4px 12px #00000059}.download-toggle:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--primary-start),var(--primary-end));border-radius:inherit;z-index:-1}.download-toggle:disabled{opacity:.65;cursor:not-allowed}.download-toggle .caret{border:solid white;border-width:0 2px 2px 0;display:inline-block;padding:4px;transform:rotate(-135deg);transition:transform .2s ease}.download-toggle .caret.open{transform:rotate(45deg)}.floating-download{position:fixed;bottom:clamp(16px,3.2vh,56px);right:20px;z-index:60}.random-fab{position:fixed;bottom:clamp(16px,3.2vh,56px);left:20px;width:44px;height:44px;padding:0;border-radius:50%;background:transparent;color:inherit;border:none;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:none;outline:none;transform:translateY(6px)}.random-fab:disabled{opacity:.6;cursor:not-allowed}.random-fab-icon{width:100%;height:100%;display:block;transform:scale(1.25);transform-origin:center}.download-menu{position:absolute;bottom:calc(100% + 6px);top:auto;right:0;background:#1c1f24;border:1px solid #2a2f36;border-radius:8px;box-shadow:0 10px 30px #00000073;overflow:hidden;min-width:220px;z-index:30}.download-menu button{width:100%;text-align:left;padding:12px 14px;background:transparent;color:#f5f5f5;border:none;cursor:pointer;font-weight:600}.download-menu button:hover{background:#262b32}.download-menu button:disabled{opacity:.6;cursor:not-allowed}.name-modal-backdrop{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.name-modal{background:#1a1f2b;color:#f5f5f5;padding:20px;border-radius:10px;width:90%;max-width:360px;box-shadow:0 20px 50px #0000008c;border:1px solid #2a2f3b;display:flex;flex-direction:column;gap:12px}.name-modal h2{margin:0;font-size:1.1rem}.name-modal input{width:100%;padding:10px;border-radius:8px;border:1px solid #333a47;background:#0c0f14;color:#f5f5f5}.name-modal-actions{display:flex;justify-content:flex-end;gap:10px}.name-modal-cancel,.name-modal-confirm{padding:10px 12px;border-radius:8px;border:none;cursor:pointer;font-weight:600}.name-modal-cancel{background:#eceff3;color:#5f6b7a}.name-modal-confirm{background:linear-gradient(135deg,#2f6bc9,#2456a6);color:#fff}.name-modal-confirm:disabled{opacity:.5;cursor:not-allowed}.name-edit-inline{background:transparent;color:#fff;border:1px dashed #555;padding:4px 8px;border-radius:6px;cursor:pointer;font-size:.8rem}.beta-banner{margin:8px 12px;background:linear-gradient(135deg,#ffb267,#ff6f61);color:#0f0b05;padding:14px 18px;display:flex;align-items:center;justify-content:flex-start;gap:12px;font-weight:600;position:sticky;top:8px;z-index:50;flex-wrap:wrap;row-gap:8px;border-radius:12px;box-shadow:0 10px 30px #00000059;border:1px solid rgba(0,0,0,.12)}.beta-banner-message{flex:1;min-width:240px;line-height:1.45}.beta-banner-close{background:#00000026;border:1px solid rgba(0,0,0,.25);color:#1a1a1a;padding:6px 12px;border-radius:6px;cursor:pointer;font-weight:700;margin-left:auto;line-height:1}.beta-banner-close:hover{background:#00000040}.gallery-page{min-height:100vh;padding:28px 20px 64px;background:#f4f7fb;color:#1a2433}.terms-page{min-height:100vh;padding:30px 20px;background:#0f1115;color:#f5f5f5;display:flex;justify-content:center}.terms-card{width:100%;max-width:820px;background:#161a21;border:1px solid #222834;border-radius:14px;padding:28px;box-shadow:0 20px 45px #00000073;display:flex;flex-direction:column;gap:16px}.terms-card h1{margin:0 0 6px;font-size:clamp(1.4rem,3vw,1.8rem)}.terms-card p{margin:0;line-height:1.6;color:#e2e6ef}.terms-card a{color:#5fa7ff;text-decoration:none}.terms-card a:hover{text-decoration:underline}.terms-card .divider{height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);margin:12px 0}.terms-card .thanks{font-size:1.05rem}.terms-card .highlight a{color:#7be0a7;font-weight:700}.terms-card .cheers{margin:0;color:#c5cad8}.profile-page{min-height:100vh;padding:24px;background:#0f1115;color:#f5f5f5;display:flex;justify-content:center;align-items:flex-start}.profile-card{width:100%;max-width:520px;background:#161a21;border:1px solid #222834;border-radius:16px;padding:24px;box-shadow:0 20px 40px #0006;display:flex;flex-direction:column;gap:16px}.profile-header{display:flex;align-items:center;justify-content:flex-start;gap:10px;flex-wrap:nowrap}.profile-header-main{display:flex;align-items:center;gap:18px;width:100%;flex-wrap:nowrap}.profile-header-text{display:flex;flex-direction:column;gap:4px;align-items:flex-start;text-align:left}.profile-avatar{position:relative;width:48px;height:48px;min-width:48px;min-height:48px;flex:0 0 48px;aspect-ratio:1 / 1;border-radius:50%;background:#141922;border:1px solid #2a2f3b;display:inline-flex;align-items:center;justify-content:center;font-weight:700;color:#e6edf7;text-transform:uppercase}.profile-crown{position:absolute;top:-10px;right:-8px;width:24px;height:24px;border-radius:999px;background:#0f131a;border:1px solid #2a2f3b;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 6px 16px #00000059}.profile-crown svg{width:16px;height:16px}.header-profile-icon{position:relative}.header-crown{position:absolute;top:-7px;right:-7px;width:20px;height:20px;border-radius:999px;background:#0f131a;border:1px solid #2a2f3b;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 4px 10px #00000059}.header-crown svg{width:14px;height:14px}.profile-header h1{margin:0}.profile-subtitle{margin:4px 0 0;color:#b4bdcc}.profile-header-actions{display:inline-flex;gap:10px;align-items:center;margin-left:auto}.profile-home{color:#cfe6ff;text-decoration:none;font-weight:700;border:1px solid #2f3542;padding:6px 10px;border-radius:8px;background:#1f2937}.profile-footer-actions{display:flex;justify-content:flex-end}.celebration-overlay{position:fixed;inset:0;pointer-events:none;z-index:260;overflow:hidden}.confetti-piece{position:absolute;top:-12px;border-radius:3px;opacity:0;animation-name:confetti-fall;animation-timing-function:ease-in;animation-fill-mode:forwards;box-shadow:0 4px 10px #1f273326}@keyframes confetti-fall{0%{transform:translate3d(0,-10vh,0) rotate(0);opacity:0}12%{opacity:1}to{transform:translate3d(var(--confetti-drift),110vh,0) rotate(var(--confetti-rotate));opacity:0}}.profile-error-backdrop{position:fixed;inset:0;background:#0a0c128c;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.profile-error-modal{width:100%;max-width:420px;background:#161a21;border:1px solid #222834;border-radius:12px;padding:16px 18px;color:#f5f5f5;box-shadow:0 18px 36px #00000073;display:flex;flex-direction:column;gap:10px}.profile-error-modal h3{margin:0}.profile-error-modal p{margin:0;color:#cbd3df}.profile-error-button{align-self:flex-end;background:linear-gradient(135deg,var(--primary-start),var(--primary-end));border:none;color:#fff;padding:8px 14px;border-radius:8px;font-weight:700;cursor:pointer}.profile-logout{text-decoration:none}.profile-logout-subtle{color:#7f8898;font-size:.8rem;font-weight:600;opacity:.7}.profile-logout-subtle:hover{color:#aab3c2;opacity:1}.profile-section{display:flex;flex-direction:column;gap:8px}.profile-label{font-size:.9rem;color:#c7cedb;font-weight:600}.profile-input{background:#0c0f14;color:#f5f5f5;border:1px solid #2a2f3b;border-radius:10px;padding:10px 12px}.profile-redeem-form{display:flex;gap:10px;flex-wrap:wrap}.profile-redeem-button{padding:10px 14px;border-radius:10px;border:none;cursor:pointer;background:linear-gradient(135deg,var(--primary-start),var(--primary-end));color:#fff;font-weight:700}.profile-hint{margin:4px 0 0;color:#9aa4b5;font-size:.85rem}.profile-codes{display:flex;flex-direction:column;gap:8px}.profile-code-row{display:flex;justify-content:space-between;align-items:center;background:#0f141d;border:1px solid #1e2633;border-radius:10px;padding:10px 12px;gap:12px;flex-wrap:wrap}.profile-code-row.code-disabled{background:#14181f;border-color:#2b313d;color:#8f98a7;opacity:.7}.profile-code-row.code-disabled .profile-code,.profile-code-row.code-disabled .profile-date{color:#8f98a7}.profile-code-row.code-disabled .feature-chip{border-color:#2d343f;color:#8f98a7;background:#141922}.profile-code-row.code-disabled .feature-chip.enabled{border-color:#2d343f;background:#141922;color:#8f98a7}.code-status{color:#8f98a7;font-weight:600}.profile-code{font-weight:700;color:#f5f5f5}.profile-features{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}.feature-chip{background:#151b24;border:1px solid #2b3444;color:#8f98a7;font-size:.75rem;padding:4px 8px;border-radius:999px;white-space:nowrap}.feature-chip.enabled{color:#d9f5e3;border-color:#2c5a3f;background:#153020}.profile-date{color:#8f98a7;font-size:.85rem}.profile-remove-button{background:#2a1a1a;color:#ffb3b3;border:1px solid #5a2b2b;padding:6px 10px;border-radius:8px;font-weight:700;cursor:pointer;white-space:nowrap}@media(max-width:720px){.profile-page{padding:16px}.profile-card{padding:18px}.profile-header-actions{width:auto;justify-content:flex-end;flex-wrap:nowrap;margin-left:auto}.profile-redeem-form{flex-direction:column;align-items:stretch}.profile-code-row{align-items:flex-start}.profile-features{justify-content:flex-start;width:100%}.profile-date{width:100%}.special-grid{grid-template-columns:1fr}.special-control{grid-template-columns:auto 1fr;grid-auto-rows:auto}.special-control input[type=number]{width:100%}.welcome-page{padding:16px}.welcome-card{padding:20px}}.profile-remove-button:disabled{opacity:.6;cursor:not-allowed}.profile-empty{color:#9aa4b5;font-size:.9rem}.welcome-page{min-height:100vh;padding:24px;background:#0f1115;color:#f5f5f5;display:flex;justify-content:center;align-items:flex-start}.welcome-card{width:100%;max-width:560px;background:#161a21;border:1px solid #222834;border-radius:16px;padding:28px;box-shadow:0 20px 40px #0006;display:flex;flex-direction:column;gap:16px}.welcome-kicker{text-transform:uppercase;letter-spacing:.2em;font-size:.7rem;color:#8aa4ff}.welcome-card h1{margin:0;font-size:clamp(1.6rem,3vw,2rem)}.welcome-subtitle{margin:0;color:#b4bdcc;line-height:1.6}.welcome-actions{display:flex;flex-direction:column;gap:12px}.welcome-button{text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border-radius:10px;border:1px solid #2f3542;background:#232833;color:#cfd6e4;font-weight:700}.welcome-button.primary{background:linear-gradient(135deg,#2f6bc9,#2456a6);border-color:#2456a6;color:#fff}.welcome-button.success{background:linear-gradient(135deg,#2b8a3e,#1f6b2f);border-color:#1f6b2f;color:#fff}.welcome-link{color:#9aa4b5;text-decoration:none;font-weight:600}.welcome-link:hover{text-decoration:underline}.gallery-header{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:24px;flex-wrap:wrap}.gallery-header-main{display:flex;flex-direction:column;gap:6px}.gallery-kicker{font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:#7a889d;font-weight:700}.gallery-title{margin:0;font-size:clamp(1.7rem,3vw,2.4rem)}.gallery-subtitle{margin:0;color:#55627a;max-width:420px}.gallery-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.gallery-button{border:none;padding:10px 14px;border-radius:10px;cursor:pointer;font-weight:700;background:#0f172a;color:#fff;min-width:130px;justify-content:center;display:inline-flex}.gallery-button.secondary{background:#e7eef8;color:#1f2a3d;border:1px solid #c9d5e6}.gallery-link{text-decoration:none;padding:10px 14px;border-radius:10px;border:1px solid #c9d5e6;background:linear-gradient(135deg,#2f6bc9,#2456a6);color:#fff;font-weight:700;min-width:130px;justify-content:center;display:inline-flex}.gallery-error{color:#b42318;background:#ffe6e1;border:1px solid #f3b1a6;padding:10px 12px;border-radius:10px;margin-bottom:16px}.gallery-feed{display:flex;flex-direction:column;gap:16px;max-width:560px;margin:0 auto}.gallery-post{background:#fff;border:1px solid #d8e1ee;border-radius:14px;overflow:hidden;box-shadow:0 10px 20px #1f27331a;display:flex;flex-direction:column}.gallery-post-image{width:100%;aspect-ratio:1 / 1;background:#edf2f8;display:flex;align-items:center;justify-content:center}.gallery-post-image img{width:100%;height:100%;object-fit:cover;display:block}.gallery-post-meta{padding:10px 12px 12px;display:flex;flex-direction:column;align-items:stretch;gap:8px}.gallery-post-title{font-weight:700;color:#1a2433}.gallery-post-date{font-size:.85rem;color:#7a879c}.gallery-post-actions{display:grid;grid-template-columns:1fr 1fr 1fr;align-items:center;gap:8px;width:100%}.gallery-post-divider{height:1px;background:#e5eaf2;width:100%}.gallery-post-info{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%}.gallery-like-group{display:inline-flex;align-items:center;gap:8px;justify-self:start}.gallery-like-btn{width:34px;height:34px;border-radius:999px;border:1px solid #d7dee8;background:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;color:#c0c7d4}.gallery-like-btn:before{content:"♥";font-size:16px;line-height:1}.gallery-like-btn.liked{color:#e94b4b;border-color:#ffb3b3;background:#fff3f3}.gallery-like-count{font-weight:700;color:#2a2f3b}.gallery-action{border:none;background:transparent;color:#2a2f3b;padding:4px 0;font-weight:700;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px}.gallery-action-icon{width:20px;height:20px}.gallery-action:hover{color:#111827}.gallery-action.disabled{opacity:.4;cursor:not-allowed}.gallery-action.disabled:hover{color:#2a2f3b}.gallery-empty{text-align:center;color:#7a879c;padding:24px 0}@media(max-width:768px){.gallery-page{padding:20px 16px 48px}.gallery-header{gap:12px}.gallery-actions{width:100%;justify-content:flex-start}.gallery-button,.gallery-link{flex:1 1 auto;justify-content:center;text-align:center}.gallery-feed{gap:14px}}.download-toast{position:fixed;right:20px;bottom:20px;max-width:380px;background:#121212f2;color:#f7f7f7;padding:16px 18px;border-radius:12px;box-shadow:0 18px 40px #00000073;border:1px solid rgba(255,255,255,.08);display:flex;gap:12px;align-items:flex-start;z-index:120}.download-toast-message{line-height:1.5;font-weight:600}.download-toast-close{background:transparent;border:1px solid rgba(255,255,255,.35);color:#f7f7f7;padding:4px 10px;border-radius:6px;cursor:pointer;font-weight:700;line-height:1}.download-toast-close:hover{background:#ffffff1a}.dashboard{padding:24px;color:#f5f5f5;min-height:100vh;background:#0f1115;display:flex;flex-direction:column;gap:16px}.dashboard-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.dashboard-button{background:linear-gradient(135deg,var(--primary-start),var(--primary-end));color:#fff;border:none;padding:10px 16px;border-radius:6px;cursor:pointer;font-weight:700}.dashboard-button.danger{background:#e53935}.dashboard-table{display:grid;gap:8px}.dashboard-row{display:grid;grid-template-columns:80px 170px 140px 1fr 1.6fr;gap:12px;padding:12px;background:#161a21;border:1px solid #222834;border-radius:10px}.dashboard-row.codes-row{grid-template-columns:80px 180px 1fr 1fr 140px 110px 140px}.dashboard-row--head{background:transparent;border:none;font-weight:700;text-transform:uppercase;font-size:.8rem;letter-spacing:.04em}.dashboard-subtitle{margin:4px 0 0;color:#bbb}.dashboard-card{background:#161a21;border:1px solid #222834;border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:10px}.dashboard-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.dashboard-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.status-badge{padding:4px 8px;border-radius:999px;font-size:.8rem;font-weight:700}.status-badge.ok{background:#1b3a24;color:#7be795;border:1px solid #2e5d3a}.status-badge.error{background:#3a1b1b;color:#ff9b9b;border:1px solid #5d2e2e}.meta-line{color:#cfd6df;font-size:.95rem}.issue-list{margin:8px 0 0;padding-left:18px;max-height:180px;overflow:auto}.issue-list li{color:#ffb3b3}.success-text{color:#9de08a;margin-top:6px}.validator-details{margin-top:10px;background:#11151c;border:1px solid #222a33;border-radius:8px;padding:8px 10px}.validator-details summary{cursor:pointer;font-weight:600}.validator-pre{margin-top:8px;max-height:240px;overflow:auto;background:#0b0f15;border:1px solid #1b2230;padding:10px;border-radius:6px;color:#cdd5e0;font-size:12px;white-space:pre-wrap;word-break:break-word}.validator-inputs{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.validator-input label{color:#cdd6df;font-weight:600;margin-bottom:6px;display:block}.validator-input textarea{width:100%;min-height:160px;background:#0b0f15;color:#cdd6df;border:1px solid #1b2230;border-radius:8px;padding:10px;font-family:monospace;resize:vertical}.validator-input input{width:100%;background:#0b0f15;color:#cdd6df;border:1px solid #1b2230;border-radius:8px;padding:10px}.validator-chips{display:flex;flex-direction:column;gap:14px;margin-top:12px}.chip-section{display:flex;flex-direction:column;gap:8px}.chip-title{font-weight:700;color:#e5eaf2}.chip-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px}.chip{display:flex;flex-direction:column;gap:4px;background:#10141d;border:1px solid #222a33;border-radius:10px;padding:10px;color:#dfe5f0}.chip.muted{opacity:.7}.chip small{color:#9aa4b5;font-size:11px}.chip-subparts{display:flex;flex-direction:column;gap:2px;border-top:1px solid #1f2632;padding-top:6px}.validator-summary{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}.summary-chip{background:#11141d;border:1px solid #222a33;border-radius:10px;padding:10px 12px;min-width:110px;display:flex;flex-direction:column;gap:4px;color:#dfe5f0}.summary-value{font-size:1.1rem;font-weight:800}.summary-label{font-size:.9rem;color:#9aa4b5}.config-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px;margin-top:12px}.config-card{background:#161a21;border:1px solid #222834;border-radius:12px;padding:14px;color:#f5f5f5;display:flex;flex-direction:column;gap:8px;box-shadow:0 12px 30px #0000004d}.config-preview{width:100%;height:120px;border-radius:10px;overflow:hidden;background:#0f1115;border:1px solid #222834;display:flex;align-items:center;justify-content:center}.config-preview img{width:100%;height:100%;object-fit:cover;display:block}.config-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.config-card-meta{display:flex;flex-direction:column;gap:4px}.config-id{font-weight:800;color:#7bb8ff}.config-name{font-weight:700;color:#f5f5f5}.config-date,.config-ip{font-size:.9rem;color:#c1c7d1}.config-ua{font-size:.9rem;color:#b0b6c3;word-break:break-word}.config-actions{display:flex;gap:6px}.config-toggle{background:#2a2f3b;color:#f5f5f5;border:1px solid #39404f;padding:8px 10px;border-radius:8px;cursor:pointer;font-weight:700}.config-toggle:hover{background:#323949}.config-json{background:#0f1115;border:1px solid #222834;border-radius:10px;padding:10px;font-size:.85rem;max-height:320px;overflow:auto}.config-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-bottom:12px}.config-stat-card{background:#161a21;border:1px solid #222834;border-radius:12px;padding:12px;color:#f5f5f5;display:flex;flex-direction:column;gap:8px}.config-stat-title{font-size:.95rem;color:#c1c7d1;text-transform:uppercase;letter-spacing:.02em}.config-stat-value{font-size:1.8rem;font-weight:800;color:#7bb8ff}.config-stat-list{display:flex;flex-direction:column;gap:6px}.config-stat-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;background:#0f1115;border:1px solid #222834;border-radius:8px;padding:6px 8px}.config-stat-label{color:#f5f5f5;font-weight:600}.config-stat-count{color:#c1c7d1;font-weight:600}.config-stat-empty{color:#9aa0ad;font-size:.9rem}.config-color-swatch{width:16px;height:16px;border-radius:4px;border:1px solid #444;display:inline-block}.dashboard-json pre{margin:0;font-size:.85rem;line-height:1.3;white-space:pre-wrap;word-break:break-word}.dashboard-ua{max-height:48px;overflow:hidden}.config-cards{margin-top:12px}.dashboard-error{color:#ff8a65;background:#2a1a14;border:1px solid #ff8a65;padding:10px 12px;border-radius:8px}.dashboard-empty{padding:12px;color:#b0b6c3}.backoffice-menu{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}.backoffice-card{display:block;padding:18px;background:#161a21;border:1px solid #222834;border-radius:12px;color:#f5f5f5;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease}.backoffice-card:hover{transform:translateY(-3px);box-shadow:0 12px 30px #00000059}.invite-form{display:flex;gap:10px;flex-wrap:wrap}.invite-form input{padding:10px 12px;border-radius:6px;border:1px solid #333a47;background:#0c0f14;color:#f5f5f5}.invite-form button{padding:10px 14px;border-radius:6px;border:none;cursor:pointer;background:#4caf50;color:#fff;font-weight:700}.login-gate{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 10% 15%,rgba(246,211,101,.18),transparent 40%),radial-gradient(circle at 90% 10%,rgba(98,216,177,.18),transparent 45%),radial-gradient(circle at 80% 80%,rgba(95,167,255,.14),transparent 50%),#0d0f14;padding:20px;font-family:Space Grotesk,Manrope,sans-serif}.login-card{background:linear-gradient(180deg,#15181ef5,#0d0f14fa) padding-box,linear-gradient(120deg,#f6d365,#5ed39f 42%,#5fa7ff) border-box;border:1px solid transparent;border-radius:22px;padding:32px 32px 26px;max-width:460px;width:100%;color:#f5f5f5;box-shadow:0 30px 70px #00000073;position:relative;overflow:visible;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.login-header{display:flex;flex-direction:column;gap:10px}.login-title-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.login-title-text{display:flex;flex-direction:column;gap:6px}.login-logo{display:flex;align-items:center;justify-content:center}.login-logo img{width:140px;max-width:45vw;height:auto;display:block}.login-kicker{text-transform:uppercase;letter-spacing:.24em;font-size:.62rem;color:#9aa7b3;font-weight:700}.login-header h1{margin:0;font-size:1.6rem;letter-spacing:-.02em}.login-subtitle{margin:0;color:#bcc5d4;font-size:.95rem;line-height:1.5}.login-subtitle-sparkle{display:inline-block;margin-left:6px;white-space:nowrap}.login-tabs{display:flex;gap:18px;margin-top:6px;border-bottom:1px solid rgba(255,255,255,.08)}.login-tab{background:none;border:none;color:#9aa8bd;cursor:pointer;padding:10px 0 12px;font-weight:700;transition:color .15s ease;position:relative}.login-tab.active{color:#fff}.login-tab.active:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;border-radius:999px;background:linear-gradient(90deg,#f6d365,#5ed39f 45%,#5fa7ff)}.login-providers{margin-top:16px;display:flex;flex-direction:column;gap:12px}.login-google{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 14px;border-radius:12px;border:1px solid #d8dde7;background:#fff;color:#1a1a1a;font-weight:700;text-decoration:none;box-shadow:0 16px 30px #0003}.login-google-icon{width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:800;color:#1a1a1a;background:conic-gradient(#ea4335 0deg 90deg,#fbbc05 90deg 180deg,#34a853 180deg 270deg,#4285f4 270deg 360deg);box-shadow:inset 0 0 0 2px #fff}.login-divider{display:flex;align-items:center;gap:8px;color:#7f8a9c;font-size:.85rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#2a3240}.login-divider span{text-transform:uppercase;letter-spacing:.2em;font-size:.6rem}.login-form{display:flex;flex-direction:column;gap:12px;margin-top:16px}.login-input{width:100%;padding:12px 14px;border-radius:12px;border:1px solid #2b3342;background:#0b1018;color:#f5f5f5;transition:border .15s ease,box-shadow .15s ease}.login-input:focus{outline:none;border-color:#3a4a63;box-shadow:0 0 0 3px #5a95ff33}.login-button{width:100%;padding:12px 16px;border-radius:12px;border:none;cursor:pointer;background:linear-gradient(135deg,var(--primary-start),var(--primary-end));color:#fff;font-weight:700;box-shadow:0 10px 22px #1f7a3840}.login-error{margin-top:10px;color:#ff8a65}.login-success{margin-top:10px;color:#8fd18a}.login-links{margin-top:16px;display:flex;flex-direction:column;gap:8px}.login-link{background:none;border:none;cursor:pointer;padding:0;text-decoration:none;position:relative;margin:0;color:#bcc5d4;font-size:.95rem;line-height:1.5}.login-link:after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;background:currentColor;opacity:.6}@media(max-width:640px){.login-gate{padding:16px}.login-card{max-width:100%;padding:24px 20px 20px;border-radius:18px}.login-header h1{font-size:1.35rem}.login-tabs{gap:12px}.login-google{padding:10px 12px;font-size:.95rem}.login-title-row{flex-direction:column;align-items:flex-start}.login-logo{align-self:flex-end}.login-logo img{width:120px}}.story-modal-backdrop{position:fixed;inset:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:120;padding:16px}.story-modal{background:#161a21;color:#f5f5f5;padding:24px;border-radius:12px;max-width:520px;width:100%;box-shadow:0 20px 50px #0000008c;border:1px solid #222834;display:flex;flex-direction:column;gap:12px;line-height:1.6}.story-modal h2{margin:0}.story-actions{display:flex;justify-content:flex-end}.story-close-btn{background:linear-gradient(135deg,var(--primary-start),var(--primary-end));color:#f5f5f5;border:1px solid #1f7a38;padding:10px 14px;border-radius:8px;cursor:pointer;font-weight:700}@media(max-width:768px){.catalog-container{position:absolute;top:0;right:0;width:0;max-width:0;transform:translate(100%);border-left:1px solid #444;box-shadow:-2px 0 10px #00000080;z-index:25}.catalog-container.open{width:80%;max-width:300px;transform:translate(0)}.catalog-toggle{display:block}.download-toast{right:12px;left:12px;max-width:unset}.floating-download{bottom:clamp(12px,2.6vh,36px);right:16px;z-index:70}.random-fab{bottom:clamp(12px,2.6vh,36px);left:16px}.dashboard{padding:16px}.dashboard-row{grid-template-columns:1fr}.dashboard-row--head{display:none}.backoffice-menu{grid-template-columns:1fr}.header{flex-wrap:nowrap;gap:8px}.header-spacer{display:none}.header-title{width:auto;flex:1 1 auto;white-space:nowrap}.header{padding:10px 12px}.footer-bar{padding:8px 12px;font-size:.8rem;flex-direction:column;align-items:flex-start;gap:8px}.footer-left,.footer-right{gap:8px}.footer-right{width:100%;justify-content:flex-end}.header-right{width:auto;min-width:0;align-items:center}.header-actions{width:auto}.controls-overlay.catalog-open{display:none}}body.theme-light{color-scheme:light;--primary-start: #3a7bd5;--primary-end: #4fa3ff;--light-bg: #f3f5f9;--light-surface: #ffffff;--light-surface-2: #f6f8fc;--light-surface-3: #eef2f7;--light-border: #d7dee8;--light-border-2: #c7d0dd;--light-text: #1f2733;--light-text-muted: #5c6778;--light-text-soft: #7b8798;--choice-bg: #e6f1ff;--choice-border: #bcd4f5;--choice-text: #1f2733;--choice-dot-border: #1f2733;--choice-bg-selected: #2f6fbf;--choice-border-selected: #2f6fbf;--choice-text-selected: #ffffff;--choice-dot-border-selected: #ffffff;background:var(--light-bg);color:var(--light-text)}body.theme-light .app-container{background:transparent}body.theme-light .scene-container{--bg-0: #f7f9fc;--bg-1: #f0f4f8;--bg-2: #e6ecf4;background:radial-gradient(1200px 500px at 50% -10%,#ffffffe6,#ffffff26 40%,#fff0 70%),radial-gradient(900px 700px at 50% 45%,#dce1eb99,#dce1eb14 45%,#fff0 70%),radial-gradient(1400px 900px at 55% 35%,#b4c3dc59,#b4c3dc14 45%,#fff0 75%),linear-gradient(180deg,var(--bg-2) 0%,var(--bg-1) 40%,var(--bg-0) 100%)}body.theme-light .profile-page{background:var(--light-bg)}body.theme-light .profile-crown,body.theme-light .header-crown{background:var(--light-surface);border-color:var(--light-border);box-shadow:0 6px 16px #1f273326}body.theme-light .profile-crown svg path,body.theme-light .header-crown svg path{fill:#f0b03f}body.theme-light .profile-avatar{background:var(--light-surface-2);border-color:var(--light-border);color:var(--light-text)}body.theme-light .header,body.theme-light .footer-bar{background:var(--light-surface);color:var(--light-text);border-color:var(--light-border)}body.theme-light .keychain-progress{background:var(--light-surface-2);color:var(--light-text);border-color:var(--light-border)}body.theme-light .header-counter,body.theme-light .header-remaining,body.theme-light .catalog-group-hint,body.theme-light .profile-hint,body.theme-light .profile-subtitle,body.theme-light .login-subtitle,body.theme-light .login-kicker,body.theme-light .login-divider span,body.theme-light .welcome-subtitle,body.theme-light .profile-empty,body.theme-light .special-label,body.theme-light .special-hint,body.theme-light .scale-hint,body.theme-light .text-color-row{color:var(--light-text-muted)}body.theme-light .header-action-link{background:var(--light-surface-2);border-color:var(--light-border);color:var(--light-text)}body.theme-light .header-action-link:hover{background:var(--light-surface-3)}body.theme-light .profile-home{background:linear-gradient(135deg,var(--primary-start),var(--primary-end));border:none;color:#fff}body.theme-light .profile-home:hover{filter:brightness(1.03)}body.theme-light .profile-code{color:var(--light-text)}body.theme-light .profile-code small,body.theme-light .code-status{color:var(--light-text-soft)}body.theme-light .profile-error-backdrop{background:#e6ebf5b3}body.theme-light .profile-error-modal{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text);box-shadow:0 18px 36px #1f27332e}body.theme-light .profile-error-modal p{color:var(--light-text-muted)}body.theme-light .catalog-container{background:var(--light-surface-2);border-left-color:var(--light-border)}body.theme-light .catalog-wrapper{color:var(--light-text)}body.theme-light .catalog-tabs{background:#eaf2ff;border-color:#cfe1ff}body.theme-light .catalog-tab{background:#eaf2ff;color:#2f6fbf}body.theme-light .catalog-tab.active{background:#d9eaff;color:#1f5ea8;box-shadow:inset 0 0 0 1px #2f6fbf4d}body.theme-light .catalog-segmented{background:#eef5ff;border-color:#cfe1ff}body.theme-light .catalog-segmented-btn{color:#2f6fbf}body.theme-light .catalog-segmented-btn.active{background:#dbeaff;color:#1f5ea8;box-shadow:inset 0 0 0 1px #2f6fbf47}body.theme-light .catalog-top-button{background:transparent;border-color:transparent;box-shadow:none}body.theme-light .catalog-sticky-tabs{background:#eef5ff;border-color:#cfe1ff}body.theme-light .catalog-sticky-tab{color:#2f6fbf}body.theme-light .catalog-sticky-tab.active{background:#dbeaff;color:#1f5ea8;box-shadow:inset 0 0 0 1px #2f6fbf47}body.theme-light .catalog-panel,body.theme-light .catalog-group,body.theme-light .segment-card,body.theme-light .segment-card-body,body.theme-light .profile-card,body.theme-light .welcome-card,body.theme-light .login-card,body.theme-light .terms-card,body.theme-light .gallery-card,body.theme-light .dashboard-card,body.theme-light .config-card,body.theme-light .backoffice-card{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text);box-shadow:0 18px 35px #1f273314}body.theme-light .segment-card-body{border-top-color:var(--light-border)}body.theme-light .segment-card-title,body.theme-light .catalog-group-title,body.theme-light .catalog-panel-header,body.theme-light .profile-label,body.theme-light .login-title-text,body.theme-light .welcome-card h1{color:var(--light-text)}body.theme-light .welcome-page{background:var(--light-bg);color:var(--light-text)}body.theme-light .welcome-kicker{color:#2f6bc9}body.theme-light .welcome-button{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text)}body.theme-light .welcome-button.success{background:linear-gradient(135deg,#2b8a3e,#1f6b2f);border-color:#1f6b2f;color:#fff}body.theme-light .welcome-button.primary{background:linear-gradient(135deg,#2f6bc9,#2456a6);border-color:#2456a6;color:#fff}body.theme-light .catalog-panel-header{background:#eef2f7;border-bottom:1px solid var(--light-border)}body.theme-light .catalog-panel-header .caret,body.theme-light .segment-caret{border-color:var(--light-text)}body.theme-light .catalog-dropdown,body.theme-light .special-select,body.theme-light .name-inline input,body.theme-light .text-gen-controls input,body.theme-light .save-share-name input,body.theme-light .save-share-link input,body.theme-light .profile-input,body.theme-light .login-input,body.theme-light .dashboard-card input,body.theme-light .dashboard-card select,body.theme-light .body-control input[type=color],body.theme-light .body-control select{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text)}body.theme-light .body-control,body.theme-light .save-share-name,body.theme-light .save-share-visibility{color:var(--light-text)}body.theme-light .save-share-visibility select,body.theme-light .save-share-link button{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text)}body.theme-light .gallery-page{background:var(--light-bg);color:var(--light-text)}body.theme-light .gallery-title,body.theme-light .gallery-post-title{color:var(--light-text)}body.theme-light .gallery-post-date,body.theme-light .gallery-empty,body.theme-light .gallery-subtitle{color:var(--light-muted)}body.theme-light .gallery-button.secondary,body.theme-light .gallery-link{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text)}body.theme-light .gallery-link.primary{background:linear-gradient(135deg,#2f6bc9,#2456a6);border-color:#2456a6;color:#fff}body.theme-light .gallery-post{background:var(--light-surface);border-color:var(--light-border)}body.theme-light .name-inline label{color:var(--light-text)}body.theme-light .color-grid-trigger{background:var(--light-surface);border-color:var(--light-border)}body.theme-light .color-grid-picker.open .color-grid-trigger{border-color:#3a7bd573;box-shadow:0 0 0 2px #3a7bd52e}body.theme-light .color-grid-panel{background:var(--light-surface);border-color:var(--light-border);box-shadow:0 12px 24px #1f27331f}body.theme-light .color-grid-input{background:var(--light-surface-2);border-color:var(--light-border);color:var(--light-text)}body.theme-light .color-grid-label{color:var(--light-text)}body.theme-light .color-swatch-picker{background:var(--light-surface-2);border-color:var(--light-border);color:var(--light-text)}body.theme-light .catalog-choice>button{color:#fff}body.theme-light .choice-color-label{background:#eef2f7;border-color:var(--light-border);color:var(--light-text)}body.theme-light .scale-preset{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text)}body.theme-light .scale-preset small{color:var(--light-text-soft)}body.theme-light .scale-preset.active{background:#e0eeff;border-color:#9bbef6;box-shadow:0 0 0 2px #2f6fbf33}body.theme-light .scale-custom{background:var(--light-surface-2);border-color:var(--light-border)}body.theme-light .scale-custom-label{color:var(--light-text)}body.theme-light .scale-input{background:var(--light-surface);border-color:var(--light-border)}body.theme-light .scale-input input{color:var(--light-text)}body.theme-light .scale-unit{color:var(--light-text-soft)}body.theme-light .special-toggle,body.theme-light .special-toggle-group label{color:var(--light-text)}body.theme-light .profile-remove-button{background:#f2f4f7;border-color:#d6dce5;color:#7a8796}body.theme-light .profile-remove-button:hover{background:#e9edf2;color:#5f6b7a}body.theme-light .special-control{background:var(--light-surface-2);border-color:var(--light-border)}body.theme-light .special-control input[type=number],body.theme-light .special-control input[type=range]{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text)}body.theme-light .catalog-clear{background:var(--light-surface-2);border-color:var(--light-border);color:#b94b4b}body.theme-light .catalog-clear:hover{background:var(--light-surface-3)}body.theme-light .segment-card{border-color:var(--light-border)}body.theme-light .profile-code-row{background:var(--light-surface-2);border-color:var(--light-border)}body.theme-light .feature-chip{background:var(--light-surface-3);border-color:var(--light-border);color:var(--light-text-soft)}body.theme-light .feature-chip.enabled{background:#f0f2f5;border-color:#cdd6df;color:#5f6b7a}body.theme-light .download-dropdown,body.theme-light .download-menu{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text)}body.theme-light .download-menu button{color:var(--light-text)}body.theme-light .download-menu button:hover{background:var(--light-surface-2)}body.theme-light .login-gate{background:radial-gradient(circle at 10% 15%,rgba(246,211,101,.25),transparent 45%),radial-gradient(circle at 90% 10%,rgba(98,216,177,.22),transparent 50%),radial-gradient(circle at 80% 80%,rgba(95,167,255,.2),transparent 55%),var(--light-bg)}body.theme-light .login-card{background:var(--light-surface);border:1px solid var(--light-border);color:var(--light-text);box-shadow:0 20px 40px #1f27331f}body.theme-light .login-tabs{border-color:var(--light-border)}body.theme-light .login-tab{color:var(--light-text-soft)}body.theme-light .login-tab.active{color:var(--light-text)}body.theme-light .login-google{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text)}body.theme-light .login-divider:before,body.theme-light .login-divider:after{background:var(--light-border)}body.theme-light .login-link{color:var(--light-text-muted)}body.theme-light .login-link:hover{color:var(--light-text)}body.theme-light .download-toast{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text)}body.theme-light .dashboard{background:var(--light-bg);color:var(--light-text)}body.theme-light .dashboard-subtitle{color:var(--light-text-muted)}body.theme-light .dashboard-table{color:var(--light-text)}body.theme-light .dashboard-row{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text)}body.theme-light .dashboard-row--head{color:var(--light-text-soft)}body.theme-light .dashboard-error{background:#fdecec;border-color:#f2b8b8;color:#a03434}body.theme-light .dashboard-empty{color:var(--light-text-soft)}body.theme-light .backoffice-card{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text)}body.theme-light .dashboard-header h1,body.theme-light .dashboard-meta,body.theme-light .dashboard-actions{color:var(--light-text)}body.theme-light .dashboard-button{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text)}body.theme-light .dashboard-button:hover{background:var(--light-surface-2)}body.theme-light .dashboard-button.danger{background:#f3d6d6;border-color:#e3b3b3;color:#8a2d2d}body.theme-light .config-id{color:#2f69b0}body.theme-light .config-name{color:var(--light-text)}body.theme-light .config-preview{background:var(--light-surface-2);border-color:var(--light-border)}body.theme-light .config-date,body.theme-light .config-ip,body.theme-light .config-ua,body.theme-light .config-stat-title,body.theme-light .config-stat-count,body.theme-light .config-stat-empty{color:var(--light-text-soft)}body.theme-light .config-toggle{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text)}body.theme-light .config-toggle:hover{background:var(--light-surface-2)}body.theme-light .config-json,body.theme-light .config-stat-row{background:var(--light-surface-2);border-color:var(--light-border);color:var(--light-text)}body.theme-light .config-stat-card{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text)}body.theme-light .config-stat-value,body.theme-light .config-stat-label,body.theme-light .meta-line{color:var(--light-text)}body.theme-light .issue-list li{color:#b04a4a}body.theme-light .validator-details{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text)}body.theme-light .validator-details summary{color:var(--light-text)}body.theme-light .validator-pre{background:var(--light-surface-2);border-color:var(--light-border);color:var(--light-text)}body.theme-light .chip{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text)}body.theme-light .chip-title{color:var(--light-text)}body.theme-light .chip small{color:var(--light-text-soft)}body.theme-light .chip-subparts{border-top-color:var(--light-border)}body.theme-light .summary-chip{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text)}body.theme-light .backoffice-card:hover{box-shadow:0 12px 26px #1f27331f}body.theme-light .invite-form input{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text)}body.theme-light .status-badge.ok{background:#e9f6ef;border-color:#b5e0c6;color:#2f6b44}body.theme-light .status-badge.error{background:#fdecec;border-color:#f2b8b8;color:#a03434}body.theme-light .download-toast-close{background:#eef2f7;border-color:#cdd6df;color:#5f6b7a}body.theme-light .download-toast-close:hover{background:#e2e8f0}body.theme-light .name-modal{background:var(--light-surface);border-color:var(--light-border);color:var(--light-text);box-shadow:0 18px 36px #1f273329}body.theme-light .name-modal h2{color:var(--light-text)}body.theme-light .name-modal input{background:var(--light-surface-2);border-color:var(--light-border);color:var(--light-text)}body.theme-light .name-modal-backdrop{background:#e6ebf5b3}body.theme-light .quick-actions{background:#ffffffd9;border-color:var(--light-border)}body.theme-light .random-btn{box-shadow:0 6px 16px #1f27332e}body.theme-light .random-fab{background:transparent;color:var(--light-text);border-color:transparent;box-shadow:none}body.theme-light .random-fab:disabled{opacity:.5}body.theme-light .export-loading{background:var(--light-surface);border:1px solid var(--light-border);padding:6px 10px;border-radius:10px}body.theme-light .catalog-toggle{background:var(--light-surface);color:var(--light-text);border-color:var(--light-border);box-shadow:0 6px 18px #1f27331f}body.theme-light .catalog-toggle:hover{background:var(--light-surface-2)}body.theme-light .undo-button,body.theme-light .redo-button{background:transparent;color:var(--light-text);border-color:transparent;box-shadow:none}body.theme-light .export-loading{color:var(--light-text)}body.theme-light .export-spinner{border-color:#1f273333;border-top-color:var(--primary-start)}
