*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* ===== THEME VARIABLES (Light Only) ===== */
:root {
  --bg:#f0f2f5;--panel:#ffffff;--panel2:#f8f9fa;--card:#ffffff;
  --border:rgba(0,0,0,.1);--text:#1a1a2e;--muted:rgba(0,0,0,.5);
  --accent:#6c63ff;--accent2:#0099cc;--accent-glow:rgba(108,99,255,.15);
  --danger:#dc3545;--success:#198754;--gold:#b8860b;
  --radius:14px;--radius-sm:10px;
  --font:'Montserrat',system-ui,sans-serif;
  --shadow:0 4px 16px rgba(0,0,0,.1);
  --canvas-shadow:0 8px 32px rgba(0,0,0,.15);
}

html{font-size:14px}
body{font-family:var(--font);background:var(--bg);color:var(--text);overflow-x:hidden;min-height:100vh;transition:background .3s,color .3s}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(128,128,128,.3);border-radius:3px}

/* ===== CATEGORY OVERLAY ===== */
.cat-overlay{position:fixed;inset:0;z-index:9999;background:linear-gradient(135deg,#f0f2f5 0%,#e8e6f0 50%,#f0f2f5 100%);display:flex;align-items:center;justify-content:center;padding:2rem;overflow-y:auto;animation:catOverlayIn .5s ease}
@keyframes catOverlayIn{from{opacity:0}to{opacity:1}}
.cat-overlay-inner{max-width:820px;width:100%;text-align:center}
.cat-overlay-header{margin-bottom:2.5rem}
.cat-overlay-sparkle{font-size:2.5rem;display:block;margin-bottom:.5rem;animation:catSparkle 2s ease-in-out infinite}
@keyframes catSparkle{0%,100%{transform:scale(1) rotate(0)}50%{transform:scale(1.15) rotate(8deg)}}
.cat-overlay-title{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700;color:var(--text);margin-bottom:.6rem;line-height:1.2}
.cat-overlay-sub{font-size:1rem;color:var(--muted);line-height:1.5}
.cat-overlay-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.cat-overlay-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.6rem 1rem;background:#fff;border:2px solid rgba(0,0,0,.06);border-radius:20px;cursor:pointer;transition:all .35s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;font-family:var(--font);color:var(--text)}
.cat-overlay-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--accent),var(--accent2));transform:scaleX(0);transition:transform .35s;transform-origin:left}
.cat-overlay-card:hover::before{transform:scaleX(1)}
.cat-overlay-card:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(108,99,255,.18);border-color:var(--accent)}
.cat-overlay-card:active{transform:translateY(-2px) scale(.97)}
.cat-overlay-emoji{font-size:2.8rem;transition:transform .3s}
.cat-overlay-card:hover .cat-overlay-emoji{transform:scale(1.2) rotate(-5deg)}
.cat-overlay-name{font-weight:700;font-size:1rem;letter-spacing:-.01em}
.cat-overlay-desc{font-size:.72rem;color:var(--muted);line-height:1.4}
.cat-overlay-hidden{display:none}
@media(max-width:768px){.cat-overlay-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.cat-overlay-card{padding:1.2rem .8rem}}
@media(max-width:480px){.cat-overlay-grid{grid-template-columns:repeat(2,1fr)}.cat-overlay{padding:1rem}}

