*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background-color:#f8fafc;color:#0f172a;-webkit-font-smoothing:antialiased}.page-wrapper{min-height:100vh;display:flex;flex-direction:column}.navbar{position:-webkit-sticky;position:sticky;top:0;z-index:50;background-color:hsla(0,0%,100%,.9);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid #e2e8f0;padding:12px 0}.nav-content{max-width:980px;margin:0 auto;padding:0 20px;justify-content:space-between;gap:12px;flex-wrap:wrap}.logo-group,.nav-content{display:flex;align-items:center}.logo-group{gap:10px;text-decoration:none;color:inherit}.logo-group:focus-visible{outline:3px solid rgba(59,130,246,.16);border-radius:8px}.logo-icon{width:26px;height:26px;object-fit:contain}.logo-text{font-weight:800;font-size:18px;letter-spacing:-.03em;color:#0f172a}.nav-links{display:flex;gap:10px;align-items:center;justify-content:flex-end;flex-wrap:wrap}.nav-link{font-size:14px;font-weight:800;color:#64748b;text-decoration:none;padding:8px 10px;border-radius:10px}.nav-link:hover{color:#2563eb;background:#f1f5f9}.nav-link.active{color:#0f172a;background:#eef2ff;border:1px solid rgba(37,99,235,.18)}.nav-cta{display:flex;gap:10px;align-items:center}.nav-btn{border-radius:12px;padding:9px 14px;font-weight:800;font-size:14px;border:1px solid #dbeafe;cursor:pointer;text-decoration:none}.nav-btn.ghost{background:#eef2f7;color:#0f172a}.nav-btn.ghost:hover{background:#e2e8f0}.nav-btn.solid{background:linear-gradient(120deg,#2563eb,#4338ca);color:#fff;border:none;box-shadow:0 10px 30px rgba(59,130,246,.25)}.nav-btn.solid:hover{filter:brightness(1.04)}.nav-toggle{display:none;flex-direction:column;gap:4px;width:38px;height:34px;justify-content:center;align-items:center;background:#eef2f7;border-radius:10px;border:1px solid #e2e8f0}.nav-toggle span{width:16px;height:2px;background:#0f172a;display:block}.container{max-width:980px;width:100%;margin:0 auto;padding:28px 20px 44px;display:flex;flex-direction:column;gap:16px}.toast{position:fixed;right:16px;top:70px;background:rgba(15,23,42,.92);color:#fff;padding:10px 12px;border-radius:12px;font-weight:900;font-size:13px;box-shadow:0 12px 28px rgba(15,23,42,.18);z-index:60}.header-group{text-align:center}.hero-title{font-size:32px;font-weight:900;letter-spacing:-.05em;margin-bottom:8px}.hero-subtitle{font-size:16px;color:#64748b;line-height:1.45}.dash-shell{margin:4px 0 8px}.dashboard-cta{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px;border-radius:16px;background:#0f172a;color:#e2e8f0;border:1px solid #1f2937;box-shadow:0 14px 40px rgba(0,0,0,.25)}.dashboard-cta-sub{color:#cbd5e1;margin-top:6px}.card{background-color:#fff;border-radius:22px;padding:24px;box-shadow:0 12px 34px rgba(2,6,23,.06);border:1px solid #eef2f7}.form-grid{display:grid;grid-template-columns:1.2fr .8fr;grid-gap:18px;gap:18px;margin-bottom:18px}.input-group{display:flex;flex-direction:column;gap:8px}.label{font-size:13px;font-weight:900;color:#334155}.label-row{justify-content:space-between;gap:10px}.label-actions,.label-row{display:flex;align-items:center}.label-actions{gap:8px}.info-btn{width:20px;height:20px;border-radius:999px;border:1px solid #cbd5e1;background:#fff;color:#334155;font-weight:900;font-size:12px;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.info-btn:hover{background:#f1f5f9}.info-btn:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(59,130,246,.18)}.info-btn[aria-expanded=true]{border-color:rgba(37,99,235,.5);color:#1d4ed8}.counter{font-size:12px;font-weight:900;color:#94a3b8}.counter-bad{color:#ef4444}.slug-input-container{display:flex;align-items:center;gap:8px;border:1px solid #e2e8f0;border-radius:12px;background-color:#f8fafc;padding:10px 12px;transition:border-color .2s,box-shadow .2s}.slug-input-container:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1);background:#fff}.field-bad{border-color:rgba(239,68,68,.55)!important;box-shadow:0 0 0 3px rgba(239,68,68,.1)!important}.slug-prefix,.slug-suffix{color:#94a3b8;font-weight:900;font-size:14px;flex:none}.slug-suffix{white-space:nowrap}.slug-input{flex:1 1;border:none;outline:none;background:transparent;font-size:14px;color:#0f172a;min-width:0}.slug-reserved{font-size:12.5px;font-weight:800;color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;padding:6px 10px;border-radius:10px}.slug-meta{display:grid;grid-template-columns:.9fr 1.1fr;grid-gap:12px;gap:12px;align-items:start;min-height:42px}.slug-rule{font-size:12.5px;color:#64748b;font-weight:800;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.slug-preview{display:flex;align-items:center;justify-content:flex-end;gap:10px;min-width:0}.slug-preview-text{color:#2563eb;font-weight:900;max-width:100%}.slug-preview-placeholder,.slug-preview-text{font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.slug-preview-placeholder{color:#94a3b8;font-weight:800}.mini-btn{border:1px solid #dbe6ff;background:rgba(37,99,235,.08);color:#1d4ed8;font-weight:900;font-size:12.5px;padding:7px 10px;border-radius:999px;cursor:pointer;flex:none}.mini-btn:hover{background:rgba(37,99,235,.12)}.slug-rules-panel{margin-top:10px;padding:12px;border-radius:14px;border:1px solid #e2e8f0;background:#f8fafc;display:flex;flex-direction:column;gap:10px}.rules-title{font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:#64748b}.rules-list{margin:0;padding-left:18px;font-size:12.5px;color:#475569;font-weight:700;line-height:1.4;display:grid;grid-gap:4px;gap:4px}.rules-hint{font-size:12px;color:#64748b;font-weight:700}.rules-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:10px;gap:10px;max-height:220px;overflow:auto;padding-right:4px}.rules-group{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:8px 10px;display:flex;flex-direction:column;gap:6px}.rules-group-title{font-size:12px;font-weight:900;color:#334155}.rules-group-list{font-size:12px;font-weight:700;color:#64748b;line-height:1.35}.security-card{border:1px solid #e2e8f0;background:#fff;border-radius:14px;padding:12px}.security-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}.security-title{font-weight:900;color:#0f172a;font-size:14px}.switch{position:relative;width:46px;height:28px;border-radius:999px;border:1px solid #e2e8f0;background:#f1f5f9;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s,box-shadow .2s}.switch:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(59,130,246,.12);border-color:rgba(59,130,246,.65)}.switch-thumb{position:absolute;top:50%;transform:translateY(-50%);width:22px;height:22px;border-radius:999px;background:#fff;box-shadow:0 8px 18px rgba(2,6,23,.14);transition:left .18s ease;left:3px}.switch-on{background:#2563eb;border-color:#2563eb}.switch-on .switch-thumb{left:21px}.switch-off{background:#f1f5f9}.switch:hover{border-color:rgba(148,163,184,.9)}.text-input{width:100%;padding:12px;border-radius:12px;border:1px solid #e2e8f0;background-color:#fff;font-size:14px;outline:none}.text-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.password-wrapper{position:relative;margin-top:10px}.password-input{padding-right:44px}.password-toggle-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);border:none;background:transparent;cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;color:#64748b}.password-toggle-btn:hover{color:#334155}.helper{font-size:12.5px;color:#64748b;font-weight:700;line-height:1.35}.tabs-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.tab-container{display:flex;background-color:#f1f5f9;padding:4px;border-radius:14px;flex:1 1;min-width:0}.tab-btn{flex:1 1;padding:10px;border-radius:12px;border:none;font-size:14px;cursor:pointer;transition:all .2s ease;font-weight:900;white-space:nowrap}.tab-active{background-color:#fff;color:#0f172a;box-shadow:0 2px 6px rgba(2,6,23,.06)}.tab-inactive{background-color:transparent;color:#64748b}.tab-inactive:hover{color:#334155}.templates-link{flex:none;border:1px solid #e2e8f0;background:#fff;color:#1d4ed8;font-weight:900;font-size:13px;padding:10px 12px;border-radius:14px;cursor:pointer}.templates-link:hover{background:rgba(37,99,235,.06)}.action-area{margin-bottom:16px}.fade-in{animation:fadeIn .25s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.editor-label{font-size:11px;font-weight:900;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em}.toolbar{display:flex;gap:10px;align-items:center}.toolbar-btn{border:1px solid #e2e8f0;background:#fff;color:#334155;font-weight:900;font-size:13px;padding:10px 12px;border-radius:12px;cursor:pointer}.toolbar-btn:hover{background:rgba(15,23,42,.03)}.toolbar-btn:disabled{opacity:.6;cursor:not-allowed}.toolbar-primary{border-color:rgba(37,99,235,.25);background:rgba(37,99,235,.08);color:#1d4ed8}.toolbar-primary:hover{background:rgba(37,99,235,.12)}.drop-surface{position:relative;border-radius:14px;overflow:hidden}.drop-surface-over{box-shadow:0 0 0 4px rgba(59,130,246,.14)}.drop-surface-disabled{opacity:.75}.drop-hint{position:absolute;inset:10px;border:2px dashed rgba(59,130,246,.45);border-radius:12px;background:rgba(37,99,235,.06);display:flex;align-items:center;justify-content:center;font-weight:900;color:#1d4ed8;pointer-events:none}.code-textarea{width:100%;height:320px;padding:16px;border-radius:14px;border:1px solid #e2e8f0;background-color:#f8fafc;color:#0f172a;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:13px;line-height:1.6;resize:vertical;outline:none}.code-textarea:focus{border-color:#cbd5e1;background:#fff}.upload-zone{width:100%;height:320px;border-radius:14px;border:2px dashed #cbd5e1;background-color:#f8fafc;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;text-align:center;transition:all .2s;padding:14px}.upload-zone:hover{background-color:#f1f5f9;border-color:#94a3b8}.upload-zone-over{border-color:rgba(59,130,246,.65);background:rgba(37,99,235,.06)}.upload-zone-disabled{cursor:not-allowed;opacity:.75}.upload-icon{font-size:40px;margin-bottom:10px}.upload-heading{font-size:16px;font-weight:900;color:#0f172a;margin-bottom:6px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-subtext{font-size:14px;color:#64748b}.zip-head{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:10px}.zip-actions{display:flex;gap:10px;flex-wrap:wrap}.limits-row{margin-top:10px}.limits-row-split{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.limits-left{flex:1 1;min-width:0}.limits-right{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap;min-width:0}.limits-row-split{margin-top:10px}.hint-left{line-height:1.35;font-weight:500}.hint-left,.limits-right{font-size:12.5px;color:#64748b}.limit-caption,.limits-right{font-weight:600}.limit-caption{color:#94a3b8}.limits-pill{background:#f1f5f9;border:1px solid #e2e8f0;color:#0f172a;font-size:12.5px;font-weight:700;padding:6px 10px;border-radius:999px;max-width:100%;white-space:nowrap}.limits-note{font-size:12px;color:#94a3b8;font-weight:800}.limits-bad{border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.06);color:#b91c1c}.file-details{margin-top:12px;border:1px solid #e2e8f0;background:#fff;border-radius:14px;padding:10px 12px}.file-summary{cursor:pointer;font-weight:900;color:#0f172a}.file-list{margin-top:10px;display:flex;flex-direction:column;gap:8px}.file-row{display:flex;justify-content:space-between;gap:10px;border:1px solid #eef2f7;background:#fbfdff;border-radius:12px;padding:8px 10px}.file-name{font-size:12.5px;font-weight:800;color:#0f172a;word-break:break-all}.file-size{font-size:12px;font-weight:900;color:#64748b;flex:none}.error-banner{background-color:#fef2f2;color:#b91c1c;padding:12px;border-radius:12px;font-size:14px;text-align:center;border:1px solid #fecaca;margin-bottom:14px}.publish-row{display:flex;flex-direction:column;gap:10px}.primary-btn{width:100%;padding:16px;border-radius:14px;border:none;background:linear-gradient(180deg,#3b82f6,#2563eb);color:#fff;font-size:16px;font-weight:900;box-shadow:0 10px 22px rgba(37,99,235,.18);cursor:pointer;transition:transform .1s,opacity .2s}.primary-btn:hover{opacity:.95}.primary-btn:active{transform:scale(.99)}.primary-btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.progress{border:1px solid #e2e8f0;background:#fff;border-radius:14px;padding:12px}.progress-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.progress-label{font-weight:900;color:#334155;font-size:13px}.progress-count{font-weight:900;color:#64748b;font-size:12.5px}.progress-bar{height:10px;background:rgba(100,116,139,.16);border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#2563eb);border-radius:999px;width:0;transition:width .2s ease}.success-state{text-align:center;padding:18px;background-color:#f0fdf4;border-radius:16px;border:1px solid #bbf7d0}.success-icon{font-size:28px;margin-bottom:10px}.success-title{font-size:18px;font-weight:900;color:#166534;margin-bottom:8px}.result-link{display:block;font-size:14px;color:#15803d;margin-bottom:14px;font-weight:900;word-break:break-all;text-decoration:none}.result-link:hover{text-decoration:underline}.btn-group{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.primary-small{padding:10px 14px;border-radius:12px;border:none;background:#166534;color:#fff;font-weight:900;cursor:pointer}.primary-small:hover{opacity:.92}.secondary-small{padding:10px 14px;border-radius:12px;border:1px solid #166534;background:#fff;color:#166534;font-weight:900;cursor:pointer}.secondary-small:hover{background:#f0fdf4}.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:14px;gap:14px;width:100%}.feature-card{background-color:#fff;padding:14px;border-radius:14px;border:1px solid #e2e8f0;display:flex;align-items:center;gap:12px}.feature-icon{font-size:20px}.feature-title{font-size:13px;font-weight:900;color:#0f172a}.feature-desc{font-size:12px;color:#64748b;font-weight:700}.footer{margin-top:26px;border-top:1px solid #e2e8f0;padding:22px 0 10px;color:#94a3b8;font-size:13px}.footer-inner{max-width:980px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.footer-text{font-size:13px;color:#94a3b8;font-weight:700}.footer-links{display:flex;gap:14px;flex-wrap:wrap}.footer-link{font-size:13px;color:#64748b;text-decoration:none;font-weight:800;padding:8px 10px;border-radius:10px}.footer-link:hover{background:#f1f5f9;color:#0f172a}.modal-backdrop{position:fixed;inset:0;background:rgba(2,6,23,.55);display:flex;align-items:center;justify-content:center;padding:16px;z-index:80}.modal{width:min(860px,100%);background:#fff;border-radius:18px;border:1px solid #e2e8f0;box-shadow:0 24px 64px rgba(2,6,23,.25);padding:16px}.modal-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.modal-title{font-weight:900;font-size:16px;color:#0f172a}.modal-sub{margin-top:4px;color:#64748b;font-weight:700;font-size:13px}.modal-close{border:1px solid #e2e8f0;background:#fff;border-radius:12px;padding:8px 10px;cursor:pointer;font-weight:900}.modal-close:hover{background:rgba(15,23,42,.03)}.modal-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:12px;gap:12px}.tpl-card{text-align:left;border:1px solid #e2e8f0;background:#fff;border-radius:16px;padding:14px;cursor:pointer;transition:transform .08s,box-shadow .2s,border-color .2s}.tpl-card:hover{border-color:rgba(37,99,235,.25);box-shadow:0 10px 22px rgba(37,99,235,.1)}.tpl-card:active{transform:scale(.99)}.tpl-name{font-weight:900;color:#0f172a;margin-bottom:6px}.tpl-desc{color:#64748b;font-weight:700;font-size:13px;line-height:1.35;min-height:38px}.tpl-foot{margin-top:12px;display:flex;align-items:center;justify-content:space-between;gap:10px}.tpl-chip{border:1px solid #e2e8f0;background:#f8fafc;border-radius:999px;padding:6px 10px;font-weight:900;font-size:12px;color:#334155}.tpl-cta{font-weight:900;color:#1d4ed8}.modal-note{margin-top:12px;color:#64748b;font-weight:700;font-size:13px}@media (max-width:768px){.nav-content{flex-wrap:wrap;gap:10px}.nav-links{width:100%;display:none;flex-direction:column;align-items:flex-start;gap:10px;margin-top:6px}.nav-links.nav-open{display:flex}.nav-toggle{display:inline-flex}.nav-btn,.nav-link{width:100%;text-align:left}.form-grid{grid-template-columns:1fr}.tabs-row{flex-direction:column;align-items:stretch}.limits-row-split{flex-direction:column;align-items:flex-start}}@media (max-width:640px){.limits-row-split{flex-direction:column;align-items:flex-start}.limits-right{justify-content:flex-start;width:100%}.limits-left{width:100%}.hint-left{display:block;width:100%}}@media (max-width:900px){.form-grid{grid-template-columns:1fr}.feature-grid{grid-template-columns:repeat(2,1fr)}.slug-meta{grid-template-columns:1fr}.slug-preview{justify-content:flex-start}.modal-grid,.rules-grid{grid-template-columns:1fr}.tabs-row{flex-direction:column;align-items:stretch}}@media (max-width:520px){.container{padding:18px 14px}.card{padding:18px}.hero-title{font-size:26px}.feature-grid{grid-template-columns:1fr}.limits-left{min-width:0}.tab-btn{font-size:13px;padding:10px 8px}}