@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";html[data-theme=dark]{--bg-primary:#060614;--bg-secondary:#0a0a20;--bg-card:#0f0f2a;--bg-card-hover:#14143a;--text-primary:#f0f0ff;--text-secondary:#9a9abf;--text-muted:#5a5a80;--border-color:#6478ff1f;--border-strong:#6478ff40;--accent:#2b4fff;--accent-light:#4d6fff;--accent-glow:#2b4fff26;--accent-surface:#2b4fff0f;--nav-bg:#060614eb;--nav-border:#6478ff1f;--modal-bg:#0f0f23;--modal-overlay:#060614d9;--card-shadow:0 4px 24px #0000004d;--footer-bg:#060614;--kakao-bg:#fee500;--kakao-text:#1a1a1a;--success:#22c55e;--error:#ef4444;--star-opacity:1;--aurora-opacity:1;--globe-filter:none}html[data-theme=light]{--bg-primary:#fff;--bg-secondary:#f5f5f7;--bg-card:#f0f0f3;--bg-card-hover:#e8e8ee;--text-primary:#1a1a2e;--text-secondary:#555570;--text-muted:#8888a0;--border-color:#00000014;--border-strong:#00000026;--accent:#2b4fff;--accent-light:#4d6fff;--accent-glow:#2b4fff14;--accent-surface:#2b4fff0d;--nav-bg:#ffffffeb;--nav-border:#0000000f;--modal-bg:#fff;--modal-overlay:#0006;--card-shadow:0 2px 12px #0000000f;--footer-bg:#f5f5f7;--kakao-bg:#fee500;--kakao-text:#1a1a1a;--success:#16a34a;--error:#dc2626;--star-opacity:0;--aurora-opacity:.03;--globe-filter:brightness(1.3) saturate(.7)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}::selection{color:#fff;background:#6c63ff4d}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}.theme-toggle{border:1px solid var(--border-color);cursor:pointer;background:0 0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;transition:transform .3s,border-color .2s;display:flex}.theme-toggle:hover{border-color:var(--border-strong)}.theme-toggle:active{transform:rotate(180deg)}@property --a{syntax:"<angle>";inherits:false;initial-value:0deg}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{--a:360deg}}@keyframes spinSimple{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{box-shadow:0 0 #6c63ff66}50%{box-shadow:0 0 0 8px #6c63ff00}}@keyframes glowLine{0%,to{opacity:.6}50%{opacity:1}}@keyframes orbFloat1{0%,to{transform:translate(0)}50%{transform:translate(8vw,-6vh)}}@keyframes orbFloat2{0%,to{transform:translate(0)}50%{transform:translate(-6vw,5vh)}}@keyframes orbFloat3{0%,to{transform:translate(0)}50%{transform:translate(5vw,4vh)}}@keyframes shineMove{0%{left:-75%}to{left:125%}}@keyframes badgePulse{0%,to{opacity:1}50%{opacity:.4}}.app{background:var(--bg-primary);min-height:100vh;display:flex;position:relative;overflow:hidden}.app:after{content:"";opacity:.045;pointer-events:none;z-index:1;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:180px;position:fixed;inset:0}.aurora-orb{pointer-events:none;z-index:0;filter:blur(1px);opacity:var(--aurora-opacity);border-radius:50%;position:fixed}.aurora-orb--1{filter:blur(60px);background:#6366f11f;width:400px;height:400px;animation:20s ease-in-out infinite alternate orbFloat1;top:5%;left:20%}.aurora-orb--2{filter:blur(50px);background:#ec489914;width:350px;height:350px;animation:25s ease-in-out infinite alternate orbFloat2;top:60%;right:10%}.aurora-orb--3{filter:blur(40px);background:#3b82f60f;width:300px;height:300px;animation:18s ease-in-out infinite alternate orbFloat3;bottom:10%;left:40%}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-color);z-index:2;flex-direction:column;flex-shrink:0;width:250px;padding:20px 0;display:flex;position:relative}.sidebar:after{content:"";background:linear-gradient(#6c63ff,#8b5cf6,#ec4899);border-radius:2px;width:2px;animation:4s ease-in-out infinite glowLine;position:absolute;top:20%;bottom:20%;right:-1px}.sidebar-header{border-bottom:1px solid var(--border-color);align-items:center;gap:12px;margin-bottom:20px;padding:0 20px 24px;display:flex}.logo-icon{background:conic-gradient(from var(--a), #6c63ff, #8b5cf6, #ec4899, #6c63ff);border-radius:10px;flex-shrink:0;width:36px;height:36px;animation:4s linear infinite spin;position:relative}.logo-icon:after{content:"C";background:var(--bg-primary);color:#fff;border-radius:7px;justify-content:center;align-items:center;font-size:16px;font-weight:800;display:flex;position:absolute;inset:3px}.logo-text{flex-direction:column;display:flex}.logo-title{color:var(--text-primary);font-size:15px;font-weight:700}.logo-sub{letter-spacing:1.5px;color:var(--text-muted);text-transform:uppercase;font-size:9px;font-weight:600}.sidebar-nav{flex-direction:column;gap:2px;margin-bottom:24px;padding:0 12px;display:flex}.sidebar-item{cursor:pointer;color:var(--text-muted);text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;padding:10px 12px;font-family:inherit;font-size:13px;transition:all .2s;display:flex;position:relative}.sidebar-item:hover{background:var(--accent-surface);color:var(--text-secondary)}.sidebar-item.active{background:var(--accent-glow);color:var(--text-primary);font-weight:600}.sidebar-item.active:before{content:"";background:var(--accent);border-radius:0 3px 3px 0;width:3px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-icon{text-align:center;width:20px;font-size:15px}.sidebar-badge{background:var(--accent-glow);color:var(--accent);border-radius:10px;margin-left:auto;padding:2px 7px;font-size:10px;font-weight:700}.sidebar-stepper{margin-bottom:auto;padding:0 20px}.sidebar-stepper-title{letter-spacing:1px;color:var(--text-muted);text-transform:uppercase;margin-bottom:16px;font-size:10px;font-weight:600}.stepper-item{align-items:center;gap:12px;padding:8px 0;display:flex;position:relative}.stepper-item:not(:last-child):after{content:"";background:var(--border-color);width:1px;height:20px;position:absolute;top:32px;left:13px}.stepper-item.done:not(:last-child):after{background:var(--accent-glow)}.stepper-dot{border:2px solid var(--border-color);width:26px;height:26px;color:var(--text-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:600;transition:all .3s;display:flex}.stepper-item.done .stepper-dot{background:var(--accent-glow);border-color:var(--accent);color:var(--accent)}.stepper-item.current .stepper-dot{background:var(--accent);border-color:var(--accent);color:#fff;animation:2s ease-in-out infinite pulse}.stepper-label{color:var(--text-muted);font-size:12px}.stepper-item.done .stepper-label{color:var(--text-secondary)}.stepper-item.current .stepper-label{color:var(--text-primary);font-weight:600}.sidebar-user{border-top:1px solid var(--border-color);align-items:center;gap:10px;padding:16px 20px;display:flex}.user-avatar{color:#fff;background:linear-gradient(135deg,#6c63ff,#ec4899);border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.user-info{flex:1}.user-name{color:var(--text-secondary);font-size:13px;font-weight:600}.user-role{color:var(--text-muted);align-items:center;gap:4px;font-size:10px;display:flex}.pro-badge{background:var(--accent-glow);color:var(--accent);letter-spacing:.5px;border-radius:4px;align-items:center;gap:3px;padding:2px 6px;font-size:9px;font-weight:700;display:inline-flex}.pro-badge:before{content:"";background:var(--accent);border-radius:50%;width:5px;height:5px;animation:2s ease-in-out infinite badgePulse}.sidebar-plan-box{margin-bottom:8px;padding:0 16px}.sidebar-plan-inner{background:var(--accent-surface);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:10px;padding:10px 14px;font-size:13px}.sidebar-plan-name{color:var(--text-primary);font-weight:600}.sidebar-bottom{padding:0 16px 16px}.sidebar-logout{border:1px solid var(--border-color);width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;padding:10px;font-family:Manrope,Inter,sans-serif;font-size:13px;transition:border-color .2s,color .2s}.sidebar-logout:hover{color:#ff6b6b;border-color:#ff64644d}.main-area{z-index:2;flex-direction:column;flex:1;min-height:100vh;display:flex;position:relative}.header{border-bottom:1px solid var(--border-color);background:var(--nav-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10;justify-content:space-between;align-items:center;height:60px;padding:0 28px;display:flex;position:sticky;top:0}.header-left{flex-direction:column;display:flex}.breadcrumbs{color:var(--text-muted);margin-bottom:2px;font-size:11px}.header-title{color:var(--text-primary);font-size:16px;font-weight:700}.header-title .gradient{background:linear-gradient(135deg,#6c63ff,#8b5cf6,#ec4899);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.header-right{align-items:center;gap:12px;display:flex}.model-badge{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:20px;align-items:center;gap:6px;padding:5px 12px;font-size:11px;font-weight:600;display:flex}.model-dot{background:#34d399;border-radius:50%;width:6px;height:6px}.btn-new{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6c63ff,#8b5cf6);border:none;border-radius:8px;padding:7px 14px;font-family:inherit;font-size:12px;font-weight:600;transition:opacity .2s}.btn-new:hover{opacity:.85}.content{flex-direction:column;flex:1;gap:20px;width:100%;max-width:960px;margin:0 auto;padding:24px 28px;display:flex}.stats-row{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:20px;animation:.5s backwards fadeUp;position:relative;overflow:hidden}.stat-card:before{content:"";background:radial-gradient(600px circle at var(--mx,50%) var(--my,50%), #6366f10f, transparent 40%);opacity:0;pointer-events:none;transition:opacity .4s;position:absolute;inset:0}.stat-card:hover:before{opacity:1}.stat-card:first-child{animation-delay:50ms}.stat-card:nth-child(2){animation-delay:.1s}.stat-card:nth-child(3){animation-delay:.15s}.stat-accent{border-radius:0 0 2px 2px;height:2px;position:absolute;top:0;left:20px;right:20px}.stat-accent--purple{background:linear-gradient(90deg,#6c63ff,#8b5cf6)}.stat-accent--blue{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.stat-accent--pink{background:linear-gradient(90deg,#ec4899,#f472b6)}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:11px;font-weight:600}.stat-value{color:var(--text-primary);align-items:center;gap:8px;font-size:28px;font-weight:800;display:flex}.stat-change{color:#34d399;background:#34d3991a;border-radius:6px;padding:2px 6px;font-size:11px;font-weight:600}.form-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;padding:28px;animation:.4s .1s backwards fadeUp;position:relative}.form-card:before{content:"";-webkit-mask-composite:xor;pointer-events:none;background:linear-gradient(135deg,#6c63ff33,#0000 40% 60%,#ec48991a);border-radius:21px;padding:1px;position:absolute;inset:-1px;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;-webkit-mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.form-card:after{content:"";background:radial-gradient(600px circle at var(--mx,50%) var(--my,50%), #6366f10a, transparent 40%);opacity:0;pointer-events:none;border-radius:20px;transition:opacity .4s;position:absolute;inset:0}.form-card:hover:after{opacity:1}.form-card h2{color:var(--text-primary);margin-bottom:20px;font-size:17px;font-weight:700}.form-card label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;margin-top:18px;margin-bottom:6px;font-size:10px;font-weight:600;display:block}.form-card label:first-of-type{margin-top:0}.req{color:#ec4899}.hint{color:var(--text-muted);margin-bottom:12px;font-size:12px}.form-card input[type=text],.form-card textarea,.form-card select{border:1px solid var(--border-color);background:var(--bg-card);width:100%;color:var(--text-primary);border-radius:10px;padding:11px 14px;font-family:inherit;font-size:14px;transition:all .2s}.form-card input::placeholder,.form-card textarea::placeholder{color:var(--text-muted)}.form-card select option{background:var(--bg-secondary);color:var(--text-primary)}.form-card input:focus,.form-card textarea:focus,.form-card select:focus{border-color:var(--accent-light);box-shadow:0 0 0 3px var(--accent-glow), 0 0 20px var(--accent-surface);outline:none}.form-card textarea{resize:vertical}.form-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.form-grid label{margin-top:0}.advantage-row{gap:8px;margin-bottom:8px;display:flex}.advantage-row input{flex:1}.btn-remove{border:1px solid var(--border-color);background:var(--bg-card);cursor:pointer;color:#ec4899;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;font-size:14px;transition:all .2s;display:flex}.btn-remove:hover{background:#ec48991a;border-color:#ec489933}.btn-add{border:1px dashed var(--border-color);cursor:pointer;width:100%;color:var(--text-muted);background:0 0;border-radius:10px;padding:11px;font-family:inherit;font-size:13px;transition:all .2s}.btn-add:hover{border-color:var(--accent-glow);color:var(--accent)}.drop-zone{border:2px dashed var(--border-color);text-align:center;cursor:pointer;color:var(--text-muted);border-radius:16px;padding:40px 20px;font-size:14px;transition:all .2s}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--accent-light);background:var(--accent-surface);color:var(--text-secondary)}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;margin-top:16px;display:grid}.photo-thumb{border:1px solid var(--border-color);border-radius:12px;position:relative;overflow:hidden}.photo-thumb img{aspect-ratio:1;object-fit:cover;width:100%;display:block}.photo-label{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--text-secondary);text-align:center;background:#06060fb3;padding:4px;font-size:10px;position:absolute;bottom:0;left:0;right:0}.photo-remove{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;cursor:pointer;background:#06060f99;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;display:flex;position:absolute;top:6px;right:6px}.photo-delete-btn{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;cursor:pointer;z-index:2;background:#0000008c;border:none;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:12px;transition:background .2s;display:flex;position:absolute;top:6px;right:6px}.photo-delete-btn:hover{background:#ef4444cc}.photo-parsed-badge{color:#fff;letter-spacing:.04em;z-index:2;background:#2b4fffb3;border-radius:4px;padding:2px 6px;font-size:9px;font-weight:700;position:absolute;bottom:28px;left:6px}.hero-photo-wrap{border:1px solid var(--border-color);border-radius:16px;display:inline-block;position:relative;overflow:hidden}.hero-photo-img{object-fit:contain;border-radius:16px;max-height:220px;display:block}.photo-replace-btn{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;cursor:pointer;z-index:2;background:#0000008c;border:none;border-radius:6px;padding:5px 12px;font-size:11px;font-weight:600;transition:background .2s;position:absolute;bottom:8px;right:8px}.photo-replace-btn:hover{background:var(--accent)}.photo-add-slot{border:2px dashed var(--border-color);cursor:pointer;aspect-ratio:1;flex-direction:column;justify-content:center;align-items:center;min-height:120px;transition:border-color .2s,background .2s;display:flex}.photo-add-slot:hover{border-color:var(--accent-light);background:var(--accent-surface)}.photo-add-icon{color:var(--text-muted);font-size:28px;line-height:1}.color-variant-row{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;align-items:center;gap:10px;margin-bottom:12px;padding:10px;display:flex}.color-variant-photo{border:2px dashed var(--border-color);background:var(--bg-card);cursor:pointer;width:72px;height:72px;color:var(--text-muted);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:22px;transition:all .15s;display:flex;overflow:hidden}.color-variant-photo:hover{border-color:var(--accent-light);background:var(--accent-surface)}.color-variant-photo img{object-fit:cover;border-radius:8px;width:100%;height:100%}.drop-zone.has-photo{border-style:solid;padding:10px}.template-options{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px;display:grid}.template-card{border:2px solid var(--border-color);cursor:pointer;text-align:center;background:var(--bg-card);border-radius:14px;padding:16px;transition:all .2s}.template-card:hover{border-color:var(--accent-glow)}.template-card.selected{border-color:var(--accent);background:var(--accent-surface)}.template-card input{display:none}.template-name{color:var(--text-secondary);margin-top:8px;font-size:13px;font-weight:600;display:block}.template-card.selected .template-name{color:var(--text-primary)}.template-preview{border-radius:8px;height:80px;margin-bottom:8px;overflow:hidden}.tp-header{height:30px}.tp-body{flex:1;padding:8px}.tp-line{border-radius:3px;width:80%;height:6px;margin-bottom:4px}.tp-line.short{width:50%}.tp-minimal .tp-header{background:var(--border-color)}.tp-minimal .tp-body{background:var(--bg-card)}.tp-minimal .tp-line{background:var(--border-color)}.tp-premium .tp-header{background:#1a1a2e}.tp-premium .tp-body{background:#d4a8530d}.tp-premium .tp-line{background:#d4a85333}.tp-standard .tp-header{background:var(--border-color)}.tp-standard .tp-body{background:var(--bg-card)}.tp-standard .tp-line{background:var(--border-color)}.template-blocks{color:var(--text-muted);margin-top:2px;font-size:10px;display:block}.photo-roles{flex-wrap:wrap;gap:6px;margin-bottom:14px;display:flex}.photo-role-tag{background:var(--accent-glow);color:var(--accent);border-radius:6px;padding:3px 8px;font-size:10px;font-weight:600}.btn-generate{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6c63ff,#8b5cf6);border:none;border-radius:12px;width:100%;padding:16px;font-family:inherit;font-size:15px;font-weight:700;transition:opacity .2s;position:relative;overflow:hidden}.btn-generate:before{content:"";background:linear-gradient(90deg,#0000,#ffffff26,#0000);width:40%;height:100%;animation:3s ease-in-out infinite shineMove;position:absolute;top:0}.btn-generate:hover:not(:disabled){opacity:.9}.btn-generate:disabled{opacity:.5;cursor:not-allowed}.step-nav{justify-content:space-between;gap:12px;display:flex}.btn-back,.btn-next{cursor:pointer;border-radius:10px;padding:10px 24px;font-family:inherit;font-size:13px;font-weight:600;transition:all .2s}.btn-back{color:var(--text-secondary);border:1px solid var(--border-color);background:0 0}.btn-back:hover{border-color:var(--text-muted);color:var(--text-primary)}.btn-next{color:#fff;background:linear-gradient(135deg,#6c63ff,#8b5cf6);border:none;margin-left:auto;position:relative;overflow:hidden}.btn-next:before{content:"";background:linear-gradient(90deg,#0000,#ffffff26,#0000);width:40%;height:100%;animation:3s ease-in-out infinite shineMove;position:absolute;top:0}.btn-next:hover:not(:disabled){opacity:.9}.btn-next:disabled{opacity:.4;cursor:not-allowed}.loader-wrapper{justify-content:center;align-items:center;gap:8px;display:flex}.spinner{border:2px solid #fff3;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spinSimple;display:inline-block}.error-msg{color:#f472b6;background:#ec489914;border:1px solid #ec489926;border-radius:12px;padding:14px 18px;font-size:13px;animation:.3s fadeUp}.result-container{animation:.4s fadeUp}.download-bar{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;margin-bottom:20px;display:flex}.btn-download-zip{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6c63ff,#8b5cf6);border:none;border-radius:10px;padding:11px 28px;font-size:14px;font-weight:700;text-decoration:none;transition:opacity .2s;display:inline-block}.btn-download-zip:hover{opacity:.85}.download-singles{flex-wrap:wrap;gap:6px;display:flex}.btn-download-single{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;border-radius:8px;padding:8px 14px;font-size:12px;font-weight:500;text-decoration:none;transition:all .15s;display:inline-block}.btn-download-single:hover{background:var(--bg-card-hover);color:var(--text-primary)}.banner-strip{max-width:780px;box-shadow:var(--card-shadow);background:#fff;border-radius:16px;margin:0 auto;overflow:hidden}.banner-strip img{width:100%;display:block}.gen-text-details{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;max-width:780px;margin:20px auto 0;padding:14px 18px}.gen-text-details summary{cursor:pointer;color:var(--text-secondary);font-size:13px;font-weight:600;list-style:none}.gen-text-details summary:hover{color:var(--text-primary)}.gen-text-details summary::-webkit-details-marker{display:none}.gen-text-content{border-top:1px solid var(--border-color);color:var(--text-secondary);margin-top:14px;padding-top:14px;font-size:13px;line-height:1.8}.gen-text-content strong{color:var(--text-primary)}.gen-text-content ul{margin:4px 0 8px 20px}.btn-new-card{border:1px solid var(--border-color);width:100%;max-width:780px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:10px;margin:20px auto 0;padding:13px;font-size:14px;font-weight:600;transition:all .15s;display:block}.btn-new-card:hover{border-color:var(--accent-glow);color:var(--accent);background:var(--accent-surface)}.download-single:hover{background:var(--accent-glow)}.my-cards{animation:.4s fadeUp}.my-cards h2{color:var(--text-primary);margin-bottom:16px;font-size:17px;font-weight:700}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;display:grid}.saved-card{background:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;border-radius:14px;transition:all .2s;animation:.4s backwards fadeUp;position:relative;overflow:hidden}.saved-card:before{content:"";background:radial-gradient(400px circle at var(--mx,50%) var(--my,50%), #6366f10f, transparent 40%);opacity:0;pointer-events:none;transition:opacity .4s;position:absolute;inset:0}.saved-card:hover{border-color:var(--accent-glow)}.saved-card:hover:before{opacity:1}.saved-card-img{aspect-ratio:16/10;object-fit:cover;border-bottom:1px solid var(--border-color);width:100%;display:block}.saved-card-body{padding:14px}.saved-card-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:13px;font-weight:600;overflow:hidden}.saved-card-meta{color:var(--text-muted);justify-content:space-between;font-size:11px;display:flex}.empty-state{text-align:center;color:var(--text-muted);padding:48px 20px;font-size:14px}.placeholder-page{background:var(--bg-card);border:1px solid var(--border-color);text-align:center;border-radius:20px;padding:48px 28px}.placeholder-page h2{color:var(--text-primary);margin-bottom:12px}.placeholder-page p{color:var(--text-muted)}.progress-bar{display:none}@media (width<=1199px){.sidebar{width:210px}.sidebar-stepper,.sidebar-user{display:none}}@media (width<=767px){html,body{overflow-x:hidden}.app{flex-direction:column;overflow:visible}.sidebar{display:none!important}.mobile-nav{background:var(--nav-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);z-index:100;gap:0;display:flex;position:sticky;top:0}.mobile-nav button{color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;min-height:48px;padding:14px 8px;font-family:inherit;font-size:12px;font-weight:600}.mobile-nav button.active{color:var(--accent);border-bottom-color:var(--accent)}.main-area{width:100%;min-width:0}.header{flex-wrap:wrap;gap:4px;height:auto;padding:10px 16px}.header-title{font-size:16px!important}.breadcrumbs{font-size:10px}.header-right{display:none}.content{gap:14px;min-width:0;padding:12px 16px}.stats-row{display:none}.form-card{border-radius:14px;padding:18px 14px}.form-card h2{margin-bottom:14px;font-size:15px}.form-card label{margin-top:14px;font-size:10px}.form-grid{grid-template-columns:1fr;gap:0}.form-card input[type=text],.form-card textarea,.form-card select{border-radius:8px;padding:12px;font-size:16px}.advantage-row input{font-size:16px}.btn-remove{width:44px;height:44px}.template-options{grid-template-columns:1fr;gap:10px}.drop-zone{min-height:100px;padding:24px 14px}.photo-grid{grid-template-columns:1fr 1fr;gap:8px}.step-nav{gap:8px}.btn-back,.btn-next{min-height:44px;padding:12px 16px;font-size:14px}.btn-next{text-align:center;flex:1}.btn-generate{min-height:48px;font-size:14px}.banner-strip{border-radius:10px;max-width:100%}.download-bar{flex-direction:column;gap:8px;margin-bottom:14px}.btn-download-zip{text-align:center;width:100%;min-height:48px;padding:14px}.download-singles{grid-template-columns:1fr 1fr;gap:6px;width:100%;display:grid}.btn-download-single{text-align:center;justify-content:center;align-items:center;min-height:44px;padding:10px 8px;font-size:11px;display:flex}.gen-text-details{margin:14px 0 0;padding:12px 14px}.btn-new-card{min-height:44px;margin:14px 0 0}.cards-grid{grid-template-columns:1fr;gap:10px}.saved-card-body{padding:10px 12px}.aurora-orb{opacity:.2}}@media (width>=768px){.mobile-nav{display:none}}.import-card{border:1px dashed var(--border-color);background:var(--bg-card);margin-bottom:16px}.import-card h3{color:var(--text-primary);margin-bottom:12px;font-size:15px}.import-row{gap:8px;display:flex}.import-row input{flex:1}.btn-import{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:8px;padding:10px 20px;font-weight:500;transition:opacity .2s}.btn-import:hover{opacity:.9}.btn-import:disabled{opacity:.5;cursor:not-allowed}.import-status{border-radius:8px;align-items:center;gap:8px;margin-top:10px;padding:8px 12px;font-size:13px;display:flex}.import-status.loading{color:#a5b4fc;background:#6366f11a}.import-status.success{color:#86efac;background:#22c55e1a}.import-status.error{color:#fca5a5;background:#ef44441a}.import-status.success{justify-content:space-between}.btn-download-photos{background:var(--bg-card);color:#86efac;white-space:nowrap;border:1px solid #86efac4d;border-radius:6px;padding:4px 12px;font-size:12px;text-decoration:none;transition:background .2s}.btn-download-photos:hover{background:var(--bg-card-hover)}.landing{--bg:var(--bg-primary);--bg-alt:var(--bg-secondary);--surface:var(--bg-card);--surface-hover:var(--bg-card-hover);--border:var(--border-color);--border-strong:var(--border-strong);--text:var(--text-primary);--text-secondary:var(--text-secondary);--text-muted:var(--text-muted);--blue:var(--accent);--blue-light:var(--accent-light);--blue-glow:var(--accent-glow);--blue-surface:var(--accent-surface);--white:var(--text-primary);--display:"Unbounded", system-ui, sans-serif;--body:"Manrope", system-ui, sans-serif;--ease-expo:cubic-bezier(.16, 1, .3, 1);--container:1200px;background:var(--bg);color:var(--text);font-family:var(--body);-webkit-font-smoothing:antialiased;max-width:100vw;font-size:16px;line-height:1.65;overflow-x:hidden}.landing *,.landing :before,.landing :after{box-sizing:border-box;margin:0;padding:0}.dot-grid{background-image:radial-gradient(circle, var(--accent-glow) 1px, transparent 1px);pointer-events:none;z-index:1;background-size:32px 32px;position:absolute;inset:0}.ln-container{max-width:var(--container);margin:0 auto;padding:0 32px}.fade-section{opacity:0;transition:opacity .8s var(--ease-expo), transform .8s var(--ease-expo);transform:translateY(40px)}.fade-section.is-visible{opacity:1;transform:translateY(0)}@keyframes float-y{0%,to{transform:translateY(0)}50%{transform:translateY(-18px)}}@keyframes rotate-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse-ring{0%{opacity:.6;transform:scale(1)}to{opacity:0;transform:scale(1.5)}}@keyframes marquee-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes hero-glow-pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}@media (prefers-reduced-motion:reduce){.fade-section{opacity:1;transition:none;transform:none}.marquee-track,.hero-globe-wrap,.banner-3d-card{animation:none!important}}.ln-nav{z-index:100;border-bottom:1px solid #0000;padding:20px 0;transition:background .4s,-webkit-backdrop-filter .4s,backdrop-filter .4s,padding .4s;position:fixed;top:0;left:0;right:0}.ln-nav.scrolled{background:var(--nav-bg);-webkit-backdrop-filter:blur(24px);border-bottom-color:var(--border);padding:12px 0}.ln-nav-inner{max-width:var(--container);justify-content:space-between;align-items:center;margin:0 auto;padding:0 32px;display:flex}.ln-logo{font-family:var(--display);letter-spacing:-.02em;color:var(--white);font-size:20px;font-weight:800;text-decoration:none}.ln-logo-mark{color:var(--blue-light)}.ln-nav-links{gap:36px;display:flex}.ln-nav-links a{color:var(--text-muted);letter-spacing:.02em;font-size:14px;font-weight:500;text-decoration:none;transition:color .2s}.ln-nav-links a:hover{color:var(--text)}.ln-nav-auth{flex-shrink:0;gap:8px;display:flex}.ln-btn{font-family:var(--body);cursor:pointer;transition:transform .25s var(--ease-expo), background .2s, box-shadow .3s;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:12px 28px;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex}.ln-btn:hover{transform:translateY(-2px)}.ln-btn-primary{background:var(--blue);color:#fff;box-shadow:0 4px 30px var(--blue-glow)}.ln-btn-primary:hover{background:var(--blue-light);box-shadow:0 8px 40px var(--blue-glow)}.ln-btn-ghost{color:var(--text-secondary);border:1px solid var(--border-strong);background:0 0}.ln-btn-ghost:hover{border-color:var(--blue-light);color:var(--text)}.ln-btn-sm{padding:9px 20px;font-size:13px}.ln-btn-full{width:100%}.ln-btn-lg{border-radius:10px;padding:16px 40px;font-size:16px}.ln-hero{background:var(--bg);align-items:center;min-height:100vh;padding:120px 0 80px;display:flex;position:relative;overflow:hidden}.hero-glow{pointer-events:none;background:radial-gradient(circle,#2b4fff33 0%,#0000 70%);border-radius:50%;width:900px;height:900px;animation:6s ease-in-out infinite hero-glow-pulse;position:absolute;top:50%;right:-100px;transform:translateY(-50%)}.hero-inner{max-width:var(--container);z-index:2;grid-template-columns:1fr 520px;align-items:center;gap:40px;width:100%;margin:0 auto;padding:0 32px;display:grid;position:relative}.hero-content{position:relative}.hero-badge{background:var(--blue-surface);border:1px solid var(--border);color:var(--blue-light);letter-spacing:.06em;text-transform:uppercase;border-radius:999px;align-items:center;gap:8px;margin-bottom:32px;padding:6px 18px;font-size:12px;font-weight:600;display:inline-flex}.badge-dot{background:#22c55e;border-radius:50%;width:6px;height:6px;box-shadow:0 0 8px #22c55e99}.hero-title{font-family:var(--display);letter-spacing:-.04em;text-transform:uppercase;color:var(--white);margin-bottom:28px;font-size:clamp(44px,6vw,76px);font-weight:900;line-height:1}.hero-title-accent{color:var(--blue-light)}.hero-sub{color:var(--text-secondary);max-width:460px;margin-bottom:44px;font-size:clamp(16px,1.8vw,19px);line-height:1.7}.hero-buttons{flex-wrap:wrap;gap:16px;display:flex}.hero-stars{pointer-events:none;z-index:0;opacity:var(--star-opacity);position:absolute;inset:0}.hero-stars:before{content:"";background:#fff;border-radius:50%;width:1px;height:1px;position:absolute;box-shadow:42px 120px #fff6,180px 80px #ffffff40,320px 200px #ffffff80,90px 340px #fff3,510px 50px #ffffff73,640px 280px #ffffff4d,770px 120px #ffffff59,900px 350px #ffffff40,1020px 180px #ffffff80,1150px 90px #fff3,60px 500px #ffffff59,250px 600px #ffffff40,400px 450px #fff6,580px 550px #ffffff26,720px 480px #fff6,870px 600px #ffffff4d,1000px 500px #ffffff40,1120px 420px #ffffff73,150px 750px #ffffff4d,350px 700px #ffffff59,550px 780px #fff3,750px 720px #fff6,950px 760px #ffffff40,1100px 680px #ffffff59,30px 850px #fff6,200px 880px #ffffff40,480px 830px #ffffff59,680px 870px #fff3,1250px 140px #ffffff4d,1300px 400px #fff3,1380px 250px #fff6,1420px 550px #ffffff40,1200px 750px #ffffff4d,1350px 680px #fff3,1100px 850px #ffffff59,1440px 100px #ffffff4d,110px 40px #ffffff40,430px 30px #ffffff4d,800px 20px #fff3,1050px 60px #ffffff59,270px 150px #fff3,660px 170px #ffffff4d,530px 380px #ffffff26,340px 490px #ffffff40,810px 430px #fff3,1080px 370px #ffffff4d}.hero-stars:after{content:"";background:#fff;border-radius:50%;width:2px;height:2px;position:absolute;box-shadow:120px 160px #ffffffb3,450px 100px #ffffff80,700px 320px #fff9,290px 420px #fff6,830px 220px #ffffff8c,1060px 300px #ffffff73,170px 580px #ffffff8c,500px 650px #fff6,860px 550px #ffffff80,1180px 600px #ffffff59,80px 720px #ffffff80,620px 800px #ffffff73,980px 830px #ffffff59,380px 900px #ffffff8c,1140px 150px #fff6,50px 280px #ffffff80,1300px 320px #ffffff73,1400px 500px #fff6,1250px 700px #ffffff59,240px 50px #ffffff80,730px 80px #fff6,1100px 40px #ffffff73}.hero-globe-wrap{flex-shrink:0;width:520px;height:520px;animation:8s ease-in-out infinite float-y;position:relative}.earth-container{width:100%;height:100%;position:relative}.earth-atmosphere{display:none}.earth-sphere{z-index:2;filter:var(--globe-filter);border-radius:50%;position:absolute;inset:0;overflow:hidden}.earth-map{background:url(/photos/earth-night.jpg) 0 0/50% 100% repeat-x;width:200%;height:100%;animation:25s linear infinite rotate-earth;position:absolute;top:0;left:0}@keyframes rotate-earth{0%{transform:translate(0)}to{transform:translate(-50%)}}.earth-shadow{background: radial-gradient(circle at 22% 20%, #c8dcff33 0%, transparent 25%),  radial-gradient(circle at 28% 30%, #78aaff1a 0%, transparent 45%),  radial-gradient(circle at 80% 60%, #000008eb 0%, #00000880 35%, transparent 60%),  radial-gradient(circle at 50% 50%, transparent 44%, #06061499 60%, var(--bg-primary) 70%);z-index:4;pointer-events:none;border-radius:50%;position:absolute;inset:0}.earth-sun{z-index:5;pointer-events:none;filter:blur(4px);background:radial-gradient(circle,#fffff0e6 0%,#fff0c880 15%,#c8dcff33 35%,#0000 60%);border-radius:50%;width:120px;height:120px;position:absolute;top:-30px;left:-30px}.earth-sun:after{content:"";filter:blur(1px);background:linear-gradient(90deg,#0000 0%,#c8dcff4d 30%,#fffff080 50%,#c8dcff4d 70%,#0000 100%);width:200px;height:2px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotate(-35deg)}.earth-pin{z-index:3;pointer-events:none;align-items:center;gap:4px;display:flex;position:absolute;transform:translate(-50%,-50%)}.pin-dot{background:#82aaffcc;border-radius:50%;flex-shrink:0;width:4px;height:4px;box-shadow:0 0 4px #6496ff99}.earth-pin-primary .pin-dot{background:var(--blue-light);width:7px;height:7px;box-shadow:0 0 8px var(--blue-glow), 0 0 16px var(--blue-glow)}.pin-ring{border:1.5px solid #4d6fff80;border-radius:50%;width:18px;height:18px;animation:2.5s ease-out infinite pulse-ring;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.pin-label{letter-spacing:.08em;text-transform:uppercase;color:#a0beffcc;white-space:nowrap;text-shadow:0 0 6px #00001ee6,0 0 3px #000014;font-size:7px;font-weight:700}.earth-pin-primary .pin-label{color:var(--blue-light);text-shadow:0 0 8px #2b4fff80,0 0 3px #000014;font-size:9px}.marquee-wrap{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg-alt);padding:28px 0;overflow:hidden}.marquee-track{width:max-content;animation:40s linear infinite marquee-scroll;display:flex}.marquee-content{font-family:var(--display);text-transform:uppercase;color:#0000;-webkit-text-stroke:1px #6482ff33;white-space:nowrap;-webkit-user-select:none;user-select:none;letter-spacing:-.02em;padding-right:32px;font-size:clamp(32px,5vw,56px);font-weight:800}.ln-stats{padding:80px 0;position:relative}.stats-grid{grid-template-columns:repeat(4,1fr);gap:0;display:grid}.stat-item{text-align:center;padding:40px 20px;position:relative}.stat-item+.stat-item:before{content:"";background:var(--border);width:1px;position:absolute;top:20%;bottom:20%;left:0}.stat-value{font-family:var(--display);color:var(--white);letter-spacing:-.03em;margin-bottom:12px;font-size:clamp(40px,5.5vw,64px);font-weight:900;line-height:1}.stat-prefix{color:var(--blue-light)}.stat-suffix{color:var(--blue-light);font-size:.6em}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:14px;font-weight:500}.ln-features{padding:120px 0 100px;position:relative}.section-header{margin-bottom:64px}.section-label{font-family:var(--display);letter-spacing:.18em;text-transform:uppercase;color:var(--blue-light);margin-bottom:20px;font-size:12px;font-weight:700}.section-title{font-family:var(--display);letter-spacing:-.03em;text-transform:uppercase;color:var(--white);font-size:clamp(32px,4.5vw,52px);font-weight:900;line-height:1.05}.bento-grid{grid-template-columns:repeat(3,1fr);grid-auto-rows:minmax(200px,auto);gap:14px;display:grid}.bento-card{background:var(--surface);border:1px solid var(--border);transition:border-color .3s, transform .4s var(--ease-expo), box-shadow .4s;border-radius:18px;flex-direction:column;justify-content:flex-end;min-height:200px;padding:32px;display:flex;position:relative;overflow:hidden}.bento-card:hover{border-color:var(--border-strong);transform:translateY(-6px);box-shadow:0 16px 48px #2b4fff1f,0 0 0 1px #2b4fff14}.bento-wide{grid-column:span 2}.bento-card-wide{min-height:260px}.bento-content{z-index:2;position:relative}.bento-emoji{filter:saturate(.85);margin-bottom:16px;font-size:36px;line-height:1}.bento-card h3{font-family:var(--display);letter-spacing:-.01em;margin-bottom:10px;font-size:18px;font-weight:700}.bento-card-wide h3{font-size:22px}.bento-card p{color:var(--text-secondary);max-width:380px;font-size:15px;line-height:1.7}.bento-photo{object-fit:cover;opacity:.22;border-radius:0 18px 18px 0;width:42%;height:100%;transition:opacity .4s;position:absolute;top:0;right:0;-webkit-mask-image:linear-gradient(270deg,#000000b3 0%,#0000 85%);mask-image:linear-gradient(270deg,#000000b3 0%,#0000 85%)}.bento-card:hover .bento-photo{opacity:.32}.bento-accent-templates{z-index:2;gap:6px;margin-top:16px;display:flex;position:relative}.template-mini{opacity:.7;width:32px;height:42px;transition:opacity .2s, transform .3s var(--ease-expo);border-radius:4px}.bento-card:hover .template-mini{opacity:1;transform:translateY(-3px)}.bento-accent-translate{z-index:2;align-items:center;gap:12px;margin-top:16px;display:flex;position:relative}.translate-from{color:var(--text-muted);border:1px solid var(--border);background:#ffffff0a;border-radius:6px;padding:6px 12px;font-size:16px;font-weight:700}.translate-arrow{color:var(--blue-light);font-size:20px;animation:2s ease-in-out infinite arrow-pulse}@keyframes arrow-pulse{0%,to{opacity:.5;transform:translate(0)}50%{opacity:1;transform:translate(3px)}}.translate-to{color:var(--blue-light);background:#2b4fff14;border:1px solid #2b4fff33;border-radius:6px;padding:6px 12px;font-size:16px;font-weight:700}.bento-accent-ruler{z-index:2;margin-top:16px;position:relative}.ruler-banner{border:1px dashed var(--border-strong);background:#2b4fff08;border-radius:6px;width:100%;max-width:160px;height:80px;position:relative}.ruler-dim{font-size:10px;font-weight:700;font-family:var(--display);color:var(--blue-light);letter-spacing:.05em;position:absolute;top:-18px;left:50%;transform:translate(-50%)}.ruler-dim-h{font-size:9px;font-weight:700;font-family:var(--display);color:var(--text-muted);letter-spacing:.05em;position:absolute;top:50%;right:-42px;transform:translateY(-50%)}.ruler-line-top{background:var(--blue-light);height:1px;position:absolute;top:-8px;left:0;right:0}.ruler-line-top:before,.ruler-line-top:after{content:"";background:var(--blue-light);width:1px;height:7px;position:absolute;top:-3px}.ruler-line-top:before{left:0}.ruler-line-top:after{right:0}.ruler-line-side{background:var(--text-muted);width:1px;position:absolute;top:0;bottom:0;right:-8px}.bento-accent-edit{z-index:2;font-family:var(--body);margin-top:16px;position:relative}.edit-line{color:var(--text);border:1px solid var(--border);background:#ffffff08;border-radius:6px;align-items:center;gap:2px;margin-bottom:4px;padding:6px 10px;font-size:14px;font-weight:600;display:flex}.edit-line-dim{color:var(--text-muted);font-size:13px;font-weight:400}.edit-cursor{background:var(--blue-light);border-radius:1px;flex-shrink:0;width:2px;height:16px;animation:1s step-end infinite cursor-blink}@keyframes cursor-blink{0%,to{opacity:1}50%{opacity:0}}.ln-showcase{padding:120px 0;position:relative;overflow:hidden}.showcase-inner{grid-template-columns:1fr 1fr;align-items:center;gap:80px;display:grid;overflow:hidden}.showcase-text h2{font-family:var(--display);text-transform:uppercase;letter-spacing:-.03em;overflow-wrap:break-word;margin-bottom:24px;font-size:clamp(22px,3.5vw,44px);font-weight:900;line-height:1.1}.showcase-text p{color:var(--text-secondary);max-width:420px;margin-bottom:36px;font-size:16px;line-height:1.7}.banner-3d-scene{perspective:1000px;justify-content:center;align-items:center;max-width:100%;padding:40px;display:flex;position:relative}.banner-3d-card{background:var(--surface);border:1px solid var(--border-strong);width:100%;max-width:380px;transform-style:preserve-3d;will-change:transform, box-shadow;z-index:2;border-radius:16px;animation:6s ease-in-out infinite float-y;position:relative;overflow:hidden;box-shadow:0 40px 80px #00000080,0 0 60px #2b4fff1f}.banner-3d-card.is-hover{animation:none}.banner-3d-sheen{z-index:10;pointer-events:none;opacity:0;border-radius:16px;transition:opacity .3s;position:absolute;inset:0}.banner-3d-card.is-hover .banner-3d-sheen{opacity:1}.banner-3d-glow{filter:blur(40px);pointer-events:none;z-index:1;opacity:.5;background:radial-gradient(circle,#2b4fff33 0%,#0000 70%);border-radius:50%;transition:opacity .4s;position:absolute;inset:-60px}.banner-3d-scene:hover .banner-3d-glow{opacity:1}.banner-3d-header{background:var(--blue);font-family:var(--display);letter-spacing:.12em;text-transform:uppercase;color:#fff;justify-content:space-between;align-items:center;padding:16px 20px;font-size:11px;font-weight:700;display:flex}.banner-3d-dots{gap:5px;display:flex}.banner-3d-dots span{background:#ffffff4d;border-radius:50%;width:8px;height:8px}.banner-3d-body{padding:0;position:relative}.banner-3d-body img{width:100%;display:block}.banner-3d-overlay{background:linear-gradient(to top, var(--bg-card) 0%, transparent 100%);padding:20px;position:absolute;bottom:0;left:0;right:0}.banner-3d-overlay h4{font-family:var(--display);margin-bottom:4px;font-size:14px;font-weight:700}.banner-3d-overlay span{color:var(--text-muted);font-size:12px}.banner-3d-footer{border-top:1px solid var(--border);gap:8px;padding:16px 20px;display:flex}.banner-3d-tag{background:var(--blue-surface);color:var(--blue-light);border:1px solid var(--border);letter-spacing:.04em;border-radius:4px;padding:4px 10px;font-size:10px;font-weight:600}.banner-3d-glow{pointer-events:none;filter:blur(40px);background:radial-gradient(circle,#2b4fff40 0%,#0000 70%);border-radius:50%;width:300px;height:300px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.ln-steps{background:var(--bg-alt);padding:120px 0;position:relative}.ln-steps:before{content:"";opacity:.04;pointer-events:none;background:url(/photos/bg-steps.jpg) 50%/cover no-repeat;position:absolute;inset:0}.steps-row{grid-template-columns:repeat(3,1fr);gap:24px;display:grid;position:relative}.step-card{text-align:center;background:var(--surface);border:1px solid var(--border);transition:border-color .3s, transform .4s var(--ease-expo);border-radius:16px;padding:48px 28px;position:relative}.step-card:hover{border-color:var(--border-strong);transform:translateY(-4px)}.step-num{font-family:var(--display);color:var(--blue);opacity:.6;margin-bottom:24px;font-size:56px;font-weight:900;line-height:1}.step-card h3{font-family:var(--display);text-transform:uppercase;letter-spacing:-.01em;margin-bottom:12px;font-size:18px;font-weight:700}.step-card p{color:var(--text-secondary);font-size:14px;line-height:1.7}.step-connector{background:var(--border);z-index:0;width:calc(100% - 60px);height:1px;position:absolute;top:50%;left:30px;transform:translateY(-20px)}.ln-pricing{padding:120px 0 100px;position:relative}.pricing-grid{grid-template-columns:repeat(3,1fr);align-items:start;gap:16px;display:grid}.price-card{background:var(--surface);border:1px solid var(--border);transition:border-color .3s, transform .4s var(--ease-expo);border-radius:16px;padding:40px 28px;position:relative}.price-card:hover{transform:translateY(-4px)}.price-card.popular{border-color:var(--blue);box-shadow:0 0 60px #2b4fff1f}.popular-badge{background:var(--blue);color:#fff;font-family:var(--display);letter-spacing:.08em;text-transform:uppercase;border-radius:999px;padding:5px 18px;font-size:11px;font-weight:700;position:absolute;top:-12px;left:50%;transform:translate(-50%)}.price-name{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:16px;font-size:14px;font-weight:600}.price-amount{font-family:var(--display);letter-spacing:-.03em;color:var(--white);margin-bottom:8px;font-size:40px;font-weight:900;line-height:1}.price-period{font-family:var(--body);color:var(--text-muted);font-size:14px;font-weight:400}.price-note{color:var(--text-muted);border-bottom:1px solid var(--border);margin-bottom:28px;padding-bottom:24px;font-size:13px}.price-card ul{margin-bottom:28px;list-style:none}.price-card li{color:var(--text-secondary);align-items:flex-start;gap:10px;padding:8px 0;font-size:14px;display:flex}.price-check{width:16px;height:16px;color:var(--blue-light);flex-shrink:0;margin-top:2px}.pricing-note-single{text-align:center;color:var(--text-secondary);background:var(--blue-surface);border:1px solid var(--border);border-radius:12px;max-width:520px;margin-top:32px;margin-left:auto;margin-right:auto;padding:18px 24px;font-size:15px;font-weight:500}.ln-reviews{background:var(--bg-alt);padding:100px 0;position:relative}.ln-reviews:before{content:"";opacity:.035;pointer-events:none;background:url(/photos/bg-reviews.jpg) 50%/cover no-repeat;position:absolute;inset:0}.reviews-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.review-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;padding:32px 28px;transition:border-color .3s;display:flex}.review-card:hover{border-color:var(--border-strong)}.review-stars{color:#fbbf24;letter-spacing:3px;margin-bottom:18px;font-size:14px}.review-text{color:var(--text-secondary);flex:1;margin-bottom:24px;font-size:15px;line-height:1.75}.review-author{border-top:1px solid var(--border);align-items:center;gap:12px;padding-top:18px;display:flex}.review-avatar{background:var(--blue-surface);border:1px solid var(--border);width:36px;height:36px;color:var(--blue-light);border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.review-name{font-size:14px;font-weight:600}.review-role{color:var(--text-muted);margin-top:2px;font-size:12px}.ln-cta{padding:80px 0}.cta-inner{text-align:center;border:1px solid var(--blue);background:radial-gradient(#2b4fff14 0%,#0000 70%);border-radius:24px;padding:80px 40px;position:relative;overflow:hidden}.cta-inner:before{content:"";opacity:.04;pointer-events:none;background:url(/photos/bg-cta.jpg) 50%/cover no-repeat;border-radius:24px;position:absolute;inset:0}.cta-inner h2{font-family:var(--display);text-transform:uppercase;letter-spacing:-.02em;margin-bottom:16px;font-size:clamp(28px,4vw,44px);font-weight:900;position:relative}.cta-inner p{color:var(--text-secondary);margin-bottom:40px;font-size:17px;position:relative}.ln-faq{padding:100px 0 120px}.faq-layout{grid-template-columns:1fr 340px;align-items:start;gap:60px;display:grid}.faq-list{max-width:none}.faq-sidebar{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px;position:sticky;top:120px}.faq-sidebar-label{font-family:var(--display);letter-spacing:.14em;text-transform:uppercase;color:var(--blue-light);margin-bottom:16px;font-size:11px;font-weight:700}.faq-sidebar h3{font-family:var(--display);margin-bottom:12px;font-size:20px;font-weight:800;line-height:1.2}.faq-sidebar p{color:var(--text-secondary);margin-bottom:24px;font-size:14px;line-height:1.7}.faq-sidebar-stats{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px;display:grid}.faq-stat{text-align:center;background:var(--blue-surface);border:1px solid var(--border);border-radius:10px;padding:16px 8px}.faq-stat-val{font-family:var(--display);color:var(--white);margin-bottom:4px;font-size:22px;font-weight:800;line-height:1}.faq-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:10px}.faq-item{border-bottom:1px solid var(--border);cursor:pointer}.faq-item:first-child{border-top:1px solid var(--border)}.faq-q{color:var(--text);justify-content:space-between;align-items:center;padding:22px 0;font-size:15px;font-weight:600;transition:color .2s;display:flex}.faq-q:hover{color:var(--blue-light)}.faq-chevron{width:18px;height:18px;color:var(--text-muted);transition:transform .3s var(--ease-expo);flex-shrink:0}.faq-item.open .faq-chevron{transform:rotate(180deg)}.faq-a{transition:grid-template-rows .35s var(--ease-expo);grid-template-rows:0fr;display:grid;overflow:hidden}.faq-item.open .faq-a{grid-template-rows:1fr}.faq-a-inner{overflow:hidden}.faq-a p{color:var(--text-secondary);max-width:560px;padding:0 0 22px;font-size:14px;line-height:1.75}.ln-footer{border-top:1px solid var(--border);padding:56px 0 32px}.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px;display:grid}.footer-brand p{color:var(--text-muted);max-width:280px;margin-top:14px;font-size:13px;line-height:1.65}.footer-col h4{color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;margin-bottom:16px;font-size:11px;font-weight:700}.footer-col a{color:var(--text-muted);padding:4px 0;font-size:14px;text-decoration:none;transition:color .2s;display:block}.footer-col a:hover{color:var(--text)}.footer-bottom{border-top:1px solid var(--border);color:var(--text-muted);justify-content:space-between;align-items:center;padding-top:24px;font-size:12px;display:flex}.footer-legal{border-top:1px solid var(--border);color:var(--text-muted);margin-top:24px;padding-top:20px;font-size:11px;line-height:1.7}@media (width<=1100px){.hero-inner{grid-template-columns:1fr 400px;gap:24px}.hero-globe-wrap{width:400px;height:400px}.ln-container{padding:0 20px}}@media (width<=960px){.hero-inner{text-align:center;grid-template-columns:1fr}.hero-content{text-align:center}.hero-sub{margin-left:auto;margin-right:auto}.hero-buttons{justify-content:center}.hero-globe-wrap{width:360px;height:360px;margin:0 auto}.hero-glow{width:500px;height:500px;right:-150px}.ln-hero{min-height:auto;padding-top:100px;padding-bottom:40px}.ln-nav-links{display:none}.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-item+.stat-item:before{display:none}.stat-item{padding:28px 16px}.bento-grid{grid-template-columns:1fr 1fr}.bento-wide{grid-column:span 2}.ln-showcase .showcase-inner{grid-template-columns:1fr;gap:32px}.ln-showcase .showcase-text{text-align:center;flex-direction:column;align-items:center;display:flex}.ln-showcase .showcase-text p{margin-left:auto;margin-right:auto}.ln-showcase .showcase-text h2,.ln-showcase .showcase-text .section-label{text-align:center}.ln-showcase .banner-3d-scene{perspective:none;justify-content:center;width:100%;padding:20px}.ln-showcase .banner-3d-card{max-width:320px;margin:0 auto;animation:none!important;transform:none!important;box-shadow:0 20px 40px #0006!important}.ln-showcase .banner-3d-glow,.ln-showcase .banner-3d-sheen{display:none}.steps-row{gap:12px}.step-connector{display:none}.step-card{padding:32px 16px}.pricing-grid{gap:12px}.price-card{padding:28px 20px}.reviews-grid{grid-template-columns:1fr;max-width:500px;margin:0 auto}.faq-layout{grid-template-columns:1fr;gap:32px}.faq-sidebar{position:static}.ln-features,.ln-pricing{padding:80px 0 60px}.ln-steps,.ln-reviews,.ln-showcase{padding:80px 0}.footer-grid{grid-template-columns:1fr 1fr;gap:28px}.footer-bottom{text-align:center;flex-direction:column;gap:8px}}@media (width<=680px){.bento-grid{grid-template-columns:1fr}.bento-wide{grid-column:span 1}.steps-row{grid-template-columns:1fr;gap:16px;max-width:360px;margin:0 auto}.pricing-grid{grid-template-columns:1fr;max-width:380px;margin:0 auto}.hero-globe-wrap{width:300px;height:300px}.banner-3d-card{max-width:280px}.section-label,.section-title{text-align:center}.section-desc{text-align:center;margin-left:auto;margin-right:auto}}@media (width<=480px){.ln-container{padding:0 16px}.hero-title{font-size:32px}.hero-globe-wrap{width:260px;height:260px}.hero-buttons{flex-direction:column}.hero-buttons .ln-btn{width:100%}.hero-badge{padding:5px 14px;font-size:10px}.ln-hero{padding-top:90px}.stat-value{font-size:28px}.stat-label{font-size:11px}.section-title{font-size:24px}.bento-card{min-height:160px;padding:24px}.step-num{font-size:40px}.cta-inner{padding:48px 20px}.cta-inner h2{font-size:24px}.banner-3d-card{max-width:240px}.ln-showcase{padding:60px 0}.price-amount{font-size:32px}.popular-badge{padding:4px 12px;font-size:9px}.footer-grid{grid-template-columns:1fr}.marquee-content{font-size:28px}.ln-nav-inner{padding:0 16px}.ln-btn-sm{padding:7px 12px;font-size:11px}.ln-nav-auth{gap:6px}.ln-logo{font-size:16px}.faq-q{padding:18px 0;font-size:14px}}@media (width<=360px){.hero-title{font-size:26px}.hero-globe-wrap{width:220px;height:220px}.stat-value{font-size:24px}.section-title{font-size:22px}.price-amount{font-size:28px}.ln-btn-sm{padding:6px 10px;font-size:10px}.ln-logo{font-size:14px}.banner-3d-card{max-width:220px}}@media (prefers-reduced-motion:reduce){.faq-a,.ln-nav,.bento-card,.price-card,.ln-btn,.step-card{transition:none}.earth-map,.hero-globe-wrap,.pin-ring{animation:none}.banner-3d-card{animation:none!important;transform:none!important}.banner-3d-glow,.banner-3d-sheen{display:none}}.pricing-page{--bg:var(--bg-primary);--bg-alt:var(--bg-secondary);--surface:var(--bg-card);--surface-hover:var(--bg-card-hover);--border:var(--border-color);--border-strong:var(--border-strong);--text:var(--text-primary);--text-secondary:var(--text-secondary);--text-muted:var(--text-muted);--blue:var(--accent);--blue-light:var(--accent-light);--blue-glow:var(--accent-glow);--display:"Unbounded", system-ui, sans-serif;--body:"Manrope", system-ui, sans-serif;background:var(--bg);min-height:100vh;color:var(--text);font-family:var(--body);-webkit-font-smoothing:antialiased}.pricing-nav{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:20px 32px;display:flex}.pricing-nav-logo{font-family:var(--display);letter-spacing:1px;color:var(--text);font-size:18px;font-weight:800;text-decoration:none}.pricing-nav-logo span{color:var(--blue)}.pricing-nav-back{color:var(--text-secondary);font-size:14px;text-decoration:none;transition:color .2s}.pricing-nav-back:hover{color:var(--text)}.pricing-content{max-width:1200px;margin:0 auto;padding:40px 32px 80px}.pricing-header{text-align:center;margin-bottom:48px}.pricing-header h1{font-family:var(--display);margin-bottom:12px;font-size:32px;font-weight:700}.pricing-usage{color:var(--text-secondary);font-size:15px}.pricing-usage strong{color:var(--text)}.pricing-cards{grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:48px;display:grid}.pricing-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;padding:32px 28px;display:flex;position:relative}.pricing-card.is-popular{border-color:var(--blue);box-shadow:0 0 40px #2b4fff1f}.pricing-card.is-current{border-color:#64ff8c4d}.pricing-popular-badge,.pricing-current-badge{letter-spacing:.5px;white-space:nowrap;border-radius:20px;padding:4px 16px;font-size:12px;font-weight:600;position:absolute;top:-12px;left:50%;transform:translate(-50%)}.pricing-popular-badge{background:var(--blue);color:#fff}.pricing-current-badge{color:#6fdf8f;background:#64ff8c26;border:1px solid #64ff8c4d}.pricing-plan-name{font-family:var(--display);margin-bottom:8px;font-size:18px;font-weight:700}.pricing-plan-price{margin-bottom:4px;font-size:32px;font-weight:800}.pricing-plan-price .period{color:var(--text-secondary);font-size:15px;font-weight:400}.pricing-plan-note{color:var(--text-muted);margin-bottom:24px;font-size:13px}.pricing-features{flex:1;margin:0 0 28px;padding:0;list-style:none}.pricing-features li{color:var(--text-secondary);align-items:center;gap:8px;padding:6px 0;font-size:14px;display:flex}.pricing-features li svg{width:16px;height:16px;color:var(--blue-light);flex-shrink:0}.pricing-card-btn{width:100%;font-size:14px;font-weight:600;font-family:var(--body);text-align:center;cursor:pointer;border:none;border-radius:10px;padding:12px;transition:background .2s,transform .1s;display:block}.pricing-card-btn.primary{background:var(--blue);color:#fff}.pricing-card-btn.primary:hover{background:var(--blue-light)}.pricing-card-btn.ghost{border:1px solid var(--border);color:var(--text-secondary);background:0 0}.pricing-card-btn.ghost:hover{border-color:var(--border-strong);color:var(--text)}.pricing-card-btn.current{color:#6fdf8f;cursor:default;background:#64ff8c1a}.pricing-card-btn.kakao,.pricing-single-btn.kakao{color:#1a1a1a;background:#fee500;font-weight:700}.pricing-card-btn.kakao:hover,.pricing-single-btn.kakao:hover{background:#ffd600}.pay-overlay{z-index:1000;background:var(--modal-overlay);-webkit-backdrop-filter:blur(20px);justify-content:center;align-items:center;padding:24px;animation:.25s ease-out pay-fade-in;display:flex;position:fixed;inset:0}@keyframes pay-fade-in{0%{opacity:0}to{opacity:1}}.pay-modal{background:var(--modal-bg);border:1px solid var(--border-color);text-align:center;border-radius:20px;width:100%;max-width:380px;padding:40px 36px;animation:.3s cubic-bezier(.16,1,.3,1) pay-scale-in;position:relative}@keyframes pay-scale-in{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.pay-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;transition:color .2s;position:absolute;top:16px;right:16px}.pay-close:hover{color:var(--text-secondary)}.pay-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;font-family:Unbounded,system-ui,sans-serif;font-size:14px;font-weight:700}.pay-amount{color:#fff;margin-bottom:28px;font-family:Unbounded,system-ui,sans-serif;font-size:36px;font-weight:900}.pay-qr-wrap{margin-bottom:24px}.pay-qr{object-fit:contain;background:#fff;border-radius:16px;width:240px;height:240px;padding:12px}.pay-kakao-btn{color:#1a1a1a;cursor:pointer;background:#fee500;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;margin-bottom:20px;padding:14px 24px;font-family:Manrope,system-ui,sans-serif;font-size:16px;font-weight:700;text-decoration:none;transition:background .2s;display:flex}.pay-kakao-btn:hover{background:#ffd600}.pay-instruction{color:var(--text-muted);font-size:13px;line-height:1.65}.pay-instruction strong{color:var(--text-secondary);font-weight:600}.pricing-plan-price .price-old{color:var(--text-muted);margin-bottom:4px;font-size:18px;font-weight:500;text-decoration:line-through;display:block}.pricing-single{background:var(--surface);border:1px solid var(--border);border-radius:16px;align-items:center;gap:24px;max-width:720px;margin:40px auto 0;padding:28px 32px;display:flex}.pricing-single-text{flex:1}.pricing-single-text h3{color:var(--text);margin-bottom:6px;font-family:Unbounded,system-ui,sans-serif;font-size:18px;font-weight:700}.pricing-single-text p{color:var(--text-muted);margin:0;font-size:14px}.pricing-single-price{text-align:right;flex-direction:column;align-items:flex-end;display:flex}.pricing-single-price .price{color:var(--text);font-family:Unbounded,system-ui,sans-serif;font-size:26px;font-weight:800;line-height:1}.pricing-single-price .label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:4px;font-size:11px}.pricing-single-btn{background:var(--blue);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:12px 28px;font-family:Manrope,system-ui,sans-serif;font-size:14px;font-weight:600;transition:background .2s}.pricing-single-btn:hover{background:var(--accent-light)}.pricing-promo{text-align:center;max-width:480px;margin:48px auto 0}.pricing-promo h3{color:var(--text);margin-bottom:16px;font-family:Unbounded,system-ui,sans-serif;font-size:16px;font-weight:700}.pricing-promo-row{gap:10px;display:flex}.pricing-promo-row input{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:8px;outline:none;flex:1;padding:12px 16px;font-family:Manrope,system-ui,sans-serif;font-size:14px;transition:border-color .2s}.pricing-promo-row input:focus{border-color:var(--blue)}.pricing-promo-row input::placeholder{color:var(--text-muted)}.pricing-promo-row button{background:var(--blue);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:12px 24px;font-family:Manrope,system-ui,sans-serif;font-size:14px;font-weight:600;transition:background .2s,opacity .2s}.pricing-promo-row button:hover{background:var(--accent-light)}.pricing-promo-row button:disabled{opacity:.5;cursor:not-allowed}.pricing-promo-ok{color:#22c55e;margin-top:12px;font-size:14px;font-weight:500}.pricing-promo-err{color:#ef4444;margin-top:12px;font-size:14px;font-weight:500}@media (width<=768px){.pricing-cards{grid-template-columns:1fr;max-width:400px;margin-left:auto;margin-right:auto}.pricing-promo-row{flex-direction:column}.pricing-single{text-align:center;flex-direction:column;gap:16px}.pricing-single-price{text-align:center;align-items:center}.pricing-single-btn{width:100%}}.auth-page{--bg:var(--bg-primary);--surface:var(--bg-card);--border:var(--border-color);--border-strong:var(--border-strong);--text:var(--text-primary);--text-secondary:var(--text-secondary);--blue:var(--accent);--blue-light:var(--accent-light);--blue-glow:var(--accent-glow);--display:"Unbounded", system-ui, sans-serif;--body:"Manrope", system-ui, sans-serif;background:var(--bg);min-height:100vh;font-family:var(--body);color:var(--text);-webkit-font-smoothing:antialiased;justify-content:center;align-items:center;padding:24px;display:flex}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:420px;padding:40px 36px}.auth-logo{font-family:var(--display);text-align:center;letter-spacing:1px;margin-bottom:32px;font-size:22px;font-weight:800}.auth-logo span{color:var(--blue)}.auth-title{font-family:var(--display);text-align:center;margin-bottom:28px;font-size:20px;font-weight:700}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-field label{color:var(--text-secondary);font-size:13px;font-weight:500}.auth-field input{background:var(--bg);border:1px solid var(--border);color:var(--text);font-size:15px;font-family:var(--body);border-radius:10px;outline:none;padding:12px 14px;transition:border-color .2s}.auth-field input::placeholder{color:var(--text-muted)}.auth-field input:focus{border-color:var(--border-strong)}.auth-submit{background:var(--blue);color:#fff;font-size:15px;font-weight:600;font-family:var(--body);cursor:pointer;border:none;border-radius:10px;margin-top:8px;padding:14px;transition:background .2s,transform .1s}.auth-submit:hover{background:var(--blue-light)}.auth-submit:active{transform:scale(.98)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-error{color:#ff6b6b;text-align:center;background:#ff3c3c1a;border:1px solid #ff3c3c40;border-radius:10px;padding:12px 14px;font-size:14px}.auth-link{text-align:center;color:var(--text-secondary);margin-top:20px;font-size:14px}.auth-link a{color:var(--blue-light);font-weight:500;text-decoration:none}.auth-link a:hover{text-decoration:underline}@media (width<=480px){.auth-card{padding:32px 24px}}.admin-page{--bg:var(--bg-primary);--surface:var(--bg-card);--border:var(--border-color);--border-strong:var(--border-strong);--text:var(--text-primary);--text-secondary:var(--text-secondary);--text-muted:var(--text-muted);--blue:var(--accent);--blue-light:var(--accent-light);--display:"Unbounded", system-ui, sans-serif;--body:"Manrope", system-ui, sans-serif;background:var(--bg);min-height:100vh;color:var(--text);font-family:var(--body);-webkit-font-smoothing:antialiased}.admin-nav{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:20px 32px;display:flex}.admin-nav-logo{font-family:var(--display);letter-spacing:1px;color:var(--text);font-size:18px;font-weight:800;text-decoration:none}.admin-nav-logo span{color:var(--blue)}.admin-nav-back{color:var(--text-secondary);font-size:14px;text-decoration:none;transition:color .2s}.admin-nav-back:hover{color:var(--text)}.admin-content{max-width:1200px;margin:0 auto;padding:0 32px 80px}.admin-title{font-family:var(--display);margin-bottom:28px;font-size:28px;font-weight:700}.admin-tabs{border-bottom:1px solid var(--border);gap:4px;margin-bottom:32px;padding-bottom:0;display:flex}.admin-tab{color:var(--text-muted);font-size:14px;font-weight:600;font-family:var(--body);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:12px 20px;transition:color .2s,border-color .2s}.admin-tab:hover{color:var(--text-secondary)}.admin-tab.active{color:var(--text);border-bottom-color:var(--blue)}.admin-table-wrap{overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:14px}.admin-table th{text-align:left;color:var(--text-secondary);border-bottom:1px solid var(--border);white-space:nowrap;padding:12px 16px;font-weight:600}.admin-table td{border-bottom:1px solid var(--border);color:var(--text);padding:12px 16px}.admin-table tr:hover td{background:#6478ff08}.admin-plan-select{background:var(--surface);border:1px solid var(--border);color:var(--text);font-size:13px;font-family:var(--body);cursor:pointer;border-radius:6px;padding:6px 10px}.admin-plan-select:focus{border-color:var(--border-strong);outline:none}.admin-actions-cell{align-items:center;gap:8px;display:flex}.admin-add-gen-btn{background:var(--accent);color:#fff;font-size:12px;font-weight:700;font-family:var(--body);cursor:pointer;white-space:nowrap;border:none;border-radius:6px;padding:6px 12px;transition:background .2s}.admin-add-gen-btn:hover{background:var(--accent-light)}.admin-stats{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;display:grid}.admin-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px}.admin-stat-label{color:var(--text-secondary);margin-bottom:8px;font-size:13px}.admin-stat-value{font-size:28px;font-weight:700}.admin-promo-list{flex-direction:column;gap:12px;margin-bottom:32px;display:flex}.admin-promo-item{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-wrap:wrap;align-items:center;gap:20px;padding:16px 20px;display:flex}.admin-promo-code{letter-spacing:1px;font-family:monospace;font-size:16px;font-weight:700}.admin-promo-meta{color:var(--text-secondary);font-size:13px}.admin-promo-badge{border-radius:12px;margin-left:auto;padding:3px 10px;font-size:11px;font-weight:600}.admin-promo-badge.active{color:#6fdf8f;background:#64ff8c1f}.admin-promo-badge.inactive{color:#ff6b6b;background:#ff64641f}.admin-promo-form{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-wrap:wrap;align-items:flex-end;gap:12px;padding:24px;display:flex}.admin-promo-form-field{flex-direction:column;gap:4px;display:flex}.admin-promo-form-field label{color:var(--text-secondary);font-size:12px}.admin-promo-form-field input{background:var(--bg);border:1px solid var(--border);color:var(--text);font-size:14px;font-family:var(--body);border-radius:8px;outline:none;width:160px;padding:10px 12px}.admin-promo-form-field input:focus{border-color:var(--border-strong)}.admin-promo-form-btn{background:var(--blue);color:#fff;font-size:14px;font-weight:600;font-family:var(--body);cursor:pointer;border:none;border-radius:8px;padding:10px 20px;transition:background .2s}.admin-promo-form-btn:hover{background:var(--blue-light)}.admin-promo-form-btn:disabled{opacity:.6;cursor:not-allowed}.admin-error{color:#ff6b6b;background:#ff3c3c1a;border:1px solid #ff3c3c40;border-radius:10px;margin-bottom:20px;padding:12px 16px;font-size:14px}.admin-empty{color:var(--text-muted);text-align:center;padding:32px 0;font-size:14px}@media (width<=768px){.admin-promo-form{flex-direction:column;align-items:stretch}.admin-promo-form-field input{width:100%}}
