:root{--bg:#f5f6f8;--surface:#ffffff;--surface-2:#fbfbfc;--hover:#f3f4f6;--line:#e6e8ec;--line-2:#eef0f3;--ink:#1b2230;--muted:#6b7280;--faint:#9aa3af;--coral-50:#f8ece7;--coral-100:#f1d9ce;--coral-200:#e6bdab;--coral:#b9694f;--coral-600:#a4583f;--coral-700:#874634;--on-coral:#fff;--danger:#e5484d;--danger-bg:#fdecec;--warn:#c4790c;--warn-bg:#fbf1df;--success:#2f8f6b;--success-bg:#e6f4ee;--info:#3b6fd4;--info-bg:#eaf1fc;--t-purple:#7c5cdb;--t-purple-bg:#efeafb;--t-blue:#3b6fd4;--t-blue-bg:#eaf1fc;--t-teal:#0e9384;--t-teal-bg:#e3f4f1;--t-pink:#c43d8a;--t-pink-bg:#fbe8f2;--r-sm:6px;--r-md:8px;--r-lg:12px;--r-pill:999px;--sh-sm:0 1px 2px rgba(20,25,40,0.06),0 1px 1px rgba(20,25,40,0.04);--sh-md:0 10px 30px rgba(20,25,40,0.12);--sans:"Inter",system-ui,sans-serif;--mono:"JetBrains Mono",monospace;--nav:248px;--rail:#1a1916;--rail-2:#2b2926;--rail-ink:#b7b6b1;--rail-faint:#7e7d78;--coral-on-dark:#e0a487;--rail-w:68px;--flyout-w:248px;--field-gap:24px;--field-max:480px;--label-size:0.85rem;--label-gap:12px;--input-py:13px;--input-px:15px;--input-font:0.95rem;--input-radius:var(--r-lg);--hint-gap:7px;--btn-py:var(--input-py);--btn-px:var(--input-px);--btn-font:var(--input-font);--btn-radius:var(--input-radius);--btn-gap:7px;--btn-sm-py:9px;--btn-sm-px:13px;--btn-sm-font:0.88rem;--btn-lg-py:14px;--btn-lg-px:22px;--btn-lg-font:1rem;--control-h:calc(var(--input-py) * 2 + 1em + 2px);--atl-bg:var(--bg);--atl-surface:var(--surface);--atl-surface-2:var(--surface-2);--atl-hover:var(--hover);--atl-line:var(--line);--atl-line-2:var(--line-2);--atl-ink:var(--ink);--atl-muted:var(--muted);--atl-faint:var(--faint);--atl-coral-50:var(--coral-50);--atl-coral-100:var(--coral-100);--atl-coral-200:var(--coral-200);--atl-coral:var(--coral);--atl-coral-600:var(--coral-600);--atl-coral-700:var(--coral-700);--atl-on-coral:var(--on-coral);--atl-danger:var(--danger);--atl-danger-bg:var(--danger-bg);--atl-warn:var(--warn);--atl-warn-bg:var(--warn-bg);--atl-success:var(--success);--atl-success-bg:var(--success-bg);--atl-info:var(--info);--atl-info-bg:var(--info-bg);--atl-r-sm:var(--r-sm);--atl-r-md:var(--r-md);--atl-r-lg:var(--r-lg);--atl-r-xl:var(--r-lg);--atl-r-pill:var(--r-pill);--atl-sh-sm:var(--sh-sm);--atl-sh-md:var(--sh-md);--atl-sans:var(--sans);--atl-mono:var(--mono)}body{font-size:14px;line-height:1.5}code{font-family:var(--mono);font-size:.82em;background:var(--line-2);border:1px solid var(--line);border-radius:5px;padding:1px 5px;color:#3a4148}.app-shell{display:grid;grid-template-columns:var(--rail-w) 1fr;min-height:100vh;position:relative}.rail{position:-webkit-sticky;position:sticky;top:0;height:100vh;background:var(--rail);display:flex;flex-direction:column;align-items:center;padding:16px 0 14px;gap:4px;z-index:50}.rail .ri{width:44px;height:44px;border-radius:12px;border:none;background:transparent;display:grid;place-items:center;color:var(--rail-ink);cursor:pointer;transition:.14s;position:relative;text-decoration:none}.rail .ri:hover{background:var(--rail-2);color:#fff}.rail .ri.active{background:rgba(224,164,135,.16);color:var(--coral-on-dark)}.rail .ri.active:before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:3px;height:20px;border-radius:0 3px 3px 0;background:var(--coral-on-dark)}.rail .sp{flex:1 1}.flyout{position:fixed;left:var(--rail-w);top:0;bottom:0;width:var(--flyout-w);background:var(--surface);border-right:1px solid var(--line);box-shadow:var(--sh-md);padding:18px 14px;z-index:45;transition:transform .22s ease,opacity .22s}.flyout.closed{transform:translateX(calc(-1 * var(--flyout-w) - 4px));opacity:0;pointer-events:none}.flyout__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.flyout__head b{font-size:1.05rem;font-weight:700}.flyout__collapse{width:30px;height:30px;border-radius:var(--r-pill);border:1px solid var(--line);background:var(--surface);cursor:pointer;display:grid;place-items:center;color:var(--muted)}.flyout__collapse:hover{background:var(--hover)}.flyout__nav{display:flex;flex-direction:column;gap:2px}.flyout__nav a{padding:10px 12px;border-radius:var(--r-md);color:var(--ink);text-decoration:none;font-size:.92rem;font-weight:500}.flyout__nav a:hover{background:var(--hover)}.flyout__nav a.active{background:var(--coral-50);color:var(--coral-700);font-weight:600}.app-main{min-width:0;display:flex;flex-direction:column;min-height:100vh}.app-shell:has(.flyout:not(.closed)) .app-main{padding-left:var(--flyout-w);transition:padding-left .22s ease}.wrap{display:grid;grid-template-columns:var(--nav) 1fr;min-height:100vh}.side{position:-webkit-sticky;position:sticky;top:0;height:100vh;overflow-y:auto;background:var(--surface);border-right:1px solid var(--line);padding:22px 14px 40px}.side .brand{font-weight:700;letter-spacing:-.01em;font-size:1rem;color:var(--ink);text-decoration:none;display:block}.side .brand b{color:var(--coral)}.side .sub{font-size:.7rem;color:var(--faint);margin:2px 0 18px;letter-spacing:.02em}.side a.nav{display:block;color:var(--muted);font-size:.85rem;padding:7px 10px;border-radius:var(--r-sm);font-weight:500;text-decoration:none}.side a.nav:hover{background:var(--hover);color:var(--ink)}.side a.nav.active{background:var(--coral-50);color:var(--coral-700);font-weight:600}.side .grp{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);font-weight:600;margin:18px 0 6px;padding:0 10px}main{padding:0 0 100px;min-width:0}.inner{width:100%;max-width:none;margin:0;padding:26px clamp(20px,3vw,48px);min-width:0}.topbar{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg) var(--r-lg) 0 0;padding:12px 16px}.topbar .logo{font-weight:700;color:var(--ink);text-decoration:none}.topbar .logo b{color:var(--coral)}.topbar .ttl{font-weight:600;color:var(--ink)}.topbar .sp{margin-left:auto;display:flex;align-items:center;gap:12px}.iconbtn{width:32px;height:32px;border-radius:50%;border:none;background:transparent;color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.iconbtn:hover{background:var(--hover)}.vtabs{display:flex;gap:4px;background:var(--surface);border:1px solid var(--line);border-top:none;padding:0 12px}.vtab{padding:11px 12px;font-size:.84rem;font-weight:500;color:var(--muted);border-bottom:2px solid transparent;cursor:pointer;text-decoration:none}.vtab:hover{color:var(--ink)}.vtab.active{color:var(--coral);border-bottom-color:var(--coral);font-weight:600}button.vtab{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:none;font:inherit;margin:0;line-height:inherit}.vtab__count{margin-left:6px;font-size:.72rem;color:var(--faint);font-weight:500}.view-shell{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}.view-shell>.topbar{border:none;border-radius:0;border-bottom:1px solid var(--line)}.view-shell>.vtabs{border:none;border-bottom:1px solid var(--line)}.view-shell__meta{padding:14px 16px;border-bottom:1px solid var(--line);background:var(--surface);display:grid;grid-gap:var(--field-gap);gap:var(--field-gap)}.view-shell__body{padding:18px 20px 22px;background:var(--surface)}.view-shell .topbar__lead{display:flex;flex-direction:column;gap:2px;min-width:0}.view-shell .topbar .ttl{font-size:1.05rem;font-weight:700;letter-spacing:-.01em}.view-shell .topbar .sub{font-size:.82rem;color:var(--muted);font-weight:400}.detail-rows .row,.drawer .row{display:flex;gap:8px;align-items:flex-start;font-size:.82rem;padding:7px 0}.detail-rows .row .k,.drawer .row .k{color:var(--faint);min-width:92px;flex-shrink:0;font-size:.74rem;text-transform:uppercase;letter-spacing:.04em;padding-top:2px}.drawer{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-md);overflow:hidden}.drawer .dh{padding:14px 16px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:10px;font-weight:600}.drawer .db{padding:16px}.grid2{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr));grid-gap:14px;gap:14px}.searchbox{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-pill);padding:7px 14px;color:var(--faint);font-size:.82rem;min-width:220px}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:20px}.page-head h1{font-size:1.6rem;font-weight:700;letter-spacing:-.02em;margin:0;color:var(--ink)}.page-head .lede{color:var(--muted);font-size:.92rem;margin:6px 0 0}.card,.card-demo{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px}.note{display:flex;gap:10px;background:var(--coral-50);border:1px solid var(--coral-100);border-radius:var(--r-md);padding:12px 14px;font-size:.84rem;color:var(--coral-700);max-width:640px;margin-top:14px}.btn{box-sizing:border-box;font-family:inherit;font-size:var(--btn-font);font-weight:600;border-radius:var(--btn-radius);padding:var(--btn-py) var(--btn-px);min-height:var(--control-h);border:1px solid transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:var(--btn-gap);transition:.12s;line-height:1.2;text-decoration:none;white-space:nowrap}.btn.primary{background:var(--coral);color:var(--on-coral);border-color:var(--coral)}.btn.primary:hover:not(:disabled):not([disabled]){background:var(--coral-600);border-color:var(--coral-600)}.btn.outline{background:var(--surface);color:var(--ink);border-color:var(--line)}.btn.outline:hover:not(:disabled):not([disabled]){background:var(--hover);border-color:var(--line)}.btn.ghost{background:transparent;color:var(--muted);border-color:transparent}.btn.ghost:hover:not(:disabled):not([disabled]){background:var(--hover);color:var(--ink)}.btn.danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn.danger:hover:not(:disabled):not([disabled]){filter:brightness(.95)}.btn.coral-soft{background:var(--coral-50);color:var(--coral-700);border-color:var(--coral-100)}.btn.coral-soft:hover:not(:disabled):not([disabled]){background:var(--coral-100)}.btn.sm{min-height:calc(var(--btn-sm-py) * 2 + 1em + 2px);padding:var(--btn-sm-py) var(--btn-sm-px);font-size:var(--btn-sm-font)}.btn.lg{min-height:calc(var(--btn-lg-py) * 2 + 1em + 2px);padding:var(--btn-lg-py) var(--btn-lg-px);font-size:var(--btn-lg-font)}.btn:disabled,.btn[disabled]{cursor:not-allowed;pointer-events:none}.btn.primary:disabled,.btn.primary[disabled]{background:var(--coral-200);border-color:var(--coral-200);color:var(--on-coral);opacity:.85}.btn.outline:disabled,.btn.outline[disabled]{background:var(--surface-2);border-color:var(--line-2);color:var(--faint)}.btn.ghost:disabled,.btn.ghost[disabled]{background:transparent;color:var(--faint)}.btn.danger:disabled,.btn.danger[disabled]{background:#f0b4b6;border-color:#f0b4b6;color:#fff;opacity:.9}.btn.coral-soft:disabled,.btn.coral-soft[disabled]{background:var(--surface-2);border-color:var(--line-2);color:var(--faint)}.btn.loading{position:relative;color:transparent!important;pointer-events:none}.btn.loading:after{content:"";position:absolute;left:50%;top:50%;width:15px;height:15px;margin:-7.5px 0 0 -7.5px;border:2px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.btn.coral-soft.loading:after,.btn.ghost.loading:after,.btn.outline.loading:after{border-color:var(--coral-100);border-top-color:var(--coral)}.badge{display:inline-flex;align-items:center;gap:5px;font-size:.72rem;font-weight:600;border-radius:var(--r-pill);padding:3px 10px;line-height:1.4}.badge.crit{background:var(--danger-bg);color:var(--danger)}.badge.high{background:var(--coral-50);color:var(--coral-700)}.badge.late{background:var(--warn-bg);color:var(--warn)}.badge.done{background:var(--success-bg);color:var(--success)}.badge.todo{background:var(--line-2);color:var(--muted)}.badge.info{background:var(--info-bg);color:var(--info)}.badge.dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.tag{display:inline-flex;align-items:center;font-size:.72rem;font-weight:500;border-radius:var(--r-sm);padding:2px 8px}.tag.purple{background:var(--t-purple-bg);color:var(--t-purple)}.tag.blue{background:var(--t-blue-bg);color:var(--t-blue)}.tag.teal{background:var(--t-teal-bg);color:var(--t-teal)}.tag.pink{background:var(--t-pink-bg);color:var(--t-pink)}.state-pill{font-size:.72rem;font-weight:600;border-radius:var(--r-pill);padding:3px 10px;display:inline-flex;gap:6px;align-items:center}.state-pill.draft{background:var(--warn-bg);color:var(--warn)}.state-pill.pub{background:var(--success-bg);color:var(--success)}.state-pill .d{width:6px;height:6px;border-radius:50%;background:currentColor}.field{margin-bottom:var(--field-gap);max-width:var(--field-max)}.field--full{max-width:none}.field label{display:block;font-size:var(--label-size);font-weight:600;color:var(--ink);margin-bottom:var(--label-gap)}.input,.select,textarea.input{width:100%;box-sizing:border-box;font-family:inherit;font-size:var(--input-font);color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:var(--input-radius);padding:var(--input-py) var(--input-px);min-height:var(--control-h);transition:.12s}.input:focus,.select:focus,textarea.input:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 3px var(--coral-50)}.input[aria-invalid=true]{border-color:var(--danger)}.input[disabled],.select[disabled],textarea.input[disabled]{background:#f1f3f6;color:var(--faint);cursor:not-allowed}.select{-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5' stroke='%236b7280' stroke-width='1.4' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}textarea.input{resize:vertical;line-height:1.5;min-height:104px}.hint{color:var(--faint)}.field-error,.hint{font-size:.78rem;margin-top:var(--hint-gap)}.field-error{color:var(--danger)}.input-wrap{position:relative}.input-wrap--password .input{padding-right:44px}.input-toggle{position:absolute;top:50%;right:10px;transform:translateY(-50%);display:grid;place-items:center;width:32px;height:32px;border:0;border-radius:999px;background:transparent;color:var(--muted);cursor:pointer}.input-toggle:hover{color:var(--ink);background:var(--line-2,#eef0f3)}.password-rules{list-style:none;margin:var(--hint-gap) 0 0;padding:0;display:grid;grid-gap:4px;gap:4px;font-size:.78rem;color:var(--faint)}.password-rules li{display:flex;align-items:center;gap:8px}.password-rules li.is-ok{color:var(--success,#1f7a4d)}.password-rules__mark{width:14px;flex:0 0 auto;text-align:center;font-weight:700}.tag-field{margin-bottom:var(--field-gap);max-width:var(--field-max);position:relative}.tag-field--full{max-width:none}.tag-field label{display:block;font-size:var(--label-size);font-weight:600;color:var(--ink);margin-bottom:var(--label-gap)}.taginput{display:flex;flex-wrap:wrap;align-items:center;gap:7px;border:1px solid var(--line);border-radius:var(--input-radius);padding:8px 10px;background:var(--surface);min-height:var(--control-h);cursor:text;transition:.12s}.taginput.open{border-color:var(--coral);box-shadow:0 0 0 3px var(--coral-50)}.taginput input{flex:1 1;min-width:120px;border:none;outline:none;font:inherit;font-size:var(--input-font);background:transparent;padding:4px;color:var(--ink)}.tagchip{display:inline-flex;align-items:center;gap:7px;background:var(--hover);border-radius:var(--r-pill);padding:5px 6px 5px 12px;font-size:.84rem;font-weight:500;color:var(--ink)}.tagchip__x{width:18px;height:18px;border-radius:99px;display:grid;place-items:center;cursor:pointer;color:var(--muted);border:none;background:transparent;padding:0;font:inherit;line-height:1}.tagchip__x:hover{background:#e2ddd5}.tagmenu{position:absolute;z-index:20;left:0;right:0;margin-top:6px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--sh-md);padding:6px;max-width:360px}.tagmenu__opt{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:9px 10px;border-radius:8px;cursor:pointer;font-size:.9rem;border:none;background:transparent;color:var(--ink);font:inherit}.tagmenu__opt:hover,.tagmenu__opt[data-active=true]{background:var(--hover)}.tagmenu__create{color:var(--muted);font-size:.84rem}.form-actions{display:flex;gap:12px;justify-content:flex-end;align-items:center;margin-top:28px}.form-actions--start{justify-content:flex-start}.field-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px;margin-bottom:var(--field-gap)}.field-row .field{margin-bottom:0;max-width:none}.control-row{display:flex;flex-wrap:wrap;align-items:stretch;gap:10px}.control-row .input,.control-row .select{width:auto}.control-row .btn{align-self:stretch}.link-back{display:inline-flex;align-items:center;gap:4px;font-size:.88rem;font-weight:500;color:var(--muted);text-decoration:none}.link-back:hover{color:var(--ink)}.toggle{width:38px;height:22px;background:var(--line);border-radius:var(--r-pill);position:relative;cursor:pointer;border:none;transition:.15s;flex:0 0 auto;padding:0}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;box-shadow:var(--sh-sm);transition:.15s}.toggle.on{background:var(--coral)}.toggle.on:after{left:18px}.switch-row{display:inline-flex;align-items:center;gap:12px}.switch-row .st{font-size:.84rem}.switch-row .st b{display:block;font-weight:600;color:var(--ink)}.switch-row .st span{color:var(--muted);font-size:.8rem}.callout{display:flex;gap:10px;background:var(--info-bg);border-left:3px solid var(--info);border-radius:0 var(--r-md) var(--r-md) 0;padding:11px 14px;font-size:.84rem;color:#33508a;max-width:520px}.av{width:30px;height:30px;border-radius:50%;background:var(--coral-100);color:var(--coral-700);display:inline-flex;align-items:center;justify-content:center;font-size:.74rem;font-weight:600;overflow:hidden;object-fit:cover}.av.sm{width:24px;height:24px;font-size:.64rem}.tbl-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--r-lg)}.tbl-wrap .tbl{min-width:760px}.tbl{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;font-size:.84rem}.tbl th{text-align:left;font-size:.68rem;letter-spacing:.04em;text-transform:uppercase;color:var(--faint);font-weight:600;background:var(--surface-2);border-bottom:1px solid var(--line)}.tbl td,.tbl th{padding:11px 14px}.tbl td{border-bottom:1px solid var(--line-2);color:var(--ink)}.tbl tr:last-child td{border-bottom:none}.tbl tbody tr:hover{background:var(--hover)}.tbl .empty{color:var(--faint);padding:0;border:none;border-radius:0;background:transparent;text-align:inherit;font-size:inherit;display:inline}.empty{text-align:center;padding:34px;color:var(--faint);font-size:.88rem;border:1px dashed var(--line);border-radius:var(--r-lg);background:var(--surface-2)}.empty .ic{font-size:1.6rem;margin-bottom:8px}.empty .et{font-weight:600;color:var(--ink);font-size:.95rem;margin-bottom:4px}.toast{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--success);border-radius:var(--r-md);box-shadow:var(--sh-md);padding:12px 16px;font-size:.86rem;max-width:340px}.toast.err{border-left-color:var(--danger)}.toast.info{border-left-color:var(--info)}.alert{display:flex;gap:10px;align-items:flex-start;border-radius:var(--r-md);padding:11px 14px;font-size:.86rem;max-width:520px;border:1px solid}.alert.ok{background:var(--success-bg);border-color:#bfe3d2;color:#1f6b4f}.alert.err{background:var(--danger-bg);border-color:#f4c4c4;color:#a3282c}.alert.warn{background:var(--warn-bg);border-color:#ecd5a6;color:#8a5a0c}.modal-bg{position:fixed;inset:0;background:rgba(12,15,22,.5);display:none;align-items:center;justify-content:center;z-index:90;padding:20px}.modal,.modal-bg--open{display:flex}.modal{background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--sh-md);max-width:430px;width:100%;overflow:hidden;flex-direction:column;max-height:min(90vh,920px)}.modal--lead{max-width:min(960px,100%)}.modal__head{justify-content:flex-end;padding:14px 18px;border-bottom:1px solid var(--line-2);background:var(--surface);flex-shrink:0}.modal__head,.modal__head-actions{display:flex;align-items:center;gap:10px}.modal__x{width:36px;height:36px;border-radius:99px;border:1px solid var(--line);background:var(--surface);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);padding:0;flex-shrink:0}.modal__x:hover{background:var(--hover);color:var(--ink)}.modal__body--scroll{overflow:auto;padding:20px 22px 24px;flex:1 1;min-height:0}.modal .mh{padding:18px 20px 4px;font-size:1.05rem;font-weight:600}.modal .mb{padding:6px 20px 18px;color:var(--muted);font-size:.88rem}.modal .mf{display:flex;gap:10px;justify-content:flex-end;padding:14px 20px;border-top:1px solid var(--line);background:var(--surface-2)}.progress{height:8px;background:var(--line-2);overflow:hidden;max-width:420px}.progress,.progress>i{border-radius:var(--r-pill)}.progress>i{display:block;height:100%;background:var(--coral);transition:width .5s}.progress.warn>i{background:var(--warn)}.progress.danger>i{background:var(--danger)}.spin{width:20px;height:20px;border:2.5px solid var(--line);border-top-color:var(--coral);border-radius:50%;animation:spin .7s linear infinite;display:inline-block;flex:0 0 auto}.spin.sm{width:14px;height:14px;border-width:2px}.spin.lg{width:34px;height:34px;border-width:3px}@keyframes spin{to{transform:rotate(1turn)}}.skel{background:linear-gradient(90deg,var(--line-2) 25%,var(--hover) 37%,var(--line-2) 63%);background-size:400% 100%;animation:shimmer 1.4s ease infinite;border-radius:var(--r-sm)}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.money{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);overflow:hidden;max-width:210px}.money .cur{padding:9px 10px;background:var(--surface-2);color:var(--muted);font-size:.82rem;border-right:1px solid var(--line)}.money input{border:none;outline:none;font-family:inherit;font-size:.9rem;padding:9px 10px;width:100%;text-align:right;color:var(--ink);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.money:focus-within{border-color:var(--coral);box-shadow:0 0 0 3px var(--coral-50)}.dropz{border:2px dashed var(--line);border-radius:var(--r-lg);padding:26px;text-align:center;color:var(--muted);background:var(--surface-2);cursor:pointer;transition:.15s}.dropz.drag,.dropz:hover{border-color:var(--coral);background:var(--coral-50);color:var(--coral-700)}.gal{display:grid;grid-template-columns:repeat(auto-fill,minmax(116px,1fr));grid-gap:8px;gap:8px}.gal .g{aspect-ratio:4/3;border-radius:var(--r-md);overflow:hidden;cursor:pointer;border:1px solid var(--line);background:var(--line-2)}.gal .g img{width:100%;height:100%;object-fit:cover;display:block}.i18n .langs{display:flex;gap:5px;margin-bottom:8px}.i18n .lang{font-size:.74rem;font-weight:600;padding:4px 10px;border-radius:var(--r-pill);border:1px solid var(--line);background:var(--surface);color:var(--muted);cursor:pointer}.i18n .lang.on{border-color:var(--coral);color:var(--coral-700);background:var(--coral-50)}.dark-scope{background:#0e1014;border:1px solid #20242c;border-radius:var(--r-lg);padding:28px}.dark-scope h4{font-family:Georgia,Times New Roman,serif;font-size:1.7rem;font-weight:500;letter-spacing:-.01em;margin:8px 0 10px;color:#f4f2ee}.dark-scope p{color:#a8acb3;font-size:.9rem;line-height:1.6}@media (max-width:880px){.app-shell{grid-template-columns:1fr}.rail{position:fixed;bottom:0;left:0;right:0;top:auto;height:auto;flex-direction:row;padding:8px 12px;gap:2px;justify-content:space-around;border-top:1px solid var(--rail-2)}.rail .ri.active:before,.rail .sp{display:none}.flyout{left:0;width:min(100%,280px)}.flyout.closed{transform:translateX(-110%)}.app-main{padding-bottom:72px}.app-shell:has(.flyout:not(.closed)) .app-main{padding-left:0}.wrap{grid-template-columns:1fr}.side{position:static;height:auto;border-right:none;border-bottom:1px solid var(--line)}}.portal-body{background:#fbfaf9;min-height:100vh}.portal-topbar{display:flex;align-items:center;height:56px;padding:0 clamp(20px,4vw,32px);border-bottom:1px solid var(--line,#e8e4de);background:#fff}.portal-scope{--bg:#fbfaf9;color:var(--ink)}.portal-scope.inner{max-width:720px;margin:0 auto;padding:28px clamp(20px,4vw,32px) 48px}.portal-head{margin:16px 0 20px}.portal-head__studio{margin:0 0 4px;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--faint)}.portal-head__title{margin:0;font-size:1.5rem;font-weight:700;letter-spacing:-.02em}.portal-launcher{display:grid;grid-gap:12px;gap:12px}.portal-launcher__card{display:block;text-decoration:none;color:inherit;padding:18px 20px;transition:.12s}.portal-launcher__card:hover{border-color:var(--coral-200);box-shadow:var(--sh-sm)}.portal-launcher__studio{display:block;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--faint);margin-bottom:6px}.portal-meta{color:var(--muted);font-size:.84rem}.portal-list{margin:0;padding:0;list-style:none;display:grid;grid-gap:12px;gap:12px}.portal-list__item{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:14px 16px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface-2)}.portal-actions-row{display:flex;flex-wrap:wrap;gap:8px;flex-shrink:0}.portal-chat{margin:0 0 16px;padding:0;list-style:none;display:grid;grid-gap:10px;gap:10px}.portal-chat__msg{padding:10px 12px;border-radius:var(--r-md);border:1px solid var(--line);font-size:.88rem;max-width:85%}.portal-chat__msg--client{margin-left:auto;background:var(--coral-50);border-color:var(--coral-100)}.portal-chat__msg--architect{background:var(--surface-2)}.portal-chat__meta{font-size:.72rem;color:var(--faint);margin-bottom:4px}.portal-history{margin:0;padding:0;list-style:none;display:grid;grid-gap:8px;gap:8px}.portal-history__item{display:grid;grid-template-columns:140px 90px 1fr;grid-gap:10px;gap:10px;font-size:.84rem;padding:8px 0;border-bottom:1px solid var(--line-2)}.portal-history__at{color:var(--faint);font-size:.76rem}.portal-history__kind{font-weight:600;text-transform:uppercase;font-size:.68rem;letter-spacing:.04em;color:var(--muted)}.login-wrap{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}.login-form-col{display:flex;align-items:center;justify-content:center;padding:40px 24px}.login-form-inner{width:100%;max-width:380px}@media (max-width:880px){.login-wrap{grid-template-columns:1fr}}