:root{--bg:#fff;--bg2:#f8f8f8;--bg3:#f0f0f0;--border:#e5e5e5;--border2:#d4d4d4;--text:#111;--text2:#555;--text3:#888;--yellow:#ffd600;--yellow-hover:#f0c800;--green:#16a34a;--red:#dc2626;--orange:#ea580c;--radius:10px;--radius-sm:6px;--sidebar-w:240px;--shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);--shadow-md:0 4px 6px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.05);--shadow-lg:0 10px 15px rgba(0,0,0,.1),0 4px 6px rgba(0,0,0,.05)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d1d1d1;border-radius:99px}.app-shell{overflow:hidden}.app-shell,.sidebar{display:flex;height:100vh}.sidebar{width:var(--sidebar-w);background:var(--bg);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;overflow-y:auto;overflow-x:hidden}.sidebar-logo{padding:16px;border-bottom:1px solid var(--border);gap:10px}.sidebar-logo,.sidebar-logo-badge{display:flex;align-items:center;flex-shrink:0}.sidebar-logo-badge{width:32px;height:32px;background:var(--yellow);border-radius:6px;justify-content:center;font-size:12px;font-weight:800;color:#000}.sidebar-logo-text strong{display:block;font-size:12px;font-weight:700}.sidebar-logo-text span{font-size:10.5px;color:var(--text3)}.sidebar-section{padding:8px 8px 0}.sidebar-section-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);padding:8px 8px 4px}.sidebar-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--radius-sm);font-size:13px;color:var(--text2);cursor:pointer;transition:all .13s;background:none;border:none;width:100%;text-align:left;text-decoration:none;position:relative}.sidebar-item:hover{background:var(--bg2);color:var(--text)}.sidebar-item.active{background:#fff9e0;color:#7a6000;font-weight:500}.sidebar-item.active:before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:3px;background:var(--yellow);border-radius:0 3px 3px 0}.sidebar-item-icon{width:16px;text-align:center;flex-shrink:0;font-size:13px}.sidebar-badge{margin-left:auto;font-size:9px;font-weight:700;padding:1px 5px;border-radius:99px;background:var(--bg3);color:var(--text3);text-transform:uppercase;letter-spacing:.04em}.sidebar-badge.new{background:#dcfce7;color:#16a34a}.sidebar-badge.soon{background:var(--bg3);color:var(--text3);opacity:.6}.sidebar-submenu{padding-left:20px}.sidebar-footer{margin-top:auto;padding:12px;border-top:1px solid var(--border);flex-shrink:0}.credits-bar{background:var(--bg2);border-radius:var(--radius-sm);padding:8px 10px;margin-bottom:8px;font-size:11px}.credits-bar-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}.credits-bar-label{color:var(--text3)}.credits-bar-value{font-weight:700;color:var(--text);font-size:12px}.credits-progress{height:3px;background:var(--border);border-radius:99px;overflow:hidden}.credits-progress-fill{height:100%;background:var(--yellow);border-radius:99px;transition:width .4s}.user-row{display:flex;align-items:center;gap:8px;padding:6px;cursor:pointer;border-radius:var(--radius-sm)}.user-row:hover{background:var(--bg2)}.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--yellow);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#000;flex-shrink:0}.user-info{flex:1 1;min-width:0}.user-name{font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{font-size:10px;color:var(--text3)}.logout-btn{width:24px;height:24px;border:none;background:none;cursor:pointer;color:var(--text3);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:13px}.logout-btn:hover{background:var(--bg3);color:var(--text)}.main-content{flex:1 1;min-width:0;display:flex;flex-direction:column;height:100vh;overflow:hidden}.page-scroll{flex:1 1;overflow-y:auto;padding:28px 32px}.credits-banner{background:#f0fdf4;border-bottom:1px solid #d1fae5;padding:8px 32px;font-size:12px;font-weight:500;color:#16a34a;display:flex;align-items:center;gap:6px;flex-shrink:0}.page-header{margin-bottom:24px}.page-title{font-size:22px;font-weight:700;line-height:1.2}.page-subtitle{font-size:13px;color:var(--text3);margin-top:3px}.card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.field{margin-bottom:16px}.field-label{display:block;font-size:12px;font-weight:600;color:var(--text);margin-bottom:6px}.field-hint{font-size:11.5px;color:var(--text3);margin-top:4px;line-height:1.5}.input{width:100%;padding:8px 11px;border:1px solid var(--border2);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);font-size:13px;outline:none;transition:border-color .15s}.input:focus{border-color:#aaa}.input::placeholder{color:var(--text3)}textarea.input{resize:vertical;min-height:80px;line-height:1.55}.select-wrapper{position:relative}.select{width:100%;padding:8px 32px 8px 11px;border:1px solid var(--border2);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);font-size:13px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpolyline points='6,9 12,15 18,9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.upload-zone{border:2px dashed var(--border2);border-radius:var(--radius);padding:28px 20px;text-align:center;cursor:pointer;transition:all .15s;background:var(--bg2)}.upload-zone.drag-over,.upload-zone:hover{border-color:#aaa;background:var(--bg3)}.upload-zone.has-image{padding:0;overflow:hidden;position:relative;min-height:140px}.upload-zone-icon{font-size:22px;color:var(--text3);margin-bottom:8px}.upload-zone-text{font-size:13px;color:var(--text2);font-weight:500}.upload-zone-hint{font-size:11px;color:var(--text3);margin-top:3px}.upload-zone img{width:100%;height:100%;object-fit:contain;max-height:220px;padding:8px}.upload-tabs{display:flex;margin-top:6px}.upload-tab{flex:1 1;padding:6px 4px;text-align:center;font-size:12px;color:var(--text3);border:1px solid var(--border);background:var(--bg);cursor:pointer;transition:all .13s}.upload-tab:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.upload-tab:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.upload-tab:not(:first-child){border-left:none}.upload-tab.active{background:var(--bg3);color:var(--text);font-weight:500}.upload-tab:hover:not(.active){background:var(--bg2)}.radio-grid{display:grid;grid-gap:8px;gap:8px}.radio-grid.cols2{grid-template-columns:1fr 1fr}.radio-grid.cols3{grid-template-columns:1fr 1fr 1fr}.radio-card{border:1.5px solid var(--border2);border-radius:var(--radius-sm);padding:9px 12px;cursor:pointer;transition:all .13s;display:flex;align-items:center;gap:8px;background:var(--bg)}.radio-card:hover{border-color:#bbb;background:var(--bg2)}.radio-card.selected{border-color:var(--text);background:var(--bg)}.radio-card.disabled{opacity:.45;cursor:not-allowed}.radio-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--border2);flex-shrink:0;display:flex;align-items:center;justify-content:center}.radio-card.selected .radio-dot{border-color:var(--text);background:var(--text);box-shadow:inset 0 0 0 2.5px var(--bg)}.radio-card-text strong{display:block;font-size:12.5px;font-weight:600}.radio-card-text span{font-size:11px;color:var(--text3)}.pill-group{display:flex;gap:6px}.pill{width:38px;height:38px;border-radius:8px;border:1.5px solid var(--border2);background:var(--bg);font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .13s}.pill:hover{border-color:#bbb;background:var(--bg2)}.pill.active{background:var(--text);color:var(--bg);border-color:var(--text)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--text);color:#fff;width:100%;padding:12px 20px;font-size:14px}.btn-primary:hover:not(:disabled){background:#222}.btn-yellow{background:var(--yellow);color:#000;width:100%;padding:12px 20px;font-size:14px;font-weight:700}.btn-yellow:hover:not(:disabled){background:var(--yellow-hover)}.btn-outline{background:transparent;color:var(--text);border:1.5px solid var(--border2)}.btn-outline:hover{background:var(--bg2)}.btn-ghost{background:transparent;color:var(--text2);border:none}.btn-ghost:hover{background:var(--bg2);color:var(--text)}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-sm{padding:5px 11px;font-size:12px}.btn-icon{width:32px;height:32px;padding:0;border-radius:var(--radius-sm)}.section{margin-bottom:28px}.section-title{font-size:14px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:7px}.two-col{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.three-col{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:12px;gap:12px}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border:1px solid var(--border2);border-radius:var(--radius-sm);background:var(--bg)}.toggle-label strong{display:block;font-size:13px;font-weight:600}.toggle-label span{font-size:11.5px;color:var(--text3)}.toggle{position:relative;width:40px;height:22px;flex-shrink:0;cursor:pointer}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{position:absolute;inset:0;border-radius:99px;background:var(--border2);transition:background .2s}.toggle-slider:before{content:"";position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;top:3px;left:3px;transition:transform .2s;box-shadow:0 1px 2px rgba(0,0,0,.2)}.toggle input:checked+.toggle-slider{background:var(--text)}.toggle input:checked+.toggle-slider:before{transform:translateX(18px)}.checkbox-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text2);cursor:pointer}.checkbox-row input[type=checkbox]{width:14px;height:14px;accent-color:var(--text)}.examples-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px}.examples-bar-left{display:flex;align-items:center;gap:12px}.examples-title{font-size:14px;font-weight:600;display:flex;align-items:center;gap:6px}.btn-tips{padding:5px 12px;border:1px solid var(--border2);border-radius:6px;background:var(--bg);color:var(--text2);gap:5px}.btn-tips,.examples-toggle{font-size:12px;cursor:pointer;display:flex;align-items:center}.examples-toggle{color:var(--text3);gap:4px}.examples-hint{font-size:11.5px;color:var(--text3);margin-bottom:12px}.variant-selector{display:flex;gap:8px}.variant-btn{flex:1 1;padding:10px;border:1.5px solid var(--border2);border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;background:var(--bg);color:var(--text2);transition:all .13s;display:flex;align-items:center;justify-content:center;gap:6px}.variant-btn.active{border-color:var(--text);color:var(--text);background:var(--bg)}.notif-note{font-size:11.5px;color:var(--text3);gap:5px;justify-content:center}.gallery-header,.notif-note{display:flex;align-items:center}.gallery-header{justify-content:space-between;margin-bottom:14px}.gallery-title{font-size:15px;font-weight:700;display:flex;align-items:center;gap:6px}.gallery-count{font-size:12px;color:var(--text3);margin-top:1px}.gallery-filter select{padding:6px 28px 6px 10px;border:1px solid var(--border2);border-radius:6px;font-size:12px}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));grid-gap:10px;gap:10px}.gallery-empty{padding:48px;text-align:center;border:2px dashed var(--border);border-radius:var(--radius);color:var(--text3)}.gallery-empty-icon{font-size:32px;margin-bottom:10px}.gallery-empty-title{font-size:14px;font-weight:600;color:var(--text2)}.gallery-empty-sub{font-size:12px;margin-top:4px}.gallery-card{border:1px solid var(--border);border-radius:8px;overflow:hidden;cursor:pointer;transition:box-shadow .15s}.gallery-card:hover{box-shadow:var(--shadow-md)}.gallery-card-img{aspect-ratio:1;background:var(--bg2);position:relative;overflow:hidden}.gallery-card-img img{width:100%;height:100%;object-fit:cover}.gallery-card-info{padding:7px 9px}.gallery-card-module{font-size:11px;font-weight:600;text-transform:capitalize}.gallery-card-date{font-size:10px;color:var(--text3)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--bg);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;padding:24px}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-title{font-size:16px;font-weight:700}.auth-page{min-height:100vh;display:flex}.auth-left{flex:1 1;background:#000;color:#fff;display:flex;flex-direction:column;padding:48px;position:relative;overflow:hidden}.auth-left:before{content:"";position:absolute;top:-80px;left:-60px;width:400px;height:400px;background:radial-gradient(circle,rgba(255,214,0,.08) 0,transparent 70%);pointer-events:none}.auth-logo{gap:12px;margin-bottom:48px}.auth-logo,.auth-logo-badge{display:flex;align-items:center}.auth-logo-badge{width:38px;height:38px;background:var(--yellow);border-radius:7px;justify-content:center;font-size:13px;font-weight:800;color:#000}.auth-logo-text strong{display:block;font-size:13px;font-weight:700;letter-spacing:.02em}.auth-logo-text span{font-size:11px;color:#888}.auth-headline{font-size:clamp(36px,4vw,52px);font-weight:800;line-height:1.05;margin-bottom:16px}.auth-headline em{color:var(--yellow);font-style:normal}.auth-sub{font-size:14px;color:#999;line-height:1.65;max-width:340px;margin-bottom:32px}.auth-features{margin-top:auto;display:flex;flex-direction:column;gap:8px}.auth-feature{display:flex;align-items:center;gap:10px;font-size:13px;color:#ccc;padding:10px 12px;background:hsla(0,0%,100%,.04);border:1px solid hsla(0,0%,100%,.07);border-radius:8px}.auth-feature-icon{color:var(--yellow);font-size:15px;flex-shrink:0}.auth-right{width:420px;display:flex;align-items:center;justify-content:center;padding:40px 36px;border-left:1px solid var(--border)}.auth-form-wrap{width:100%;max-width:320px}.auth-form-title{font-size:22px;font-weight:700;margin-bottom:4px}.auth-form-sub{font-size:13px;color:var(--text3);margin-bottom:24px}.auth-error{background:#fef2f2;border:1px solid #fecaca;border-radius:7px;padding:9px 12px;font-size:12px;color:var(--red);margin-bottom:14px}.auth-link{text-align:center;margin-top:16px;font-size:12px;color:var(--text3)}.auth-link a{color:var(--text);font-weight:600;text-decoration:underline}.brand-section{border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px}.brand-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.brand-section-title{font-size:14px;font-weight:700;display:flex;align-items:center;gap:7px}.brand-section-sub{font-size:12px;color:var(--text3);margin-bottom:14px}.color-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:12px;gap:12px}.color-slot label{font-size:11px;color:var(--text3);margin-bottom:5px;display:block}.color-input-row{display:flex;align-items:center;gap:7px}.color-swatch{width:32px;height:32px;border-radius:5px;border:1px solid var(--border2);cursor:pointer;flex-shrink:0}.color-add-btn{width:100%;padding:8px 12px;border:1.5px dashed var(--border2);background:var(--bg2);color:var(--text3);border-radius:var(--radius-sm);font-size:12px;cursor:pointer;transition:all .13s;display:flex;align-items:center;justify-content:center;gap:5px}.color-add-btn:hover{border-color:#aaa;background:var(--bg3);color:var(--text)}.asset-empty{border:2px dashed var(--border);border-radius:8px;padding:28px;text-align:center;font-size:12px;color:var(--text3)}.asset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));grid-gap:10px;gap:10px}.asset-card{border:1px solid var(--border);border-radius:8px;overflow:hidden;position:relative}.asset-card img{width:100%;aspect-ratio:1;object-fit:cover}.asset-card-name{padding:5px 6px;font-size:10px;color:var(--text2)}.asset-card-del{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;border:none;cursor:pointer;font-size:10px;display:flex;align-items:center;justify-content:center}.admin-table{width:100%;border-collapse:collapse}.admin-table th{text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text3);padding:8px 12px}.admin-table td,.admin-table th{border-bottom:1px solid var(--border)}.admin-table td{padding:10px 12px;font-size:13px}.admin-table tr:hover td{background:var(--bg2)}.badge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:99px;font-size:10px;font-weight:600}.badge-admin{background:#fef9c3;color:#854d0e}.badge-user{background:var(--bg3);color:var(--text3)}.badge-active{background:#dcfce7;color:#16a34a}.usp-item{border:1px solid var(--border2);border-radius:var(--radius-sm);padding:12px;background:var(--bg2);margin-bottom:8px;display:flex;gap:10px;align-items:flex-start}.usp-num{width:24px;height:24px;border-radius:50%;background:var(--text);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.usp-fields{flex:1 1;display:flex;flex-direction:column;gap:6px}.btn-add-dashed{width:100%;padding:9px;border:1.5px dashed var(--border2);background:transparent;border-radius:var(--radius-sm);color:var(--text3);font-size:12.5px;cursor:pointer;transition:all .13s;display:flex;align-items:center;justify-content:center;gap:5px}.btn-add-dashed:hover{border-color:#aaa;background:var(--bg2);color:var(--text)}.spinner{width:18px;height:18px;border:2px solid hsla(0,0%,100%,.3);border-top-color:currentcolor;border-radius:50%;animation:spin .7s linear infinite}.spinner-dark{border-color:rgba(0,0,0,.15);border-top-color:var(--text)}@keyframes spin{to{transform:rotate(1turn)}}.template-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:18px;gap:0}.template-tab{padding:9px 16px;font-size:13px;color:var(--text3);background:none;cursor:pointer;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .13s}.template-tab.active{color:var(--text);border-bottom-color:var(--text);font-weight:600}.template-tab:hover:not(.active){color:var(--text2)}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));grid-gap:12px;gap:12px}.template-card{border:1.5px solid var(--border);border-radius:8px;overflow:hidden;cursor:pointer;transition:all .15s}.template-card:hover{border-color:#bbb;box-shadow:var(--shadow-md)}.template-card.selected{border-color:var(--text);box-shadow:var(--shadow)}.template-card-img{aspect-ratio:1;background:var(--bg2);overflow:hidden}.template-card-img img{width:100%;height:100%;object-fit:cover}.template-card-name{padding:8px 10px;font-size:12px;font-weight:500}.template-card-brand{font-size:10px;color:var(--text3)}.variation-group{border:1px solid var(--border2);border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:8px}.variation-label{font-size:12px;font-weight:700;margin-bottom:8px}@media (max-width:768px){.auth-left{display:none}.auth-right{width:100%}.two-col{grid-template-columns:1fr}}