:root{--cream:#eae4d8;--cream-dark:#ddd6c8;--parchment:#d0c9b8;--ink:#2c2418;--ink-soft:#46382a;--ink-muted:#8e7e68;--nav-bg:#2c2418;--terracotta:#b86240;--terracotta-light:#cc8060;--sage:#688060;--sage-light:#88a080;--gold:#a87830;--gold-light:#c89848;--border:rgba(44,36,24,.12);--border-strong:rgba(44,36,24,.24);--paper:var(--cream);--ctrl-h:40px;--font-mono:"JetBrains Mono","Courier New",monospace}*{box-sizing:border-box;margin:0;padding:0}body,html{background:var(--cream);color:var(--ink);font-family:DM Sans,system-ui,sans-serif;font-weight:400;font-size:15px;line-height:1.6;min-height:100vh}html{touch-action:manipulation}*{-webkit-tap-highlight-color:transparent}::-webkit-scrollbar{width:7px;height:7px}::-webkit-scrollbar-track{background:var(--cream-dark)}::-webkit-scrollbar-thumb{background:var(--parchment);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--ink-muted)}.app-shell{display:flex;flex-direction:row;min-height:100vh}.sidenav{width:260px;flex-shrink:0;background:var(--nav-bg);display:flex;flex-direction:column;position:-webkit-sticky;position:sticky;top:0;height:100vh;overflow-y:auto;scrollbar-width:none;z-index:50}.sidenav::-webkit-scrollbar{display:none}.sidenav-brand{padding:22px 18px 18px;border-bottom:1px solid hsla(0,0%,100%,.09)}.sidenav-brand h1{font-family:Georgia,serif;font-size:1.45rem;font-weight:400;color:var(--cream)}.sidenav-brand p{font-size:.72rem;color:hsla(40,30%,88%,.4);margin-top:3px;text-transform:uppercase;letter-spacing:.09em}.sidenav-section{padding:12px 10px 6px}.sidenav-section-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:hsla(40,30%,88%,.38);padding:0 10px 8px}.sidenav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:7px;cursor:pointer;color:hsla(40,30%,88%,.7);font-size:.88rem;font-weight:400;border:none;background:none;width:100%;text-align:left;transition:background .12s,color .12s;min-height:44px}.sidenav-item:hover{background:hsla(0,0%,100%,.08);color:var(--cream)}.sidenav-item.active{background:rgba(184,98,64,.25);color:var(--terracotta-light)}.sidenav-footer{margin-top:auto;padding:14px 10px;border-top:1px solid hsla(0,0%,100%,.09)}.sidenav-user{font-size:.8rem;color:hsla(40,30%,88%,.45);padding:0 10px 10px}.page{flex:1 1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.page-header{display:flex;align-items:center;gap:10px;padding:12px 20px;background:var(--cream-dark);border-bottom:2px solid var(--border-strong);flex-shrink:0;flex-wrap:wrap;min-height:58px}.page-header h2{font-size:1rem;font-weight:600;color:var(--ink);margin-right:4px}.btn{display:inline-flex;align-items:center;gap:.45rem;padding:.5rem 1rem;border-radius:6px;font-size:.88rem;font-weight:500;cursor:pointer;border:none;transition:background .12s,color .12s;white-space:nowrap;font-family:inherit;min-height:38px}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--terracotta);color:var(--cream)}.btn-primary:hover:not(:disabled){background:var(--terracotta-light)}.btn-secondary{background:transparent;color:var(--ink-soft);border:1.5px solid var(--border-strong)}.btn-secondary:hover:not(:disabled){background:var(--parchment)}.btn-ghost{background:transparent;color:var(--ink-muted);padding:.45rem .7rem}.btn-ghost:hover:not(:disabled){color:var(--ink);background:var(--cream-dark)}.btn-danger{background:transparent;color:#c04040;border:1.5px solid rgba(192,64,64,.35)}.btn-danger:hover:not(:disabled){background:rgba(192,64,64,.1)}.btn-sm{padding:0 .85rem;font-size:.82rem;height:var(--ctrl-h);min-height:var(--ctrl-h)}.tool-palette{display:flex;align-items:center;gap:3px;background:var(--parchment);border:1.5px solid var(--border-strong);border-radius:8px;padding:4px}.tool-btn{display:inline-flex;align-items:center;gap:7px;padding:7px 13px;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;border:none;background:transparent;color:var(--ink-muted);transition:all .12s;font-family:inherit;white-space:nowrap;min-height:38px}.tool-btn:hover{background:var(--cream);color:var(--ink)}.tool-btn.active{background:var(--nav-bg);color:var(--cream)}.props-panel{width:288px;flex-shrink:0;background:var(--cream);border-left:2px solid var(--border-strong);display:flex;flex-direction:column;overflow-y:auto}.props-panel-header{padding:14px 16px 12px;font-size:.76rem;text-transform:uppercase;letter-spacing:.09em;color:var(--ink-muted);font-weight:600}.props-panel-header,.props-section{border-bottom:1px solid var(--border)}.props-section{padding:14px 16px}.props-section-title{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-muted);margin-bottom:11px;font-weight:600}.props-row{display:flex;align-items:center;gap:8px;margin-bottom:9px}.props-label{font-size:.82rem;color:var(--ink-muted);width:54px;flex-shrink:0}.props-input{flex:1 1;height:36px;padding:0 10px;border:1.5px solid var(--border-strong);border-radius:5px;background:var(--paper);color:var(--ink);font-size:.88rem;font-family:var(--font-mono);transition:border-color .12s}.props-input:focus{outline:none;border-color:var(--terracotta);box-shadow:0 0 0 2px rgba(184,98,64,.15)}.props-input-full{width:100%;height:36px;padding:0 10px;border:1.5px solid var(--border-strong);border-radius:5px;background:var(--paper);color:var(--ink);font-size:.9rem;font-family:inherit}.props-input-full:focus{outline:none;border-color:var(--terracotta)}.props-hint{font-size:.76rem;color:var(--ink-muted);margin-top:4px;line-height:1.5}.props-empty{padding:24px 16px;text-align:center;color:var(--ink-muted);font-size:.88rem;line-height:1.7}.color-swatches{display:flex;gap:7px;flex-wrap:wrap}.color-swatch{width:26px;height:26px;border-radius:5px;cursor:pointer;border:2px solid transparent;transition:border-color .12s,transform .1s}.color-swatch:hover{transform:scale(1.18)}.color-swatch.selected{border-color:var(--ink);box-shadow:0 0 0 1px var(--ink)}.fp-list{padding:8px 10px;flex:1 1;overflow-y:auto}.fp-item{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:7px;cursor:pointer;font-size:.88rem;color:hsla(40,30%,88%,.65);transition:background .12s,color .12s;border:none;background:none;width:100%;text-align:left;min-height:44px}.fp-item:hover{background:hsla(0,0%,100%,.08);color:var(--cream)}.fp-item.active{background:rgba(184,98,64,.25);color:var(--terracotta-light)}.fp-item-name{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-overlay{position:fixed;inset:0;background:rgba(44,36,24,.5);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.modal{background:var(--cream);border-radius:12px;width:100%;max-width:420px;box-shadow:0 12px 48px rgba(44,36,24,.28)}.modal-header{padding:20px 22px 14px;border-bottom:1px solid var(--border);font-size:1.05rem;font-weight:600}.modal-body{padding:20px 22px}.modal-footer{padding:14px 22px 18px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.field{margin-bottom:16px}.field label{display:block;font-size:.8rem;color:var(--ink-muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.06em;font-weight:500}.field input,.field select{width:100%;height:42px;padding:0 12px;border:1.5px solid var(--border-strong);border-radius:6px;background:var(--paper);color:var(--ink);font-size:.95rem;font-family:inherit;transition:border-color .12s}.field input:focus,.field select:focus{outline:none;border-color:var(--terracotta);box-shadow:0 0 0 3px rgba(184,98,64,.12)}.field-error{font-size:.8rem;color:#c04040;margin-top:4px}.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--cream)}.auth-card{width:100%;max-width:400px;padding:40px 36px;background:var(--paper);border-radius:14px;border:1.5px solid var(--border-strong);box-shadow:0 6px 32px rgba(44,36,24,.12)}.auth-title{font-family:Georgia,serif;font-size:2rem;font-weight:400;color:var(--ink);margin-bottom:6px}.auth-sub{margin-bottom:28px}.auth-sub,.auth-toggle{font-size:.88rem;color:var(--ink-muted)}.auth-toggle{text-align:center;margin-top:18px}.auth-toggle button{color:var(--terracotta);font-size:inherit;font-family:inherit;text-decoration:underline;font-weight:500}.auth-toggle button,.zoom-btn{background:none;border:none;cursor:pointer}.zoom-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;color:var(--ink-muted);font-size:1.15rem;transition:background .1s}.zoom-btn:hover{background:var(--cream-dark);color:var(--ink)}.zoom-level{width:38px;height:26px;display:flex;align-items:center;justify-content:center;font-size:.68rem;font-family:var(--font-mono);color:var(--ink-muted);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}@media (max-width:768px){.props-panel,.sidenav{display:none}.page-header{padding:10px 12px;min-height:50px}}