/* ===== LAYOUT ===== */
.app{display:grid;grid-template-columns:340px 1fr 280px;grid-template-rows:auto 1fr;min-height:100vh}
.topbar{grid-column:1/-1;position:sticky;top:0;display:flex;align-items:center;justify-content:space-between;padding:10px 24px;background:linear-gradient(135deg,var(--panel),var(--panel2));border-bottom:1px solid var(--border);gap:16px;z-index:200;flex-wrap:wrap;backdrop-filter:blur(12px)}
.topbar .logo{display:flex;align-items:center;gap:10px;font-size:1.15rem;font-weight:700;letter-spacing:-.3px}
.topbar .logo span{background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.topbar-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.topbar-sep{width:1px;height:24px;background:var(--border);margin:0 4px}

.sidebar{display:flex;flex-direction:column;overflow:hidden;background:var(--panel);border-right:1px solid var(--border);padding:0;position:sticky;top:48px;height:calc(100vh - 48px);transition:background .3s}
.canvas-area{display:flex;justify-content:center;align-items:flex-start;padding:20px;background:radial-gradient(ellipse at 50% 0%,rgba(108,99,255,.06),transparent 70%);overflow:auto;position:relative}
.canvas-wrapper{border-radius:4px;box-shadow:var(--canvas-shadow);position:relative;line-height:0}
.canvas-wrapper canvas{border-radius:4px}

/* ===== RIGHT PANEL ===== */
.right-panel{background:var(--panel);border-left:1px solid var(--border);padding:12px;display:flex;flex-direction:column;gap:8px;position:sticky;top:48px;height:calc(100vh - 48px);transition:background .3s;overflow:hidden}
.rp-title{font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text);margin-bottom:4px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.rp-title span:last-child{font-size:.7rem;color:var(--muted);font-weight:500;background:rgba(108,99,255,.1);padding:2px 8px;border-radius:10px}
.rp-check-row{display:flex;gap:4px;margin-bottom:4px;flex-shrink:0}
.rp-check-row .btn{flex:1;font-size:.68rem;padding:6px 8px;justify-content:center}
#invList{display:flex;flex-direction:column;gap:8px;overflow-y:auto;overflow-x:hidden;min-height:0;flex:1;padding:2px 4px 2px 0}
.rp-bottom{flex-shrink:0;background:var(--panel);padding:8px 0 0;display:flex;flex-direction:column;gap:8px}
.inv-card{position:relative;border-radius:10px;border:2px solid var(--border);overflow:hidden;cursor:pointer;transition:.25s;background:var(--card);flex-shrink:0}
.inv-card:hover{border-color:rgba(128,128,128,.35);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.08)}
.inv-card.active{border-color:var(--accent);box-shadow:0 0 16px var(--accent-glow)}
.inv-card .inv-thumb{width:100%;height:160px;background-size:contain;background-repeat:no-repeat;background-position:center;background-color:#fff;border-radius:8px 8px 0 0}
.inv-card .inv-info{padding:8px 10px;display:flex;align-items:center;justify-content:space-between;gap:6px}
.inv-card .inv-name{font-size:.75rem;font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}
.inv-card .inv-actions{display:flex;gap:4px}
.inv-card .inv-btn{width:32px;height:32px;border:none;border-radius:8px;cursor:pointer;font-size:.82rem;display:flex;align-items:center;justify-content:center;transition:.15s;padding:0}
.inv-card .inv-btn[data-a="rename"]{background:rgba(32,201,151,.15);color:#198754}
.inv-card .inv-btn[data-a="rename"]:hover{background:rgba(32,201,151,.3);color:#198754;transform:scale(1.1)}
.inv-card .inv-btn[data-a="dup"]{background:rgba(108,99,255,.15);color:#6c63ff}
.inv-card .inv-btn[data-a="dup"]:hover{background:rgba(108,99,255,.3);color:#6c63ff;transform:scale(1.1)}
.inv-card .inv-btn[data-a="del"]{background:rgba(255,107,107,.15);color:#ff6b6b}
.inv-card .inv-btn[data-a="del"]:hover{background:rgba(255,107,107,.3);color:#ff6b6b;transform:scale(1.1)}
.inv-card .inv-check{position:absolute;top:6px;left:6px;width:24px;height:24px;border-radius:7px;border:2px solid rgba(255,255,255,.5);background:rgba(0,0,0,.4);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.7rem;z-index:2;transition:.15s;backdrop-filter:blur(4px)}
.inv-card .inv-check:hover{border-color:rgba(255,255,255,.8)}
.inv-card .inv-check.checked{border-color:var(--success);background:var(--success);color:#fff}
.inv-card .inv-num{position:absolute;top:6px;right:6px;padding:3px 10px;border-radius:10px;background:rgba(0,0,0,.65);font-size:1.1rem;color:#fff;font-weight:700;min-width:30px;text-align:center;backdrop-filter:blur(4px)}
.rp-add-btn{width:100%;padding:12px;border-radius:var(--radius-sm);border:2px dashed var(--accent);background:rgba(108,99,255,.04);color:var(--accent);cursor:pointer;font-size:.82rem;font-weight:600;transition:.2s;font-family:var(--font);display:flex;align-items:center;justify-content:center;gap:6px}
.rp-add-btn:hover{border-color:var(--accent);color:var(--text);background:rgba(108,99,255,.1);transform:translateY(-1px)}
.rp-export-btn{width:100%;padding:10px;border-radius:var(--radius-sm);border:1px solid rgba(32,201,151,.35);background:rgba(32,201,151,.12);color:var(--success);cursor:pointer;font-size:.78rem;font-weight:600;transition:.2s;font-family:var(--font);display:flex;align-items:center;justify-content:center;gap:5px}
.rp-export-btn:hover{background:rgba(32,201,151,.22)}

/* ===== TABS ===== */
.tabs{display:flex;border-bottom:1px solid var(--border);background:var(--panel2);flex-shrink:0;position:sticky;top:0;z-index:10}
.tab{flex:1;padding:11px 6px;text-align:center;font-size:.78rem;font-weight:500;cursor:pointer;transition:.2s;border-bottom:2px solid transparent;color:var(--muted);position:relative}
.tab:hover{color:var(--text);background:rgba(128,128,128,.05)}
.tab.active{color:var(--accent);border-bottom-color:var(--accent);background:rgba(108,99,255,.06)}
.tab .tab-icon{font-size:1.2rem;display:block;margin-bottom:2px}

/* ===== SIDEBAR PANELS ===== */
.sidebar-panel{display:none;padding:14px;overflow-y:auto;flex:1;min-height:0}
.sidebar-panel.active{display:block}
.panel-title{font-size:.85rem;font-weight:600;margin-bottom:12px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}

/* ===== CARDS ===== */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:12px;transition:background .3s}
.card-title{font-size:.82rem;font-weight:600;margin-bottom:10px;display:flex;align-items:center;gap:6px}

/* ===== CATEGORY SELECTOR ===== */
.categories{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:14px;flex-shrink:0}
.cat-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;border-radius:20px;border:1.5px solid var(--border);background:rgba(128,128,128,.02);cursor:pointer;transition:.25s;font-size:.72rem;font-weight:500;color:var(--muted);white-space:nowrap}
.cat-btn:hover{border-color:rgba(128,128,128,.2);background:rgba(128,128,128,.05);transform:translateY(-1px)}
.cat-btn.active{border-color:var(--accent);background:var(--accent-glow);color:var(--text)}
.cat-btn .cat-icon{font-size:1rem}
.cat-btn .cat-label{line-height:1.2}

/* ===== TEMPLATES ===== */
.templates-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding-right:4px}
.tpl-card{position:relative;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;border:2px solid transparent;transition:.25s}
.tpl-card:hover{border-color:rgba(128,128,128,.25);transform:scale(1.03)}
.tpl-card.active{border-color:var(--accent);box-shadow:0 0 20px var(--accent-glow)}
.tpl-preview{width:100%;padding-bottom:140%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;font-size:.65rem;line-height:1.3;position:relative;overflow:hidden}
.tpl-preview>*{position:absolute}
.tpl-name{position:absolute;bottom:0;left:0;right:0;padding:5px;background:rgba(0,0,0,.65);font-size:.68rem;font-weight:500;text-align:center;backdrop-filter:blur(4px);color:#fff;z-index:1}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:rgba(128,128,128,.06);color:var(--text);font-size:.8rem;font-weight:500;cursor:pointer;transition:.2s;font-family:var(--font)}
.btn:hover{background:rgba(128,128,128,.12);border-color:rgba(128,128,128,.2)}
.btn-primary{background:linear-gradient(135deg,var(--accent),#8b5cf6);border-color:rgba(108,99,255,.4);color:#fff}
.btn-primary:hover{box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-1px);color:#fff}
.btn-success{background:rgba(32,201,151,.15);border-color:rgba(32,201,151,.35);color:var(--success)}
.btn-danger{background:rgba(255,107,107,.1);border-color:rgba(255,107,107,.3);color:var(--danger)}
.btn-gold{background:linear-gradient(135deg,#d4a574,#f0c27f);border-color:rgba(212,165,116,.4);color:#1a1a2e}
.btn-sm{padding:6px 10px;font-size:.75rem}
.btn-icon{width:34px;height:34px;padding:0;justify-content:center;font-size:1rem}
.btn-block{width:100%}
.btn-group{display:flex;gap:6px;flex-wrap:wrap}

/* ===== INPUTS ===== */
.input,.select{width:100%;padding:9px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:rgba(128,128,128,.06);color:var(--text);font-size:.82rem;font-family:var(--font);transition:.2s}
.input:focus,.select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.color-input{width:44px;height:36px;padding:2px;border-radius:8px;cursor:pointer;border:1px solid var(--border);background:transparent}
.form-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.form-label{font-size:.75rem;color:var(--muted);margin-bottom:4px;display:block}
.form-group{margin-bottom:10px}

/* ===== LAYERS ===== */
.layers-list{max-height:220px;overflow-y:auto}
.layer-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:.15s;border:1px solid transparent;margin-bottom:3px}
.layer-item:hover{background:rgba(128,128,128,.06)}
.layer-item.active{border-color:rgba(108,99,255,.4);background:rgba(108,99,255,.08)}
.layer-item .layer-icon{font-size:1rem;width:22px;text-align:center}
.layer-item .layer-name{flex:1;font-size:.78rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.layer-item .layer-actions{display:flex;gap:3px}
.layer-item .layer-actions button{opacity:.5;transition:.15s;background:transparent;border:none;color:var(--muted);cursor:pointer;padding:2px 4px;border-radius:4px;font-size:.7rem}
.layer-item .layer-actions button:hover{opacity:1;background:rgba(128,128,128,.12);color:var(--text)}

/* ===== SHAPES GRID ===== */
.shapes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(48px,1fr));gap:5px}
.shape-btn{aspect-ratio:1;border-radius:var(--radius-sm);border:1px solid var(--border);background:rgba(128,128,128,.04);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:.2s;position:relative}
.shape-btn:hover{background:rgba(128,128,128,.1);border-color:rgba(128,128,128,.2);transform:scale(1.08)}

/* ===== DECORATIVE ELEMENTS ===== */
.decos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(65px,1fr));gap:5px;padding-right:4px}
.deco-btn{padding:8px 4px;border-radius:var(--radius-sm);border:1px solid var(--border);background:rgba(128,128,128,.04);cursor:pointer;text-align:center;font-size:1.3rem;transition:.2s}
.deco-btn:hover{background:rgba(128,128,128,.1);transform:scale(1.05)}
.deco-btn small{display:block;font-size:.55rem;margin-top:2px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.deco-btn.deco-svg{border-color:rgba(212,165,116,.25);background:rgba(212,165,116,.04);font-size:1.1rem}
.deco-btn.deco-svg:hover{border-color:rgba(212,165,116,.5);background:rgba(212,165,116,.1)}

/* ===== SEPARATOR ===== */
.sep{height:1px;background:var(--border);margin:12px 0}

/* ===== TEXT PRESETS ===== */
.text-presets-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px}
.text-preset-btn{padding:7px 6px;border-radius:var(--radius-sm);border:1px solid var(--border);background:rgba(108,99,255,.03);cursor:pointer;text-align:center;font-size:.68rem;color:var(--text);transition:.2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.text-preset-btn:hover{background:rgba(108,99,255,.1);border-color:var(--accent);transform:scale(1.02)}

/* ===== MAGIC TOOLS ===== */
.magic-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.magic-btn{aspect-ratio:1;border-radius:var(--radius-sm);border:1px solid var(--border);background:rgba(128,128,128,.04);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:.2s;color:var(--muted)}
.magic-btn:hover{background:rgba(108,99,255,.12);border-color:rgba(108,99,255,.3);color:var(--text);transform:scale(1.05)}
.magic-btn.active{background:var(--accent-glow);border-color:var(--accent);color:var(--text)}
.palettes-grid{display:flex;flex-direction:column;gap:6px}
.palette-row{display:flex;gap:3px;cursor:pointer;border-radius:var(--radius-sm);padding:4px;border:2px solid transparent;transition:.2s}
.palette-row:hover{border-color:rgba(128,128,128,.15);background:rgba(128,128,128,.04)}
.palette-swatch{flex:1;height:28px;border-radius:6px;transition:.2s}
.palette-swatch:first-child{border-radius:6px 3px 3px 6px}
.palette-swatch:last-child{border-radius:3px 6px 6px 3px}
.palette-label{font-size:.6rem;color:var(--muted);text-align:center;margin-top:2px}
.ornament-btn{padding:8px 6px;border-radius:var(--radius-sm);border:1px solid var(--border);background:rgba(128,128,128,.04);cursor:pointer;text-align:center;font-size:1.3rem;transition:.2s}
.ornament-btn:hover{background:rgba(128,128,128,.1);transform:scale(1.05)}
.ornament-btn small{display:block;font-size:.55rem;margin-top:2px;color:var(--muted)}
.canvas-area.drawing-mode{cursor:crosshair}
.border-btn{padding:6px;border-radius:var(--radius-sm);border:1px solid var(--border);background:rgba(128,128,128,.04);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.7rem;transition:.2s;color:var(--muted);text-align:center;line-height:1.2}
.border-btn:hover{background:rgba(108,99,255,.1);border-color:rgba(108,99,255,.3);color:var(--text)}
.png-ornaments-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding-right:4px}
.png-orn-card{border-radius:var(--radius-sm);border:1px solid var(--border);background:rgba(128,128,128,.04);cursor:pointer;overflow:hidden;transition:.2s;aspect-ratio:1;display:flex;align-items:center;justify-content:center;padding:6px;min-height:0;min-width:0}
.png-orn-card:hover{background:rgba(108,99,255,.1);border-color:rgba(108,99,255,.3);transform:scale(1.04)}
.png-orn-card img{width:100%;height:100%;object-fit:contain;pointer-events:none;display:block}
.png-orn-trigger{grid-column:1/-1;display:flex;align-items:center;justify-content:center;padding:10px;cursor:pointer;border-radius:var(--radius-sm);border:1.5px dashed var(--border);background:rgba(128,128,128,.03);transition:.2s;font-size:.72rem;color:var(--muted)}
.png-orn-trigger:hover{border-color:rgba(108,99,255,.3);background:rgba(108,99,255,.06);color:var(--text)}

/* ===== TOAST ===== */
.toast{position:fixed;bottom:24px;right:24px;padding:12px 20px;border-radius:var(--radius);background:rgba(32,201,151,.9);color:#fff;font-size:.85rem;font-weight:500;z-index:9999;animation:toastIn .3s ease;pointer-events:none;backdrop-filter:blur(8px)}
@keyframes toastIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* ===== AI INLINE ===== */
.ai-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;background:linear-gradient(135deg,#6c63ff,#00d2ff);font-size:.6rem;font-weight:700;color:#fff;letter-spacing:.5px}
.tpl-card.ai-loading-card{border:2px dashed rgba(108,99,255,.35);cursor:default}
.tpl-card.ai-loading-card:hover{transform:none;border-color:rgba(108,99,255,.5)}
.tpl-card.ai-loading-card .tpl-preview{background:var(--card);display:flex;align-items:center;justify-content:center;gap:8px;flex-direction:column}
.ai-spinner-sm{width:22px;height:22px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:aiSpin .7s linear infinite}
@keyframes aiSpin{to{transform:rotate(360deg)}}
@keyframes dspin{to{transform:rotate(360deg)}}
.tpl-card.ai-card{border-color:rgba(108,99,255,.25);position:relative}
.tpl-card.ai-card::after{content:'AI';position:absolute;top:5px;right:5px;padding:1px 6px;border-radius:8px;background:linear-gradient(135deg,#6c63ff,#00d2ff);font-size:.55rem;font-weight:700;color:#fff;letter-spacing:.3px;z-index:2}
.ai-scroll-trigger{grid-column:1/-1;display:flex;align-items:center;justify-content:center;padding:14px;cursor:pointer;border-radius:var(--radius-sm);border:2px dashed rgba(108,99,255,.2);background:rgba(108,99,255,.04);transition:.25s;gap:8px;font-size:.78rem;color:var(--muted)}
.ai-scroll-trigger:hover{border-color:rgba(108,99,255,.4);background:rgba(108,99,255,.08);color:var(--text)}

/* ===== PDF MODAL ===== */
.pdf-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:500;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.pdf-modal{background:var(--panel2);border:1px solid var(--border);border-radius:var(--radius);padding:24px;min-width:340px;max-width:700px;width:95%;box-shadow:var(--shadow);animation:toastIn .25s ease}
.pdf-modal h3{font-size:1rem;font-weight:600;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.pdf-modal .pdf-sizes{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}
.pdf-modal .pdf-size-btn{padding:14px 10px;border-radius:var(--radius-sm);border:2px solid var(--border);background:rgba(128,128,128,.04);cursor:pointer;text-align:center;transition:.2s;color:var(--muted);font-family:var(--font);font-size:.78rem}
.pdf-modal .pdf-size-btn:hover{border-color:rgba(128,128,128,.2);background:rgba(128,128,128,.06)}
.pdf-modal .pdf-size-btn.active{border-color:var(--accent);background:var(--accent-glow);color:var(--text)}
.pdf-modal .pdf-size-btn .sz-detail{font-size:.6rem;color:var(--muted);margin-top:2px}
.pdf-modal .pdf-orient{display:flex;gap:8px;margin-bottom:16px}
.pdf-modal .pdf-orient-btn{flex:1;padding:10px;border-radius:var(--radius-sm);border:2px solid var(--border);background:rgba(128,128,128,.04);cursor:pointer;text-align:center;transition:.2s;color:var(--muted);font-family:var(--font);font-size:.78rem}
.pdf-modal .pdf-orient-btn:hover{border-color:rgba(128,128,128,.2)}
.pdf-modal .pdf-orient-btn.active{border-color:var(--accent);background:var(--accent-glow);color:var(--text)}
.pdf-modal .pdf-info{font-size:.72rem;color:var(--muted);padding:8px 12px;border-radius:var(--radius-sm);background:rgba(128,128,128,.04);margin-bottom:14px;line-height:1.5}
.pdf-modal .pdf-actions{display:flex;gap:8px;justify-content:flex-end}

/* ===== SNAP GUIDELINES ===== */
.snap-line{position:absolute;background:var(--accent);z-index:100;pointer-events:none}
.snap-line.h{height:1px;width:100%;left:0}
.snap-line.v{width:1px;height:100%;top:0}

/* ===== GRID OVERLAY ===== */
.grid-overlay{position:absolute;inset:0;pointer-events:none;z-index:1;opacity:.08}

/* ===== RESPONSIVE ===== */

/* ===== FONT DROPDOWN ===== */
.font-dropdown{position:relative;width:100%}
.font-dropdown-selected{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:rgba(128,128,128,.06);color:var(--text);font-size:.82rem;cursor:pointer;transition:.2s;min-height:40px}
.font-dropdown-selected:hover{border-color:rgba(128,128,128,.2)}
.font-dropdown.open .font-dropdown-selected{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.font-dropdown-list{display:none;position:absolute;top:100%;left:0;right:0;z-index:50;max-height:320px;overflow-y:auto;background:var(--panel2);border:1px solid var(--border);border-radius:0 0 var(--radius-sm) var(--radius-sm);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.font-dropdown.open .font-dropdown-list{display:block}
.font-dropdown-item{padding:10px 14px;cursor:pointer;transition:.15s;border-bottom:1px solid rgba(128,128,128,.05);display:flex;align-items:center;gap:10px;min-height:42px}
.font-dropdown-item:hover{background:rgba(108,99,255,.1)}
.font-dropdown-item.active{background:var(--accent-glow);color:var(--accent)}
.font-dropdown-item .fd-preview{flex:1;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.font-dropdown-item .fd-name{font-size:.6rem;color:var(--muted);min-width:60px;text-align:right;font-family:var(--font)!important}
.font-dropdown-cat{padding:8px 14px 5px;font-size:.6rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.5px;background:rgba(108,99,255,.08);border-bottom:1px solid var(--border)}

/* ===== RESPONSIVE ===== */

/* ===== FLOATING TEXT TOOLBAR ===== */
.floating-text-toolbar{position:absolute;top:8px;left:50%;transform:translateX(-50%);z-index:90;display:flex;align-items:center;gap:4px;padding:8px 16px;border-radius:16px;background:var(--panel2);border:1px solid var(--border);box-shadow:0 6px 28px rgba(0,0,0,.3);backdrop-filter:blur(14px);animation:ftbSlideIn .2s ease}
@keyframes ftbSlideIn{from{opacity:0;transform:translateX(-50%) translateY(-8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.ftb-btn{width:42px;height:40px;border:none;border-radius:10px;background:transparent;color:var(--text);font-size:1.05rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.15s;padding:0}
.ftb-btn:hover{background:rgba(108,99,255,.15);color:var(--accent)}
.ftb-btn.active{background:var(--accent);color:#fff}
.ftb-btn.ftb-danger:hover{background:rgba(244,67,54,.15);color:#f44336}
.ftb-sep{width:1px;height:28px;background:var(--border);margin:0 5px}
.ftb-size{font-size:.85rem;color:var(--muted);min-width:30px;text-align:center;font-weight:700}
.ftb-color-swatch{width:34px;height:34px;border:2px solid var(--border);border-radius:8px;cursor:pointer;position:relative;transition:.15s}
.ftb-color-swatch:hover{border-color:var(--accent);transform:scale(1.08)}

/* ===== CONTEXT POPUP ===== */
.ctx-popup{position:absolute;z-index:95;width:220px;background:#fff;border:1px solid rgba(0,0,0,.12);border-radius:14px;box-shadow:0 8px 32px rgba(0,0,0,.18);padding:0;animation:ctxIn .18s ease;overflow:hidden;user-select:none}
@keyframes ctxIn{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
.ctx-tabs{display:flex;border-bottom:1px solid rgba(0,0,0,.08);background:#fafafa}
.ctx-tab{flex:1;border:none;background:transparent;padding:7px 0;font-size:.85rem;cursor:pointer;transition:.15s;color:#888;border-bottom:2px solid transparent}
.ctx-tab:hover{background:rgba(108,99,255,.06)}
.ctx-tab.active{color:var(--accent);border-bottom-color:var(--accent);background:rgba(108,99,255,.04)}
.ctx-panel{display:none;padding:10px 12px 12px}
.ctx-panel.active{display:block}
.ctx-label{font-size:.62rem;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.ctx-mini-label{font-size:.55rem;color:#aaa;display:block;margin-bottom:1px}
.ctx-row{display:flex;gap:6px;align-items:center}
.ctx-colors-row{display:flex;gap:3px;flex-wrap:wrap;margin-bottom:6px}
.ctx-colors-row span{width:20px;height:20px;border-radius:5px;cursor:pointer;border:2px solid transparent;transition:.12s}
.ctx-colors-row span:hover{transform:scale(1.18);border-color:var(--accent)}
.ctx-colors-row span.active{border-color:var(--accent);box-shadow:0 0 0 2px rgba(108,99,255,.25)}
.ctx-color-pick{width:28px;height:28px;border:2px solid rgba(0,0,0,.1);border-radius:6px;padding:0;cursor:pointer}
.ctx-hex{flex:1;border:1px solid rgba(0,0,0,.1);border-radius:6px;padding:4px 6px;font-size:.7rem;font-family:var(--font);color:var(--text);outline:none}
.ctx-hex:focus{border-color:var(--accent)}
.ctx-range{width:100%;height:4px;-webkit-appearance:none;appearance:none;background:rgba(0,0,0,.08);border-radius:2px;outline:none;margin:4px 0}
.ctx-range::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.ctx-check{display:flex;align-items:center;gap:4px;font-size:.68rem;color:var(--text);cursor:pointer;font-weight:500}
.ctx-check input{accent-color:var(--accent)}
.ctx-presets{display:flex;gap:4px;flex-wrap:wrap;margin-top:6px}
.ctx-presets button{padding:3px 7px;border-radius:6px;border:1px solid rgba(0,0,0,.08);background:#fafafa;font-size:.58rem;cursor:pointer;color:#555;transition:.12s}
.ctx-presets button:hover{background:rgba(108,99,255,.1);border-color:var(--accent)}
.ctx-action-btn{display:block;width:100%;padding:6px 10px;border:none;border-radius:7px;background:#fafafa;font-size:.7rem;cursor:pointer;text-align:left;color:var(--text);transition:.12s;margin-bottom:3px;font-family:var(--font)}
.ctx-action-btn:hover{background:rgba(108,99,255,.1);color:var(--accent)}
.ctx-action-btn.ctx-danger{color:var(--danger)}
.ctx-action-btn.ctx-danger:hover{background:rgba(220,53,69,.08)}

/* ===== SWEETALERT2 CUSTOM ===== */
.swal-restart-popup{border-radius:20px!important;padding:2rem 1.5rem!important;font-family:var(--font)!important;box-shadow:0 25px 80px rgba(0,0,0,.2)!important}
.swal-restart-title{font-family:'Playfair Display',var(--font)!important;font-size:1.6rem!important;color:var(--text)!important}
.swal-restart-confirm{border-radius:12px!important;padding:12px 28px!important;font-size:.9rem!important;font-weight:600!important;font-family:var(--font)!important;transition:all .25s!important}
.swal-restart-confirm:hover{transform:translateY(-1px)!important;box-shadow:0 6px 20px rgba(231,76,60,.35)!important}
.swal-restart-cancel{border-radius:12px!important;padding:12px 28px!important;font-size:.9rem!important;font-weight:600!important;font-family:var(--font)!important;transition:all .25s!important}
.swal-restart-cancel:hover{transform:translateY(-1px)!important;box-shadow:0 4px 12px rgba(0,0,0,.15)!important}

@media(max-width:1100px){.app{grid-template-columns:300px 1fr 240px}}
@media(max-width:900px){
  .app{grid-template-columns:1fr;grid-template-rows:auto auto 1fr auto}
  .topbar{position:sticky;top:0}
  .sidebar{position:static;max-height:40vh;height:auto;border-right:none;border-bottom:1px solid var(--border)}
  .right-panel{position:static;max-height:28vh;height:auto;border-left:none;border-top:1px solid var(--border);flex-direction:row;flex-wrap:wrap}
}

/* ===== IRO.JS COLOR PICKER ===== */
.iro-swatch{width:36px;height:30px;border:2px solid var(--border);border-radius:8px;cursor:pointer;transition:.15s;position:relative;flex-shrink:0}
.iro-swatch:hover{border-color:var(--accent);transform:scale(1.06)}
.iro-swatch-sm{width:28px;height:24px;border-radius:6px}
.iro-popup{position:absolute;z-index:300;background:var(--panel);border:1px solid var(--border);border-radius:16px;box-shadow:0 8px 32px rgba(0,0,0,.25);padding:12px;animation:iroIn .15s ease;backdrop-filter:blur(12px)}
@keyframes iroIn{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
.iro-popup-hidden{display:none}
.iro-popup-fixed{position:fixed;z-index:9000}
.iro-hex-input{width:100%;margin-top:8px;padding:6px 8px;border:1px solid var(--border);border-radius:8px;font-size:.75rem;font-family:var(--font);text-align:center;background:rgba(128,128,128,.06);color:var(--text)}
.iro-hex-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}

/* ===== CUSTOM GRADIENT PALETTE CREATOR ===== */
.gradient-creator{padding:10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:rgba(128,128,128,.03)}
.gradient-preview{width:100%;height:48px;border-radius:10px;border:2px solid var(--border);margin-bottom:10px;cursor:pointer;transition:.2s}
.gradient-preview:hover{border-color:var(--accent)}
.gradient-stops{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}
.gradient-stop-row{display:flex;align-items:center;gap:6px}
.gradient-stop-row .iro-swatch{width:28px;height:24px}
.gradient-stop-row input[type="range"]{flex:1;height:4px}
.gradient-stop-row .stop-remove{width:22px;height:22px;border:none;border-radius:50%;background:rgba(220,53,69,.1);color:var(--danger);cursor:pointer;font-size:.7rem;display:flex;align-items:center;justify-content:center;transition:.15s}
.gradient-stop-row .stop-remove:hover{background:rgba(220,53,69,.25)}
.gradient-direction{display:flex;gap:4px;margin-bottom:8px}
.gradient-dir-btn{flex:1;padding:6px;border:1px solid var(--border);border-radius:8px;background:transparent;cursor:pointer;font-size:.7rem;text-align:center;transition:.15s;color:var(--muted);font-family:var(--font)}
.gradient-dir-btn:hover{border-color:rgba(128,128,128,.2);background:rgba(128,128,128,.05)}
.gradient-dir-btn.active{border-color:var(--accent);background:var(--accent-glow);color:var(--text)}
.gradient-actions{display:flex;gap:6px}

/* ===== ANGLE PICKER ===== */
.angle-picker{position:relative;width:64px;height:64px;border-radius:50%;border:2px solid var(--border);background:var(--panel);cursor:pointer;flex-shrink:0;transition:border-color .2s}
.angle-picker:hover{border-color:var(--accent)}
.angle-picker-track{position:absolute;inset:4px;border-radius:50%;border:1px dashed rgba(128,128,128,.2)}
.angle-picker-handle{position:absolute;width:12px;height:12px;border-radius:50%;background:var(--accent);box-shadow:0 2px 8px rgba(108,99,255,.4);transform:translate(-50%,-50%);transition:box-shadow .15s;z-index:2;top:0%;left:50%}
.angle-picker-handle:hover{box-shadow:0 2px 12px rgba(108,99,255,.6)}
.angle-picker-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700;color:var(--muted);pointer-events:none;z-index:1}

/* ===== DRAWING EXPANDED ===== */
.draw-options{display:flex;flex-direction:column;gap:6px}
.draw-row{display:flex;gap:6px;align-items:center}
.draw-row label{font-size:.68rem;color:var(--muted);min-width:60px}
