@font-face{font-family:PP Fragment;src:url(/assets/fonts/PPFragment-SansLight.otf) format("opentype");font-weight:300;font-style:normal;font-display:swap}@font-face{font-family:PP Fragment;src:url(/assets/fonts/PPFragment-SansRegular.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:PP Fragment;src:url(/assets/fonts/PPFragment-SansExtraBold.otf) format("opentype");font-weight:800;font-style:normal;font-display:swap}@font-face{font-family:PP Fragment Glare;src:url(/assets/fonts/PPFragment-GlareLight.otf) format("opentype");font-weight:300;font-style:normal;font-display:swap}@font-face{font-family:PP Fragment Glare;src:url(/assets/fonts/PPFragment-GlareRegular.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:PP Fragment Glare;src:url(/assets/fonts/PPFragment-GlareExtraBold.otf) format("opentype");font-weight:800;font-style:normal;font-display:swap}@font-face{font-family:SVN Le Beaune New;src:url(/assets/fonts/SVN-Le-Beaune-New.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Libre Franklin;src:url(/assets/fonts/LibreFranklin-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Libre Franklin;src:url(/assets/fonts/LibreFranklin-Medium.ttf) format("truetype");font-weight:500;font-style:normal;font-display:swap}:root{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--bg-panel: rgba(255, 255, 255, .95);--bg-glass: rgba(255, 255, 255, .85);--clr-navy: #263c48;--clr-navy-dark: #1a2c36;--clr-gold: #d4a853;--clr-gold-bright: #f0c46b;--clr-red: #e74c3c;--clr-accent: var(--clr-gold);--clr-accent-glow: rgba(212, 168, 83, .2);--gold: var(--clr-gold);--clr-primary: var(--clr-gold);--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--text-on-dark: #f8fafc;--border: #e2e8f0;--border-hover: #cbd5e1;--border-active: #d4a853;--shadow: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--glow-gold: 0 0 0 2px rgba(212, 168, 83, .2);--glow-accent: 0 0 15px rgba(212, 168, 83, .2);--font-display: "PP Fragment Glare", serif;--font-body: "PP Fragment", sans-serif;--header-h: 64px;--sidebar-w: 260px;--radius: 8px;--radius-sm: 4px;--radius-lg: 12px;--ease: cubic-bezier(.4, 0, .2, 1);--duration: .2s}:root:lang(vi),[lang=vi]{--font-display: "SVN Le Beaune New", serif;--font-body: "Libre Franklin", sans-serif}[lang=vi]{font-family:var(--font-body)}[lang=vi] h1,[lang=vi] h2,[lang=vi] h3,[lang=vi] .terms-title,[lang=vi] .loading-title,[lang=vi] .app-title,[lang=vi] .terms-intro-title,[lang=vi] .terms-section-header h4,[lang=vi] .modal-header h2,[lang=vi] .leaderboard-title,[lang=vi] .gallery-section-title{font-family:var(--font-display);font-kerning:none;font-feature-settings:"liga" off}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}.icon{display:inline-block;vertical-align:middle;flex-shrink:0}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);overflow:hidden;height:100vh;width:100vw;line-height:1.5}.hidden{display:none!important}.grecaptcha-badge{z-index:9999!important}#app{height:100vh;display:flex;flex-direction:column;overflow:hidden}#loading-screen{position:fixed;inset:0;z-index:1000;background:var(--clr-navy-dark);display:flex;align-items:center;justify-content:center;animation:fadeOut .6s var(--ease) 2.5s forwards}.loading-content{text-align:center;color:var(--text-on-dark)}.loading-title{font-family:var(--font-display);font-size:3.5rem;color:var(--clr-gold);font-weight:700;letter-spacing:-.02em}.loading-subtitle{font-family:var(--font-body);font-size:1rem;color:#ffffffe6;margin-top:8px;text-transform:uppercase;letter-spacing:.2em;font-weight:500}.loading-bar{width:200px;height:2px;background:#ffffff1a;margin:40px auto 16px;overflow:hidden}.loading-fill{height:100%;background:var(--clr-gold);box-shadow:0 0 10px var(--clr-gold);animation:loadBar 2.2s var(--ease) forwards}.loading-hint{font-size:.85rem;color:#fff9}@keyframes loadBar{0%{width:0%}to{width:100%}}@keyframes fadeOut{to{opacity:0;pointer-events:none}}#app-header{height:var(--header-h);background:linear-gradient(135deg,var(--clr-navy) 0%,#2d4654 100%);border-bottom:none;display:flex;align-items:center;justify-content:flex-start;padding:0 28px;position:relative;z-index:400;flex-shrink:0;box-shadow:0 2px 12px #263c4826}#app-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,var(--clr-gold) 50%,transparent 100%);opacity:.4}.header-left{display:flex;align-items:center;min-width:0}.app-title{font-family:var(--font-display);font-size:1.35rem;color:var(--clr-gold);font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.header-logo{height:28px;width:auto;filter:brightness(0) invert(1);opacity:.9;flex-shrink:0}.header-right{position:absolute;right:28px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:8px;flex-shrink:0}.header-nav{display:flex;gap:24px;background:transparent;padding:0}.nav-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border:none;background:transparent;color:var(--text-secondary);font-family:var(--font-body);font-size:.9rem;font-weight:500;cursor:pointer;transition:all var(--duration) var(--ease);position:relative}.nav-btn:hover{color:var(--clr-gold);background:transparent}.nav-btn.active{background:transparent;color:var(--text-primary);font-weight:600;box-shadow:none}.nav-btn.active:after{content:"";position:absolute;bottom:-20px;left:0;width:100%;height:2px;background:var(--clr-gold)}.nav-icon{font-size:1rem}.icon-btn{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:var(--text-on-dark);cursor:pointer;font-size:1rem;transition:all var(--duration) var(--ease);display:flex;align-items:center;justify-content:center}.icon-btn:hover{border-color:var(--clr-gold);color:var(--clr-gold);background:#d4a8531a;box-shadow:0 0 8px #d4a85333}.mobile-only{display:none}.view{display:none;flex:1;min-height:0}.view.active{display:flex;background:var(--bg-primary)}.sidebar{width:var(--sidebar-w);background:var(--bg-panel);border-right:none;box-shadow:2px 0 12px #0000000a;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:8px;z-index:300;position:relative}.panel-section{background:var(--bg-secondary);border:none;border-radius:10px;padding:10px 12px;box-shadow:0 1px 4px #0000000a}.desktop-only{display:flex}.panel-title{font-family:var(--font-body);font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-weight:600;margin-bottom:8px;display:flex;align-items:center;gap:5px}.panel-title:before{content:"";width:3px;height:10px;background:var(--clr-gold);border-radius:2px;flex-shrink:0}.tool-grid{display:flex;gap:6px}.tool-btn{width:36px;height:36px;border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-secondary);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration) var(--ease)}.tool-btn svg{width:16px;height:16px}.tool-btn:hover{border-color:#d4a85366;color:var(--clr-gold);background:#d4a8530a;transform:scale(1.02)}.tool-btn.active{border-color:transparent;color:var(--clr-navy);background:linear-gradient(135deg,var(--clr-gold) 0%,#e0b96e 100%);font-weight:600;box-shadow:0 3px 10px #d4a85359}.slider-wrapper{display:flex;align-items:center;gap:8px}.slider{flex:1;-webkit-appearance:none;appearance:none;height:6px;background:linear-gradient(90deg,var(--bg-tertiary) 0%,rgba(212,168,83,.12) 100%);border-radius:3px;outline:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--clr-gold);cursor:pointer;border:2px solid #fff;box-shadow:0 1px 4px #0000001f;transition:transform .15s var(--ease),box-shadow .15s var(--ease)}.slider::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 2px 8px #d4a85359}.slider-value{font-size:.72rem;color:var(--text-secondary);min-width:28px;text-align:right;font-feature-settings:"tnum"}.cp-root{touch-action:none;user-select:none;-webkit-user-select:none;display:flex;flex-direction:column;align-items:center;gap:8px;padding:6px 0;width:100%;box-sizing:border-box}.cp-wheel-area{position:relative;width:100%;max-width:140px;aspect-ratio:1}.cp-compact .cp-wheel-area{width:100%;max-width:120px;aspect-ratio:1}.cp-compact .cp-hue-handle,.cp-compact .cp-sv-handle{width:12px;height:12px;border-width:2px}.cp-compact .cp-preview{width:22px;height:22px}.cp-compact .cp-hex-input{width:68px;font-size:12px;padding:3px 6px}.cp-compact .cp-hash{font-size:12px}.cp-hue-ring{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:50%;cursor:crosshair}.cp-sv-square{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:4px;cursor:crosshair;box-shadow:0 0 3px #0000004d;width:51.5%;height:51.5%}.cp-compact .cp-sv-square{width:48.67%;height:48.67%}.cp-hue-handle,.cp-sv-handle{position:absolute;width:14px;height:14px;border-radius:50%;border:2.5px solid #fff;box-shadow:0 0 3px #00000080,inset 0 0 2px #0003;transform:translate(-50%,-50%);pointer-events:none;z-index:2}.cp-controls{width:100%;display:flex;flex-direction:column;gap:6px}.cp-hex-row{display:flex;align-items:center;gap:4px;justify-content:center}.cp-preview{width:22px;height:22px;border-radius:50%;border:2px solid var(--border);flex-shrink:0}.cp-hash{font-size:12px;font-weight:600;color:var(--text-secondary, #666)}.cp-hex-input{width:68px;padding:3px 6px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:JetBrains Mono,Menlo,monospace;font-size:12px;text-transform:uppercase;background:var(--bg-white, #fff);color:var(--text-primary, #333);text-align:center}.cp-hex-input:focus{outline:2px solid var(--clr-gold);outline-offset:1px}.current-color-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding:6px 8px;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border)}.current-color-swatch{width:28px;height:28px;border-radius:6px;border:2px solid rgba(0,0,0,.1);flex-shrink:0;box-shadow:0 1px 3px #0000001a}.current-color-hex{font-family:JetBrains Mono,Menlo,monospace;font-size:.7rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;flex:1;min-width:0}.cp-toggle-btn{width:26px;height:26px;border:1px solid var(--border);border-radius:6px;background:var(--bg-secondary);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;flex-shrink:0}.cp-toggle-btn:hover{border-color:#d4a85366;color:var(--clr-gold)}.cp-toggle-btn.open{background:linear-gradient(135deg,var(--clr-gold) 0%,#e0b96e 100%);color:var(--clr-navy);border-color:transparent}.cp-toggle-btn svg{transition:transform .2s ease}.cp-toggle-btn:not(.open) svg{transform:rotate(180deg)}.cp-collapsible{overflow:hidden;margin-bottom:6px;padding-top:4px;animation:cpSlideDown .2s ease}@keyframes cpSlideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:300px}}.recent-colors-wrap{margin-bottom:8px;padding-top:6px;border-top:1px solid rgba(0,0,0,.04)}.recent-colors-label{font-size:.58rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600;margin-bottom:5px}.recent-colors{display:flex;flex-wrap:wrap;gap:3px}.recent-colors .recent-swatch{width:20px;height:20px;aspect-ratio:auto;border-radius:4px;flex-shrink:0}.color-palette{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;padding-top:6px;border-top:1px solid rgba(0,0,0,.04)}.color-swatch{aspect-ratio:1;border-radius:5px;border:1px solid rgba(0,0,0,.08);cursor:pointer;transition:transform .15s var(--ease),box-shadow .2s var(--ease)}.color-swatch:hover{transform:scale(1.15);box-shadow:0 2px 8px #d4a85333}.color-swatch.active{box-shadow:0 0 0 2px #fff,0 0 0 3.5px var(--clr-gold);z-index:1;transform:scale(1.05)}.color-swatch.transparent{background:#e2e8f0;position:relative}.color-swatch.transparent:after{content:"✕";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--text-muted)}.preset-btns{display:grid;grid-template-columns:1fr 1fr;gap:5px}.preset-btn{padding:5px 8px;font-size:.72rem;font-family:var(--font-body);font-weight:500;border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-secondary);border-radius:6px;cursor:pointer;transition:all var(--duration) var(--ease)}.preset-btn:hover{border-color:#d4a85366;color:var(--clr-gold);background:#d4a8530a}.preset-btn.active{border-color:transparent;color:var(--clr-navy);background:linear-gradient(135deg,var(--clr-gold) 0%,#e0b96e 100%);font-weight:600}.action-btns{display:flex;flex-direction:column;gap:6px}.action-btn{padding:8px 12px;font-family:var(--font-body);font-size:.78rem;font-weight:600;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:10px;transition:all var(--duration) var(--ease)}.action-btn:hover{border-color:#d4a8534d;background:var(--bg-tertiary);transform:translateY(-1px);box-shadow:0 2px 8px #0000000f}.action-btn.accent{background:linear-gradient(135deg,var(--clr-gold) 0%,#e0b96e 100%);border-color:transparent;color:var(--clr-navy);box-shadow:0 3px 10px #d4a8534d}.action-btn.accent:hover{background:linear-gradient(135deg,#e0b96e 0%,var(--clr-gold) 100%);transform:translateY(-1px);box-shadow:0 6px 16px #d4a85359}.action-btn.large{padding:10px;font-size:.85rem;border-radius:10px;justify-content:center}.action-btn .icon{width:16px;height:16px;flex-shrink:0}.canvas-area{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);position:relative;overflow:hidden;touch-action:none;padding:24px 24px 96px;box-sizing:border-box}.canvas-wrapper{position:relative;border-radius:16px;overflow:hidden;box-shadow:0 4px 24px #00000014,0 1px 4px #0000000a;border:1px solid rgba(212,168,83,.15);background-color:#fff;background-image:linear-gradient(45deg,#f1f5f9 25%,transparent 25%),linear-gradient(-45deg,#f1f5f9 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f1f5f9 75%),linear-gradient(-45deg,transparent 75%,#f1f5f9 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px}.canvas-wrapper.dark-bg{border-color:var(--text-muted);background-color:#1e293b;background-image:linear-gradient(45deg,#162032 25%,transparent 25%),linear-gradient(-45deg,#162032 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#162032 75%),linear-gradient(-45deg,transparent 75%,#162032 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px}.bg-toggle-row{display:flex;gap:5px}.bg-toggle-btn{flex:1;padding:5px;border-radius:6px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-muted);font-size:.72rem;cursor:pointer;transition:all .2s var(--ease)}.bg-toggle-btn:hover{border-color:#d4a85366;color:var(--clr-gold)}.bg-toggle-btn.active{background:linear-gradient(135deg,var(--clr-gold) 0%,#e0b96e 100%);color:var(--clr-navy);border-color:transparent}.canvas-wrapper canvas{display:block}.canvas-wrapper .canvas-container{position:relative!important}.canvas-floating-controls{position:fixed;bottom:56px;left:50%;transform:translate(calc(-50% + var(--sidebar-w, 260px) / 2));display:flex;align-items:center;justify-content:center;gap:6px;background:#ffffffeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:5px 12px;border-radius:24px;box-shadow:0 1px 8px #0000000f;border:1px solid rgba(0,0,0,.04);z-index:200;touch-action:auto}.mobile-footer{position:fixed;bottom:0;left:var(--sidebar-w, 260px);right:0;z-index:200;padding:8px 16px;padding-bottom:calc(8px + env(safe-area-inset-bottom,0px));background:#fffffff2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid rgba(0,0,0,.04);display:flex;justify-content:center;align-items:center}.mobile-submit-btn{padding:10px 32px;border:none;border-radius:24px;background:linear-gradient(135deg,var(--clr-gold) 0%,#e0b96e 100%);color:var(--clr-navy);font-size:.85rem;font-weight:700;cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:0 3px 12px #d4a8534d;display:inline-flex;align-items:center;justify-content:center;gap:6px;letter-spacing:.03em;text-transform:uppercase;line-height:1}.mobile-submit-btn .icon{width:14px;height:14px;flex-shrink:0;vertical-align:middle}.mobile-submit-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px #d4a85373}.mobile-submit-btn:active{transform:translateY(0)}.canvas-floating-controls button{touch-action:auto}.control-group{display:flex;align-items:center;gap:4px}.control-group+.control-group:before{content:"";width:1px;height:20px;background:#0000001a;margin:0 4px;flex-shrink:0}.float-btn{width:34px;height:34px;border-radius:8px;border:1px solid transparent;background:transparent;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s var(--ease);font-size:1rem}.float-btn:hover{background:#d4a85314;color:var(--clr-gold);transform:translateY(-1px)}.io-float-btn{width:auto;height:32px;padding:0 10px;gap:4px;border:1px solid var(--border);border-radius:7px;font-family:var(--font-body);font-size:.72rem;font-weight:600;white-space:nowrap}.io-float-btn svg{width:13px;height:13px;flex-shrink:0;opacity:.7}.float-btn:active{transform:translateY(1px)}.float-btn.active{background:var(--clr-gold);color:var(--clr-navy);border-color:var(--clr-gold)}.float-btn.accent-btn{width:auto;height:36px;padding:0 16px;border-radius:20px;background:linear-gradient(135deg,var(--clr-gold) 0%,#e0b96e 100%);color:var(--clr-navy);font-size:.85rem;font-weight:700;white-space:nowrap;border:none;gap:4px;letter-spacing:.02em;box-shadow:0 2px 8px #d4a85359}.float-btn.accent-btn:hover{background:linear-gradient(135deg,#e0b96e 0%,var(--clr-gold) 100%);color:var(--clr-navy);transform:translateY(-1px);box-shadow:0 4px 12px #d4a85373}.zoom-level{font-family:var(--font-body);font-size:.78rem;font-weight:600;color:var(--text-secondary);min-width:40px;text-align:center;font-feature-settings:"tnum"}.gallery-main{padding:24px 16px;max-width:1200px;margin:0 auto;overflow-y:auto;height:100%;background:var(--bg-primary)}.gallery-leaderboard{margin-bottom:40px}.leaderboard-title{font-family:var(--font-display);font-size:1.6rem;color:var(--text-primary);text-align:center;margin-bottom:20px;font-weight:700}.podium{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.podium-empty{grid-column:1 / -1;text-align:center;color:var(--text-muted);padding:32px;font-style:italic}.podium-card{background:var(--bg-secondary);border-radius:var(--radius-lg);overflow:hidden;border:2px solid var(--border);box-shadow:var(--shadow);transition:all .3s var(--ease)}.podium-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.podium-card.gold{border-color:#d4a853;box-shadow:0 4px 20px #d4a85340}.podium-card.silver{border-color:#a8b4c0;box-shadow:0 4px 16px #a8b4c040}.podium-card.bronze{border-color:#c4854a;box-shadow:0 4px 16px #c4854a33}.podium-media{position:relative;width:100%;aspect-ratio:2/1;background:#1a1a2e;overflow:hidden}.podium-img,.podium-video{width:100%;height:100%;object-fit:cover;display:block}.podium-medal{position:absolute;top:8px;left:8px;font-size:1.8rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5));z-index:2}.podium-info{padding:12px}.podium-title{font-size:1rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.podium-author{font-size:.8rem;color:var(--text-muted);margin-bottom:8px}.podium-actions{display:flex;align-items:center;gap:8px}.vote-btn,.share-btn{background:transparent;border:1px solid var(--border);color:var(--text-secondary);padding:4px 10px;border-radius:20px;cursor:pointer;font-size:.8rem;display:flex;align-items:center;gap:4px;transition:all .2s}.vote-btn:hover{border-color:#ef4444;color:#ef4444}.vote-btn.voted{background:#fef2f2;border-color:#ef4444;color:#ef4444}.share-btn:hover{border-color:var(--gold);color:var(--gold)}.vote-display{font-size:.85rem;color:var(--text-muted)}.gallery-header{margin-bottom:20px}.gallery-section-title{font-family:var(--font-display);font-size:1.4rem;color:var(--text-primary);margin-bottom:12px;font-weight:700}.gallery-filter-tabs{display:flex;gap:8px}.gallery-filter-btn{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);padding:6px 16px;border-radius:20px;cursor:pointer;font-size:.85rem;transition:all .2s}.gallery-filter-btn:hover{border-color:var(--gold);color:var(--gold)}.gallery-filter-btn.active{background:var(--text-primary);color:var(--bg-primary);border-color:var(--text-primary)}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;padding-bottom:40px}.gallery-empty{grid-column:1 / -1;text-align:center;padding:48px 24px;color:var(--text-muted)}.gallery-empty-icon{font-size:3rem;display:block;margin-bottom:12px}.gallery-card{background:var(--bg-secondary);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);transition:all .3s var(--ease);border:1px solid var(--border)}.gallery-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.gallery-card.highlighted{border-color:var(--gold);box-shadow:0 0 0 3px #d4a8534d}.gallery-card-media{position:relative;width:100%;aspect-ratio:2/1;background:#1a1a2e;overflow:hidden}.gallery-card-img,.gallery-card-video{width:100%;height:100%;object-fit:cover;display:block}.gallery-card-body{padding:12px}.gallery-card-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gallery-card-author{font-size:.8rem;color:var(--text-muted);margin-bottom:8px}.gallery-card-own{font-size:.75rem;color:var(--gold)}.gallery-card-footer{display:flex;align-items:center;justify-content:space-between}.gallery-vote-btn{background:transparent;border:1px solid var(--border);color:var(--text-secondary);padding:4px 10px;border-radius:20px;cursor:pointer;font-size:.8rem;display:flex;align-items:center;gap:4px;transition:all .2s}.gallery-vote-btn:hover{border-color:#ef4444;color:#ef4444}.gallery-vote-btn.voted{background:#fef2f2;border-color:#ef4444;color:#ef4444}.modal-overlay{position:fixed;inset:0;background:#263c48cc;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:var(--bg-secondary);border-radius:16px;width:100%;max-width:500px;max-height:90vh;box-shadow:0 8px 40px #0000001f,0 2px 8px #0000000f;display:flex;flex-direction:column;overflow:hidden;animation:modalUp .3s var(--ease)}@keyframes modalUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:20px 24px;border-bottom:1px solid rgba(212,168,83,.12);display:flex;align-items:center;justify-content:space-between}.modal-header h2{font-family:var(--font-display);font-size:1.5rem;color:var(--text-primary)}.modal-close{background:transparent;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:24px;overflow-y:auto;flex:1;min-height:0}.help-modal{max-width:520px}.help-body{padding:20px 24px!important}.help-intro{font-size:.88rem;color:var(--text-secondary);margin:0 0 16px;line-height:1.5}.help-method{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;padding:14px 16px}.help-method-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.help-method-header h3{margin:0;font-family:var(--font-body);font-size:.88rem;font-weight:700;color:var(--text-primary)}.help-method-badge{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:7px;background:linear-gradient(135deg,var(--clr-gold),#e0b96e);color:var(--clr-navy);font-family:var(--font-body);font-size:.78rem;font-weight:800;flex-shrink:0}.help-method-steps{display:flex;flex-direction:column;gap:6px}.help-divider{display:flex;align-items:center;gap:12px;margin:14px 0}.help-divider:before,.help-divider:after{content:"";flex:1;height:1px;background:var(--border)}.help-divider span{font-family:var(--font-body);font-size:.7rem;font-weight:700;color:var(--text-muted);letter-spacing:1px}.help-footer{padding:0 24px 20px;text-align:center}.help-footer .action-btn{width:100%}.help-step{display:flex;align-items:flex-start;gap:10px;padding:6px 0}.help-step:last-child{padding-bottom:0}.help-step:first-child{padding-top:0}.step-num{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:#d4a85326;color:var(--clr-gold);font-size:.72rem;font-weight:700;flex-shrink:0;margin-top:1px}.help-step p{flex:1;font-family:var(--font-body);font-size:.82rem;color:var(--text-secondary);margin:0;line-height:1.5}.help-step p strong{color:var(--text-primary);font-weight:600}.result-modal{text-align:center;padding:40px 32px 32px;max-width:380px;border-radius:20px;animation:resultSlideIn .4s cubic-bezier(.34,1.56,.64,1)}@keyframes resultSlideIn{0%{opacity:0;transform:translateY(30px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.result-icon{font-size:64px;line-height:1;margin-bottom:16px;animation:resultBounce .6s .2s cubic-bezier(.34,1.56,.64,1) both}@keyframes resultBounce{0%{transform:scale(0);opacity:0}60%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.result-title{font-size:1.4rem;font-weight:700;margin:0 0 8px}.result-message{font-size:.95rem;color:var(--text-secondary, #aaa);margin:0 0 24px;line-height:1.5}.result-close-btn{width:100%;margin-top:0}.result-modal.success .result-title{color:#4ade80}.result-modal.error .result-title{color:#f87171}.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10001;overflow:hidden}.confetti{position:absolute;width:10px;height:10px;top:-10px;animation:confettiFall linear forwards}@keyframes confettiFall{0%{transform:translateY(0) rotate(0);opacity:1}80%{opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.submit-preview-wrap{border-radius:var(--radius);overflow:hidden;margin-bottom:20px;background:#fff}.submit-preview-wrap video,.submit-preview-wrap img,.submit-preview-wrap canvas{width:100%;display:block;max-height:300px;object-fit:contain}.submit-form{display:flex;flex-direction:column;gap:6px}.submit-step{border:1px solid rgba(212,168,83,.1);border-radius:12px;background:#ffffff05;overflow:hidden}.submit-step-header{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#d4a85308;border-bottom:1px solid rgba(212,168,83,.08)}.submit-step-num{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--clr-gold),#c9a84c);color:var(--clr-navy);font-size:.75rem;font-weight:700;flex-shrink:0}.submit-step-title{font-size:.9rem;font-weight:600;color:var(--text-primary)}.submit-step-body{padding:12px 14px;display:flex;flex-direction:column;gap:8px}.submit-step-body label{font-size:.82rem;font-weight:600;color:var(--text-secondary);margin-bottom:-4px}.required{color:#ef4444;font-weight:400}.optional,.optional-label{font-weight:400;color:var(--text-muted);font-size:.8em}.security-hint{font-size:.82rem;color:var(--text-secondary);margin-bottom:8px}.otp-row{display:flex;gap:8px;align-items:flex-end}.otp-input-wrap{flex:1}.otp-row .action-btn{height:42px;white-space:nowrap;flex-shrink:0}.otp-status-text{font-size:.78rem;color:var(--text-muted);margin-top:4px}.security-badges{display:none;flex-wrap:wrap;gap:6px;margin-top:4px}.security-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:.7rem;font-weight:600;border:1px solid rgba(255,255,255,.08)}.security-badge.active{background:#22c55e1f;color:#22c55e;border-color:#22c55e40}.security-badge.inactive{background:#64646414;color:var(--text-muted);border-color:#64646426}.submit-label{display:block;font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:4px}.submit-label .optional{font-weight:400;color:var(--text-muted);font-size:.8rem}.submit-input{display:block;width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius);background:var(--bg-primary);color:var(--text-primary);font-size:.95rem;font-family:var(--font-body);transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.submit-input:focus{outline:none;border-color:var(--clr-gold);box-shadow:0 0 0 3px #d4a85333}.submit-input::placeholder{color:var(--text-muted)}.gallery-detail-media{width:100%;border-radius:var(--radius);overflow:hidden;background:#1a1a2e;margin-bottom:16px}.gallery-detail-media video{width:100%;max-height:50vh;object-fit:contain;display:block}.gallery-detail-info{display:flex;flex-direction:column;gap:12px}.gallery-detail-author{font-size:.9rem;color:var(--text-secondary)}.gallery-detail-actions{display:flex;gap:8px;flex-wrap:wrap}.gallery-detail-modal{max-width:800px}.gallery-detail-modal .gallery-detail-media video{max-height:60vh}.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:12px;z-index:3000}.toast{background:var(--bg-secondary);border-left:4px solid var(--clr-gold);padding:16px 20px;border-radius:var(--radius);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:12px;min-width:300px;animation:slideIn .3s var(--ease)}.toast.error{border-left-color:#ef4444}.toast.success{border-left-color:#22c55e}.toast-message{font-size:.9rem;color:var(--text-primary)}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.terms-overlay{position:fixed;inset:0;z-index:10000;background:#263c48a6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex!important;align-items:center;justify-content:center;padding:24px;animation:termsFadeIn .5s var(--ease)}.terms-overlay.hidden{display:none!important}.terms-container{background:#fff;max-width:520px;width:100%;max-height:88vh;border-radius:28px;box-shadow:0 25px 60px #0000004d,0 0 0 1px #ffffff1a;display:flex;flex-direction:column;overflow:hidden;position:relative;animation:termsSlideUp .6s cubic-bezier(.16,1,.3,1)}.terms-header{position:relative;text-align:center;flex-shrink:0;overflow:hidden;padding:0}.terms-header-bg{position:absolute;inset:0;background:linear-gradient(160deg,var(--clr-navy) 0%,#2d4654 50%,#345260 100%);z-index:0}.terms-header-bg:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 50% at 20% 80%,rgba(212,168,83,.08) 0%,transparent 60%),radial-gradient(ellipse 60% 40% at 80% 20%,rgba(212,168,83,.06) 0%,transparent 50%)}.terms-header-bg:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,var(--clr-gold) 50%,transparent 100%);opacity:.4}.terms-header-content{position:relative;z-index:1;padding:36px 32px 28px}.terms-logo{margin-bottom:16px}.terms-logo-img{height:40px;width:auto;filter:brightness(0) invert(1);opacity:.9}.terms-title{font-family:var(--font-display);font-size:1.75rem;color:#fff;margin-bottom:8px;line-height:1.15;letter-spacing:.04em}.terms-subtitle{font-family:var(--font-body);font-size:.72rem;color:var(--clr-gold);text-transform:uppercase;letter-spacing:.25em;font-weight:600;opacity:.85}.terms-header-line{width:36px;height:2px;background:linear-gradient(90deg,transparent,var(--clr-gold),transparent);margin:16px auto 0;border-radius:1px;opacity:.6}.terms-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:24px 28px;scroll-behavior:smooth;overscroll-behavior:contain}.terms-intro-box{background:linear-gradient(135deg,#faf8f4,#f5f0e8);border:1px solid rgba(212,168,83,.18);padding:24px 20px;border-radius:16px;text-align:center;margin-bottom:24px;position:relative}.terms-intro-box:before{content:"";position:absolute;top:-1px;left:20%;right:20%;height:2px;background:linear-gradient(90deg,transparent,var(--clr-gold),transparent);border-radius:1px;opacity:.4}.terms-intro-eyebrow{font-family:var(--font-body);font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.2em;color:var(--text-muted);margin-bottom:6px}.terms-intro-title{font-family:var(--font-display);font-size:1.2rem;color:var(--clr-navy);margin-bottom:6px;line-height:1.4;text-transform:uppercase}.text-gold{color:var(--clr-gold);display:block;margin-top:2px}.terms-intro-subtitle{font-family:var(--font-body);font-size:.7rem;font-weight:600;text-transform:uppercase;color:var(--text-muted);letter-spacing:.12em;margin-top:4px}.terms-divider{height:1px;width:32px;background:var(--clr-gold);margin:14px auto;opacity:.4}.terms-slogan{font-family:var(--font-body);color:var(--clr-navy);font-size:.88rem;line-height:1.5}.terms-slogan em{font-style:italic}.terms-content-section{margin-bottom:20px}.terms-section-header{display:flex;align-items:center;gap:10px;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid rgba(0,0,0,.05)}.terms-section-icon{flex-shrink:0;color:var(--clr-gold)}.terms-section-header h4{font-family:var(--font-display);font-size:1rem;color:var(--clr-navy);line-height:1.2;letter-spacing:.02em;margin:0}.terms-section-body{display:flex;flex-direction:column;gap:8px}.terms-section-body p{font-family:var(--font-body);font-size:.88rem;color:var(--text-secondary);line-height:1.65;margin:0}.terms-section-body strong{color:var(--clr-navy);font-weight:600}.terms-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.terms-list li{background:var(--bg-primary);border:1px solid rgba(0,0,0,.04);padding:12px 14px;border-radius:12px;display:flex;gap:12px;align-items:center;transition:all .25s var(--ease)}.terms-list li:hover{background:#f1f5f9;border-color:#d4a85333}.list-num{background:linear-gradient(135deg,var(--clr-navy),#2d4654);color:var(--clr-gold);font-family:var(--font-body);font-weight:700;font-size:.72rem;width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:8px;flex-shrink:0}.list-content{flex:1;font-family:var(--font-body);font-size:.85rem;color:var(--text-secondary);line-height:1.5}.list-content strong{color:var(--clr-navy);font-weight:600}.terms-body::-webkit-scrollbar{width:4px}.terms-body::-webkit-scrollbar-track{background:transparent}.terms-body::-webkit-scrollbar-thumb{background:#94a3b840;border-radius:10px}.terms-body::-webkit-scrollbar-thumb:hover{background:#94a3b873}.terms-footer{padding:20px 28px 28px;background:linear-gradient(to top,#f8fafc,#fff);border-top:1px solid rgba(0,0,0,.05);display:flex;flex-direction:column;gap:16px;flex-shrink:0}.terms-checkbox-label{display:flex;align-items:flex-start;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none;font-family:var(--font-body);font-size:.82rem;color:var(--text-secondary);line-height:1.45;padding:2px 0;transition:color .2s}.terms-checkbox-label:hover{color:var(--text-primary)}.terms-checkbox-label input{display:none}.terms-checkbox-custom{width:20px;height:20px;border:2px solid var(--border-hover);border-radius:6px;background:#fff;display:flex;align-items:center;justify-content:center;transition:all .25s cubic-bezier(.4,0,.2,1);flex-shrink:0;margin-top:1px}.terms-checkbox-label input:checked+.terms-checkbox-custom{background:var(--clr-gold);border-color:var(--clr-gold);transform:scale(1.08);box-shadow:0 3px 10px #d4a85359}.terms-checkbox-label input:checked+.terms-checkbox-custom:after{content:"✓";color:#fff;font-size:12px;font-weight:800}.terms-start-btn{width:100%;padding:15px 24px;border:none;border-radius:14px;background:linear-gradient(135deg,var(--clr-navy),#2d4654);color:#fff;font-family:var(--font-body);font-size:1rem;font-weight:600;cursor:pointer;transition:all .35s cubic-bezier(.34,1.56,.64,1);box-shadow:0 6px 20px #263c4840;letter-spacing:.03em;position:relative;overflow:hidden}.terms-start-btn:before{content:"";position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);transform:skew(-20deg);transition:left .6s}.terms-start-btn:hover:not(.disabled-visual){transform:translateY(-2px);box-shadow:0 10px 30px #263c4859}.terms-start-btn:hover:before{left:150%}.terms-start-btn:active:not(.disabled-visual){transform:translateY(0);box-shadow:0 4px 12px #263c4833}.terms-start-btn.disabled-visual{opacity:.5;cursor:not-allowed;background:#cbd5e1;color:#94a3b8;box-shadow:none;transform:none}@keyframes termsFadeIn{0%{opacity:0}to{opacity:1}}@keyframes termsSlideUp{0%{opacity:0;transform:translateY(30px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:1366px)and (min-width:1025px){:root{--sidebar-w: 220px}.sidebar{padding:14px;gap:8px}.panel-section{padding:12px;border-radius:10px}.panel-title{font-size:.7rem;margin-bottom:8px}.tool-grid{gap:5px}.tool-btn{border-radius:8px}.slider-wrapper{gap:8px}.slider-value{font-size:.75rem;min-width:28px}.color-palette{gap:4px}.preset-btns{gap:5px}.preset-btn{padding:6px 10px;font-size:.75rem}.action-btn{padding:10px 12px;font-size:.82rem;gap:8px}.bg-toggle-btn{padding:6px;font-size:.75rem}}@media(max-width:1200px)and (min-width:1025px){:root{--sidebar-w: 200px}.sidebar{padding:12px;gap:6px}.panel-section{padding:10px}.panel-title{font-size:.65rem;margin-bottom:6px}.tool-grid{gap:4px}.preset-btn{padding:5px 8px;font-size:.72rem}.action-btn{padding:8px 10px;font-size:.8rem;border-radius:8px}.action-btn.large{padding:10px;font-size:.85rem}.cp-wheel-area{max-width:150px}.cp-hex-input{width:64px;font-size:11px}}@media(max-width:768px){.terms-overlay{padding:16px}.terms-container{max-width:100%;max-height:90vh;border-radius:24px}.terms-header-content{padding:28px 24px 24px}.terms-title{font-size:1.5rem}.terms-body{padding:20px 22px}.terms-footer{padding:16px 22px 24px}}@media(max-width:640px){.terms-overlay{padding:0;align-items:flex-end;background:#263c48b3}.terms-container{max-height:94vh;max-height:94dvh;border-radius:24px 24px 0 0;animation:termsSlideUpMobile .5s cubic-bezier(.16,1,.3,1)}@keyframes termsSlideUpMobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}.terms-header-content{padding:28px 20px 22px}.terms-logo-img{height:32px}.terms-title{font-size:1.35rem}.terms-subtitle{font-size:.65rem}.terms-body{padding:18px}.terms-intro-box{padding:20px 16px}.terms-intro-title{font-size:1.05rem}.terms-section-body p{font-size:.84rem}.terms-list li{padding:10px 12px}.terms-footer{padding:16px 18px;padding-bottom:max(20px,env(safe-area-inset-bottom))}.terms-start-btn{font-size:.95rem;padding:14px 20px}}@media(max-width:380px){.terms-title{font-size:1.2rem}.terms-intro-title{font-size:.95rem}.terms-header-content{padding:24px 16px 18px}.list-content{font-size:.8rem}}:root{--mobile-nav-h: 72px;--header-h-mobile: 50px}@media(max-width:1024px){body{font-size:16px;overflow:hidden;touch-action:none;overscroll-behavior:none;-webkit-overflow-scrolling:auto;position:fixed;width:100%;height:100%}#app-header{height:var(--header-h-mobile)!important;padding:0 16px;justify-content:flex-start;background:linear-gradient(135deg,var(--clr-navy) 0%,#2d4654 100%);color:var(--clr-gold);backdrop-filter:none!important;-webkit-backdrop-filter:none!important;border-bottom:none;box-shadow:0 2px 12px #263c4826}.app-title-text{display:inline}.app-title{gap:0}.header-logo{height:26px}.header-right{right:16px}.header-nav{position:fixed;bottom:0;top:auto!important;left:0;width:100%;height:var(--mobile-nav-h);background:#ffffffd9;border-top:1px solid rgba(0,0,0,.06);display:flex;justify-content:space-around;align-items:center;z-index:1000;padding:0;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);box-shadow:0 -2px 20px #0000000a;padding-bottom:env(safe-area-inset-bottom,0px)}.view{height:calc(100vh - var(--header-h-mobile));top:var(--header-h-mobile);position:absolute;width:100%;overflow-y:auto;overflow-x:hidden}.nav-btn{flex-direction:column;justify-content:center;align-items:center;gap:2px;background:transparent;border:none;padding:8px 16px 6px;height:100%;border-radius:0;color:#8e99a4;transition:color .2s ease,transform .2s ease;flex:1}.nav-btn:active{transform:scale(.92)}.nav-btn.active{background:transparent;color:var(--clr-gold);box-shadow:none;position:relative}.nav-btn.active:after{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:32px;height:3px;background:linear-gradient(90deg,var(--clr-gold),#f0c46b);border-radius:0 0 6px 6px;box-shadow:0 2px 8px #d4a85366}.nav-icon{font-size:1.4rem;line-height:1;display:flex;align-items:center;justify-content:center;height:28px}.nav-label{font-size:.65rem;font-weight:600;letter-spacing:.3px;text-transform:uppercase}#view-color{flex-direction:column}#tools-panel{position:fixed;top:0;height:100vh;width:280px;background:var(--bg-panel);z-index:300;transition:transform .3s cubic-bezier(.4,0,.2,1);padding-top:var(--header-h-mobile);overflow-y:auto}#tools-panel{left:0;border-right:1px solid var(--border);transform:translate(-100%);box-shadow:4px 0 16px #00000026}#tools-panel.open{transform:translate(0)}.drawer-fab{position:fixed;top:50%;width:28px;height:58px;border:none;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:2px;cursor:pointer;z-index:250;font-size:1.1rem;transition:all .25s ease;-webkit-tap-highlight-color:transparent;padding:6px 0 0}.drawer-fab:active{transform:translateY(-50%) scale(.95)}.drawer-fab.active{opacity:0;pointer-events:none}.drawer-fab-left{left:0;transform:translateY(-50%);border-radius:0 12px 12px 0;background:linear-gradient(135deg,var(--clr-gold) 0%,#e0b96e 100%);box-shadow:2px 2px 10px #d4a85340;color:var(--clr-navy)}.fab-grip{font-size:.75rem;letter-spacing:3px;opacity:.85;line-height:1;writing-mode:horizontal-tb;pointer-events:none;-webkit-user-select:none;user-select:none;order:-1;color:#ffffffe6}.fab-icon{font-size:1.1rem;line-height:1;writing-mode:horizontal-tb;pointer-events:none;flex:1;display:flex;align-items:center}.drawer-fab:active .fab-grip{opacity:1}.drawer-handle,.drawer-toggle{display:none!important}.drawer-overlay{position:fixed;inset:0;background:#00000059;z-index:190;opacity:0;pointer-events:none;transition:opacity .3s}.drawer-overlay.visible{opacity:1;pointer-events:auto}#view-color #canvas-area{width:100%;height:100%;margin:0;position:absolute;inset:0;padding-top:44px;padding-bottom:calc(48px + env(safe-area-inset-bottom,0px));box-sizing:border-box}#view-color.active{display:block}#canvas-area{touch-action:none;-webkit-overflow-scrolling:auto}.canvas-wrapper{border-radius:10px;box-shadow:0 2px 12px #0000000f}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;padding:12px}.gallery-card-title{font-size:.9rem}.podium{flex-direction:column;align-items:center;gap:16px}.podium-card{width:100%;max-width:300px}.podium-card.gold{order:1;transform:none}.podium-card.silver{order:2;transform:none}.podium-card.bronze{order:3;transform:none}.mobile-only{display:block!important}.desktop-only{display:none!important}:root{--mobile-safe-bottom: env(safe-area-inset-bottom, 0px)}#tools-panel,.drawer-fab,.drawer-overlay{display:none!important}.mtp-io-group{display:flex;align-items:center;gap:4px;margin-left:auto;padding-left:6px;border-left:1px solid rgba(0,0,0,.08)}@supports (flex-wrap: wrap){.mobile-tool-panel{row-gap:4px}.mtp-io-group{flex-basis:auto}}.mtp-io-btn{display:flex;align-items:center;gap:3px;padding:4px 8px;border:1px solid var(--border);border-radius:6px;background:var(--bg-tertiary);color:var(--text-secondary);font-family:var(--font-body);font-size:.62rem;font-weight:600;white-space:nowrap;cursor:pointer;transition:all .15s ease}.mtp-io-btn svg{width:13px;height:13px;flex-shrink:0;opacity:.7}.mtp-io-btn:active{background:var(--bg-secondary);transform:scale(.95)}.sidebar .cp-wheel-area{max-width:160px!important}.canvas-floating-controls{position:fixed!important;bottom:calc(56px + env(safe-area-inset-bottom,0px))!important;top:auto!important;left:50%!important;right:auto!important;transform:translate(-50%)!important;width:auto!important;max-width:94%!important;z-index:240;padding:4px 10px!important;gap:4px!important;border-radius:20px!important;background:#ffffffeb!important;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 1px 8px #0000000f!important;border:1px solid rgba(0,0,0,.04)!important;box-sizing:border-box!important}.canvas-floating-controls .float-btn{width:34px!important;height:34px!important;font-size:1rem!important;border-radius:8px!important}.canvas-floating-controls .float-btn svg{width:18px!important;height:18px!important}.canvas-floating-controls .zoom-level{font-size:.75rem!important;min-width:34px}.canvas-floating-controls .control-group{gap:2px!important}.mobile-tool-panel{position:fixed;top:var(--header-h-mobile, 50px);left:0;right:0;z-index:250;margin-top:0;background:#fffffff5;backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border-radius:0;padding:4px 10px;box-shadow:0 1px 6px #0000000f;border-bottom:1px solid rgba(0,0,0,.04);display:flex!important;flex-direction:row;flex-wrap:wrap;gap:2px;align-items:center;justify-content:center;touch-action:none;-webkit-user-select:none;user-select:none;overflow:visible}.mobile-tool-panel:has(.mtp-section.open){border-radius:0}.mobile-tool-panel.dragging{box-shadow:0 1px 6px #0000000f}.mtp-grip,.mep-grip{display:none!important}.mtp-section{display:flex;align-items:center;justify-content:center;gap:2px;min-height:36px;position:relative;width:auto;align-self:center}.mtp-section.open{justify-content:center;width:auto;align-self:center}.mtp-collapsed{cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.mtp-expanded{display:none;flex-direction:column;align-items:center;justify-content:flex-start;gap:6px;padding:10px;animation:mtpExpand .12s ease;position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:6px;background:#fffffff7;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:14px;box-shadow:0 4px 20px #0000001a,0 1px 4px #0000000a;min-width:200px;max-width:calc(100vw - 20px);max-height:calc(100vh - 140px);overflow-y:auto;-webkit-overflow-scrolling:touch;z-index:300}@keyframes mtpExpand{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.mtp-section.open .mtp-collapsed{display:none}.mtp-section.open .mtp-expanded{display:flex}.mtp-btn{width:34px;height:34px;border:none;border-radius:8px;background:transparent;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s ease;-webkit-tap-highlight-color:transparent;flex-shrink:0}.mtp-btn:active{transform:scale(.9)}body .mtp-btn.active{background:linear-gradient(135deg,var(--clr-gold),#e0b96e)!important;color:var(--clr-navy)!important;box-shadow:0 2px 6px #d4a8534d!important}.mtp-color-preview{width:26px;height:26px;border-radius:50%;border:2px solid #e2e8f0;cursor:pointer;transition:transform .12s ease}.mtp-color-preview:active{transform:scale(.85)}.mtp-color-input{width:30px;height:30px;border:2px solid #e2e8f0;border-radius:6px;padding:1px;cursor:pointer;flex-shrink:0}.mtp-color-input::-webkit-color-swatch-wrapper{padding:0}.mtp-color-input::-webkit-color-swatch{border:none;border-radius:3px}.mtp-palette{display:grid;grid-template-columns:repeat(9,1fr);gap:3px;width:100%;padding-top:6px;border-top:1px solid rgba(0,0,0,.04)}.mtp-palette .mtp-swatch{aspect-ratio:1;width:auto;height:auto;max-width:36px;border-radius:4px;border:1px solid rgba(0,0,0,.08);cursor:pointer;transition:transform .12s ease,box-shadow .15s ease;-webkit-tap-highlight-color:transparent}.mtp-palette .mtp-swatch:hover,.mtp-palette .mtp-swatch:active{transform:scale(1.1);box-shadow:0 2px 6px #d4a85333}.mtp-palette .mtp-swatch.active{box-shadow:0 0 0 2px #fff,0 0 0 3px var(--clr-gold);z-index:1;transform:scale(1.05)}#mtp-section-colors .mtp-expanded{left:auto;right:auto;transform:none;position:fixed;top:calc(var(--header-h-mobile) + 44px + 2px);left:10px;right:10px;width:auto;min-width:auto;overflow-y:auto;-webkit-overflow-scrolling:touch;align-items:stretch;padding:12px;gap:0;animation:mtpExpandDown .15s ease}@keyframes mtpExpandDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.mtp-current-color-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding:6px 8px;background:var(--bg-tertiary, #f8fafc);border-radius:8px;border:1px solid var(--border, rgba(0, 0, 0, .06))}.mtp-current-swatch{width:28px;height:28px;border-radius:6px;border:2px solid rgba(0,0,0,.1);flex-shrink:0;box-shadow:0 1px 3px #0000001a}.mtp-current-hex{font-family:JetBrains Mono,Menlo,monospace;font-size:.72rem;color:var(--text-secondary, #64748b);font-weight:600;text-transform:uppercase;flex:1;min-width:0}#mtp-colors-expanded #mobile-color-picker-container{width:100%;margin-bottom:6px;padding-top:4px}.mtp-recent-wrap{width:100%;margin-bottom:8px;padding-top:6px;border-top:1px solid rgba(0,0,0,.04)}.mtp-recent-label{font-size:.58rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted, #94a3b8);font-weight:600;margin:0 0 5px}.mtp-recent-swatches{display:flex;flex-wrap:wrap;gap:3px}.mtp-recent-swatches .mtp-swatch{width:22px;height:22px;border-radius:4px;border:1px solid rgba(0,0,0,.08);cursor:pointer;transition:transform .15s ease,box-shadow .2s ease;-webkit-tap-highlight-color:transparent}.mtp-recent-swatches .mtp-swatch:hover,.mtp-recent-swatches .mtp-swatch:active{transform:scale(1.15);box-shadow:0 2px 8px #d4a85333}.mtp-recent-swatches .mtp-swatch.active{box-shadow:0 0 0 2px #fff,0 0 0 3.5px var(--clr-gold);z-index:1;transform:scale(1.05)}.mtp-done-btn{width:100%;padding:8px 0;border:none;border-radius:8px;background:linear-gradient(135deg,var(--clr-gold) 0%,#e0b96e 100%);color:var(--clr-navy);font-size:.75rem;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .12s ease;margin-top:10px;text-transform:uppercase;letter-spacing:.03em}.mtp-done-btn:active{transform:scale(.97)}.mtp-size-badge{width:28px;height:28px;border-radius:50%;background:#f1f5f9;color:#475569;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;border:2px solid #e2e8f0;transition:transform .12s ease}.mtp-size-badge:active{transform:scale(.85)}.mtp-range{width:160px;height:6px;-webkit-appearance:none;appearance:none;background:#e2e8f0;border-radius:3px;outline:none;touch-action:auto;padding:10px 0;accent-color:var(--clr-gold)}.mtp-range::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;border-radius:50%;background:var(--clr-gold);cursor:pointer;box-shadow:0 1px 4px #0003}.mtp-size-val{font-size:.85rem;font-weight:600;color:#64748b;min-width:18px;text-align:center}.mtp-section+.mtp-section:before,.mtp-mode-btn+.mtp-section:before{content:"";width:1px;height:20px;background:#00000014;margin:0 4px;flex-shrink:0}.mtp-mode-btn{width:34px;height:34px;border:none;border-radius:8px;background:transparent;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s ease;-webkit-tap-highlight-color:transparent;flex-shrink:0}.mtp-mode-btn svg{width:18px;height:18px}.mtp-mode-btn.active{background:linear-gradient(135deg,var(--clr-gold),#e0b96e);color:var(--clr-navy);box-shadow:0 2px 6px #d4a8534d}.mtp-mode-btn:active{transform:scale(.9)}.mobile-footer{position:fixed!important;bottom:0!important;left:0!important;right:0!important;width:100%!important;z-index:250;padding:8px 16px!important;padding-bottom:calc(8px + env(safe-area-inset-bottom,0px))!important;background:#ffffffeb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid rgba(0,0,0,.04);display:flex!important;justify-content:center!important;align-items:center!important;box-sizing:border-box!important}.mobile-submit-btn{width:auto!important;max-width:none!important;margin:0 auto!important;padding:10px 32px;border:none;border-radius:24px;background:linear-gradient(135deg,var(--clr-gold) 0%,#e0b96e 100%);color:var(--clr-navy);font-family:var(--font-body);font-size:.85rem;font-weight:700;cursor:pointer;box-shadow:0 3px 12px #d4a8534d;transition:all .15s ease;-webkit-tap-highlight-color:transparent;display:inline-flex;align-items:center;justify-content:center;gap:6px;letter-spacing:.03em;text-transform:uppercase;box-sizing:border-box}.mobile-submit-btn:active{transform:scale(.96);box-shadow:0 1px 6px #d4a85333}.view{height:calc(100vh - var(--header-h-mobile))}.control-group{gap:2px;align-items:center}.float-btn{width:36px;height:36px;font-size:1rem;flex-shrink:0}.float-btn.accent-btn{height:34px;padding:0 12px;font-size:.78rem}.zoom-level{font-size:.75rem;min-width:36px}.panel-section{transition:all .2s ease}.panel-title{display:flex;align-items:center;cursor:pointer;padding-right:8px}.panel-title:after{content:"▼";font-size:.7rem;color:var(--text-muted);transition:transform .2s;margin-left:auto}.panel-section.collapsed .panel-title:after{transform:rotate(-90deg)}.panel-section.collapsed>*:not(.panel-title){display:none}.modal-overlay{padding:12px;align-items:flex-end}.modal{max-height:85vh;border-radius:16px 16px 0 0}.modal-header{padding:12px 16px;gap:8px}.modal-header h2{font-size:.9rem;display:flex;align-items:center;gap:6px;letter-spacing:-.01em}.modal-header h2 .icon{width:16px;height:16px;flex-shrink:0;color:var(--clr-gold)}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px}.modal-body{padding:16px}.submit-preview-wrap{max-height:35vh;overflow:hidden;border-radius:10px;margin-bottom:14px}.submit-preview-wrap img,.submit-preview-wrap canvas{width:100%;height:100%;max-height:35vh;object-fit:contain;display:block}.submit-form .submit-label{font-size:.8rem;margin-bottom:4px}.submit-form .submit-input{padding:10px 12px;font-size:.9rem}.otp-row{flex-direction:row;gap:6px;align-items:stretch}.otp-row .otp-input-wrap{flex:1;min-width:0}.otp-row .action-btn{white-space:nowrap;padding:8px 14px;font-size:.75rem;border-radius:8px;flex-shrink:0;justify-content:center}.otp-row .action-btn .icon{width:13px;height:13px}.help-step{padding:10px 0}.gallery-detail-modal{max-width:100%}.gallery-detail-media img{max-height:40vh;object-fit:contain}}@media(max-width:1024px){.terms-container{width:100%;max-width:100%}.terms-body{-webkit-overflow-scrolling:touch;overflow-y:auto;flex:1}}@media(max-width:600px){.app-title-text{display:none}}@media(max-width:380px){#app-header{padding:0 10px}.header-logo{height:20px}.header-right{right:10px}.icon-btn{width:34px;height:34px}.mtp-btn,.mtp-mode-btn{width:30px!important;height:30px!important}.mtp-color-preview{width:22px!important;height:22px!important}.mtp-size-badge{width:24px!important;height:24px!important;font-size:.65rem!important}.mobile-tool-panel{padding:3px 6px!important}.canvas-floating-controls .float-btn{width:30px!important;height:30px!important}.canvas-floating-controls .zoom-level{font-size:.7rem!important;min-width:30px}.mobile-submit-btn{padding:8px 24px!important;font-size:.8rem!important}}@media(min-width:600px)and (max-width:1024px){.mobile-tool-panel{padding:6px 16px!important;gap:4px!important}.mtp-btn,.mtp-mode-btn{width:38px!important;height:38px!important}.mtp-color-preview{width:30px!important;height:30px!important}.mtp-size-badge{width:32px!important;height:32px!important}.mtp-expanded{min-width:260px!important}#mtp-section-colors .mtp-expanded{left:50%!important;right:auto!important;transform:translate(-50%)!important;width:300px!important;position:absolute!important;top:100%!important}.mtp-palette{grid-template-columns:repeat(10,1fr)!important}.canvas-floating-controls .float-btn{width:38px!important;height:38px!important}.modal{max-width:500px;margin:0 auto;border-radius:16px!important}.modal-overlay{align-items:center!important}}@media(max-width:1024px)and (max-height:500px){:root{--header-h-mobile: 42px}.mobile-tool-panel{padding:2px 10px!important}.mtp-btn,.mtp-mode-btn{width:30px!important;height:30px!important}.mtp-section{min-height:30px!important}.canvas-floating-controls{bottom:calc(36px + env(safe-area-inset-bottom,0px))!important;padding:3px 8px!important}.canvas-floating-controls .float-btn{width:28px!important;height:28px!important}.mobile-footer{padding:4px 16px!important;padding-bottom:calc(4px + env(safe-area-inset-bottom,0px))!important}.mobile-submit-btn{padding:6px 24px!important;font-size:.8rem!important}#view-color #canvas-area{padding-top:36px!important;padding-bottom:calc(36px + env(safe-area-inset-bottom,0px))!important}.mtp-expanded{max-height:calc(100vh - 120px)!important}.modal{max-height:90vh!important}}
