:root{--bg:#f3efe5;--surface:#fffaf1;--ink:#1f2a2a;--muted:#5d6a6a;--line:#d6cbb2;--accent:#0f766e;--accent-h:#0d655d;--amber:#d97706;--danger:#dc2626;--done-bg:#dcfce7;--done-fg:#166534;--blue-bg:#dbeafe;--blue-fg:#1e40af;--amber-bg:#fef3c7;--amber-fg:#92400e;--plan-bg:#f3f4f6;--plan-fg:#6b7280;--purple-bg:#ede9fe;--purple-fg:#5b21b6;--wip-bg:#fef9c3;--wip-fg:#854d0e;--urg-bg:#fee2e2;--urg-fg:#991b1b;--r-sm:8px;--r-md:14px;--r-lg:20px;--safe-b:env(safe-area-inset-bottom,0px)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{min-height:100dvh;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;font-size:16px;line-height:1.5;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
.app{max-width:600px;margin:0 auto;padding:16px;padding-bottom:calc(72px + var(--safe-b))}
@media(min-width:768px){.app{max-width:720px;padding:32px 24px 48px}}

/* Header */
.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;min-height:44px}
.header h1{font-size:18px;font-weight:700}
.header-r{display:flex;align-items:center;gap:8px}
.uname{font-size:12px;color:var(--muted);display:none}
@media(min-width:480px){.uname{display:block}}
.bi{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);cursor:pointer;color:var(--muted);transition:all .15s}
.bi:hover{border-color:var(--accent);color:var(--accent)}.bi:active{transform:scale(.96)}.bi svg{width:18px;height:18px}

/* Login */
.lw{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:24px}
.lb{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:32px 24px;width:100%;max-width:380px;box-shadow:0 20px 60px rgba(31,42,42,.08)}
.lb h1{font-size:24px;margin-bottom:4px}.lb .sub{color:var(--muted);font-size:14px;margin-bottom:24px}
.fld{margin-bottom:14px}.fld label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:4px}
.fld input{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:var(--r-sm);font-size:16px;font-family:inherit;background:#fff;outline:none;transition:border-color .15s;min-height:44px}
.fld input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(15,118,110,.12)}
.bp{display:block;width:100%;padding:14px;border:none;border-radius:var(--r-sm);font-size:16px;font-weight:600;font-family:inherit;background:var(--accent);color:#fff;cursor:pointer;min-height:48px;margin-top:8px}
.bp:hover{background:var(--accent-h)}.bp:active{transform:scale(.98)}.bp:disabled{opacity:.5;cursor:not-allowed}
.err{background:#fef2f2;color:var(--danger);border:1px solid #fecaca;border-radius:var(--r-sm);padding:10px 14px;font-size:14px;margin-bottom:14px;display:none}

/* Bottom Nav */
.bnav{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--line);display:flex;justify-content:center;padding-bottom:var(--safe-b);z-index:100}
.bni{display:flex;width:100%;max-width:600px}
.ni{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-height:56px;border:none;background:none;cursor:pointer;color:var(--muted);font-size:10px;font-weight:600;font-family:inherit;transition:color .15s;position:relative;padding:8px 4px}
.ni svg{width:20px;height:20px}.ni.a{color:var(--accent)}.ni.a::after{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:28px;height:3px;background:var(--accent);border-radius:0 0 3px 3px}.ni:active{transform:scale(.95)}

/* Carousel */
.cw{margin-bottom:14px}.car{display:flex;gap:10px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:2px 0}.car::-webkit-scrollbar{display:none}.car>*{scroll-snap-align:start;flex-shrink:0}

/* Dash cards */
.dc{width:140px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:12px;text-align:center}
.dc .v{font-size:22px;font-weight:700;color:var(--accent);line-height:1.1}.dc .v.ld{color:var(--line)}
.dc .l{font-size:10px;color:var(--muted);margin-top:2px;font-weight:500}
.dc .sp{height:20px;display:flex;align-items:flex-end;gap:2px;justify-content:center;margin-top:4px}
.dc .b{width:5px;border-radius:2px 2px 0 0;background:var(--accent);opacity:.25}
.dc .b.h1{height:6px}.dc .b.h2{height:11px}.dc .b.h3{height:16px;opacity:.6}.dc .b.h4{height:20px;opacity:1}

/* QA cards */
.qa{width:90px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:10px 6px;display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;transition:all .15s;text-decoration:none;color:var(--ink);min-height:80px;justify-content:center}
.qa:hover{border-color:var(--accent)}.qa:active{transform:scale(.96)}
.qi{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center}
.qi svg{width:16px;height:16px}
.qi.g{background:var(--done-bg);color:var(--done-fg)}.qi.b{background:var(--blue-bg);color:var(--blue-fg)}.qi.am{background:var(--amber-bg);color:var(--amber-fg)}.qi.p{background:var(--purple-bg);color:var(--purple-fg)}
.qa span{font-size:10px;font-weight:600;text-align:center;line-height:1.2}

/* Infra carousel cards */
.ic{width:200px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:14px}
.ic h4{font-size:13px;font-weight:700;margin-bottom:8px;color:var(--accent)}
.ic-row{display:flex;align-items:center;gap:6px;font-size:12px;margin-bottom:4px}
.ic-row svg{width:14px;height:14px;color:var(--accent);flex-shrink:0}
.ic-row .k{color:var(--muted);font-weight:500}.ic-row .vl{font-weight:600}
.ic-dot{width:7px;height:7px;border-radius:50%;background:var(--done-fg);flex-shrink:0}

/* Section label */
.sec{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin:18px 0 8px;display:flex;align-items:center;gap:8px}

/* Solution cards */
.sol-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.sol{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:14px;position:relative;transition:all .15s;cursor:pointer;min-height:80px}
.sol:hover{border-color:var(--accent)}
.sol-title{font-size:14px;font-weight:700;margin-bottom:2px}
.sol-desc{font-size:11px;color:var(--muted);line-height:1.3}
.sol-link{display:inline-block;font-size:11px;color:var(--accent);margin-top:4px;text-decoration:none;font-weight:600}
.sol-link:hover{text-decoration:underline}
.sol-edit{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:6px;border:1px solid var(--line);background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);opacity:0;transition:opacity .15s}
.sol:hover .sol-edit{opacity:1}
.sol-edit svg{width:14px;height:14px}
.sol-add{background:var(--bg);border:2px dashed var(--line);border-radius:var(--r-md);padding:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);font-size:13px;font-weight:600;min-height:80px;transition:all .15s}
.sol-add:hover{border-color:var(--accent);color:var(--accent)}

/* Accordion */
.acc{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);margin-bottom:8px;overflow:hidden}
.acc-h{display:flex;align-items:center;gap:8px;padding:12px 14px;cursor:pointer;min-height:48px;-webkit-tap-highlight-color:transparent}
.acc-h:active{background:rgba(0,0,0,.02)}
.acc-arr{width:18px;height:18px;color:var(--muted);transition:transform .2s;flex-shrink:0}
.acc.open .acc-arr{transform:rotate(90deg)}
.acc-bg{font-size:10px;font-weight:700;padding:2px 7px;border-radius:4px;text-transform:uppercase;letter-spacing:.03em;flex-shrink:0}
.acc-bg.done{background:var(--done-bg);color:var(--done-fg)}.acc-bg.wip{background:var(--wip-bg);color:var(--wip-fg)}.acc-bg.plan{background:var(--plan-bg);color:var(--plan-fg)}
.acc-t{font-size:13px;font-weight:600;flex:1}
.acc-body{max-height:0;overflow:hidden;transition:max-height .25s ease}
.acc.open .acc-body{max-height:2000px}
.acc-in{padding:0 14px 14px}

/* Phase items */
.pi{display:flex;align-items:flex-start;gap:8px;padding:6px 0;border-bottom:1px solid rgba(0,0,0,.04);font-size:13px}
.pi:last-child{border-bottom:none}
.pi-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:6px}
.pi-dot.done{background:var(--done-fg)}.pi-dot.pending{background:var(--plan-fg)}.pi-dot.wip{background:var(--wip-fg)}
.pi-text{flex:1;color:var(--muted);line-height:1.3}
.pi-text.done{color:var(--ink)}
.pi-meta{display:flex;gap:4px;align-items:center;flex-wrap:wrap;margin-top:2px}
.pi-date{font-size:10px;color:var(--plan-fg)}
.pi-author{font-size:10px;color:var(--plan-fg);font-weight:500}
.pi-urg{font-size:9px;font-weight:700;padding:1px 5px;border-radius:3px;background:var(--urg-bg);color:var(--urg-fg);text-transform:uppercase}
.pi-edit{width:24px;height:24px;border-radius:4px;border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);opacity:0;flex-shrink:0}
.pi:hover .pi-edit{opacity:1}
.pi-edit svg{width:12px;height:12px}
.pi-add{display:flex;align-items:center;justify-content:center;padding:8px;cursor:pointer;color:var(--muted);font-size:12px;font-weight:600;gap:4px;border-top:1px dashed var(--line);margin-top:4px}
.pi-add:hover{color:var(--accent)}
.pi-add svg{width:14px;height:14px}

/* Modal */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:200;display:flex;align-items:flex-end;justify-content:center;padding:0}
@media(min-width:480px){.modal-bg{align-items:center;padding:24px}}
.modal{background:var(--surface);border-radius:var(--r-lg) var(--r-lg) 0 0;padding:24px;width:100%;max-width:420px;max-height:90vh;overflow-y:auto}
@media(min-width:480px){.modal{border-radius:var(--r-lg)}}
.modal h3{font-size:18px;margin-bottom:16px}
.modal .fld input,.modal .fld select,.modal .fld textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r-sm);font-size:14px;font-family:inherit;background:#fff;outline:none;min-height:44px}
.modal .fld textarea{min-height:60px;resize:vertical}
.modal .fld select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235d6a6a' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.modal-actions{display:flex;gap:8px;margin-top:16px}
.modal-actions button{flex:1;padding:12px;border-radius:var(--r-sm);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;min-height:44px;border:none}
.modal-actions .save{background:var(--accent);color:#fff}
.modal-actions .cancel{background:var(--plan-bg);color:var(--ink)}
.modal-actions .del{background:var(--urg-bg);color:var(--urg-fg);flex:0;padding:12px 16px}
.chk-row{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.chk-row input[type=checkbox]{width:20px;height:20px;accent-color:var(--accent)}
.chk-row label{font-size:13px;font-weight:500}

/* Roadmap timeline */
.roadmap{position:relative;padding-left:28px;margin-bottom:8px}
.roadmap::before{content:'';position:absolute;left:8px;top:8px;bottom:8px;width:2px;background:var(--line);border-radius:2px}
.rm-item{position:relative;margin-bottom:16px}
.rm-item:last-child{margin-bottom:0}
.rm-dot{position:absolute;left:-24px;top:10px;width:14px;height:14px;border-radius:50%;border:2px solid var(--line);background:var(--surface);display:flex;align-items:center;justify-content:center;z-index:1}
.rm-dot.done{border-color:var(--done-fg);background:var(--done-bg)}
.rm-dot.wip{border-color:var(--wip-fg);background:var(--wip-bg)}
.rm-dot.plan{border-color:var(--plan-fg);background:var(--surface)}
.rm-dot svg{width:8px;height:8px}
.rm-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:12px 14px}
.rm-card.done{border-color:rgba(22,101,52,.2);background:rgba(220,252,231,.3)}
.rm-card.wip{border-color:rgba(133,77,14,.2);background:rgba(254,249,195,.3)}
.rm-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.rm-num{font-size:10px;font-weight:700;color:var(--muted)}
.rm-title{font-size:13px;font-weight:700;flex:1}
.rm-badge{font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.04em}
.rm-badge.done{background:var(--done-bg);color:var(--done-fg)}
.rm-badge.wip{background:var(--wip-bg);color:var(--wip-fg)}
.rm-badge.plan{background:var(--plan-bg);color:var(--plan-fg)}
.rm-items{list-style:none;display:flex;flex-direction:column;gap:3px}
.rm-items li{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px;line-height:1.3}
.rm-items li::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--muted);flex-shrink:0}
.rm-items li.done-item{color:var(--ink)}
.rm-items li.done-item::before{background:var(--done-fg)}

/* Data + Docs */
.grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(min-width:560px){.grid{grid-template-columns:repeat(4,1fr)}}
.sc{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:14px;cursor:pointer;transition:all .15s;text-align:center;min-height:72px}
.sc:hover{border-color:var(--accent)}.sc:active{transform:scale(.97)}
.sc .ct{font-size:24px;font-weight:700;color:var(--accent)}.sc .ct.ld{color:var(--line)}.sc .nm{font-size:11px;color:var(--muted);margin-top:2px}
.ts{margin-top:16px}.ts h3{font-size:16px;margin-bottom:8px}
.tw{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface)}
.dt{width:100%;border-collapse:collapse;min-width:480px}
.dt th{text-align:left;padding:8px 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);border-bottom:1px solid var(--line);background:rgba(255,255,255,.5);white-space:nowrap}
.dt td{padding:8px 12px;font-size:13px;border-bottom:1px solid var(--line)}.dt tr:last-child td{border-bottom:none}
.bdg{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600}.bdg.grn{background:var(--done-bg);color:var(--done-fg)}.bdg.gry{background:var(--plan-bg);color:var(--plan-fg)}
.dp{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:16px}
.dp h2{font-size:18px;margin-bottom:12px}.dp h3{font-size:14px;margin:16px 0 6px;color:var(--accent)}
.dp p{font-size:13px;line-height:1.6;color:var(--muted);margin-bottom:6px}
.dp code{font-family:"SF Mono",monospace;background:var(--plan-bg);padding:1px 5px;border-radius:3px;font-size:12px;color:var(--amber)}
.dp pre{background:var(--ink);color:#e2e8f0;padding:12px;border-radius:var(--r-sm);overflow-x:auto;font-size:12px;line-height:1.5;margin:6px 0}.dp pre code{background:none;color:inherit;padding:0}
.ep{display:flex;align-items:center;gap:6px;margin-bottom:3px;flex-wrap:wrap}
.epm{padding:2px 6px;border-radius:3px;font-size:10px;font-weight:700;font-family:"SF Mono",monospace}.epm.get{background:var(--done-bg);color:var(--done-fg)}.epm.post{background:var(--blue-bg);color:var(--blue-fg)}.epm.patch{background:var(--amber-bg);color:var(--amber-fg)}
.epp{font-family:"SF Mono",monospace;font-size:12px;font-weight:600}
.epb{margin-bottom:12px}
.empty{color:var(--muted);font-size:13px;text-align:center;padding:24px 16px}
/* Diagrama de Modulos */
.modmap-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:16px;margin-bottom:14px}
.modmap-intro{font-size:12px;color:var(--muted);line-height:1.6;margin-bottom:14px}
.modmap-intro code{font-family:"SF Mono",monospace;background:var(--plan-bg);padding:1px 5px;border-radius:3px;font-size:11px;color:var(--amber)}
.modmap-tree{font-size:13px;font-family:"SF Mono",monospace}
.mmt-root{display:flex;flex-direction:column;gap:4px}
.mmt-children{padding-left:20px;display:flex;flex-direction:column;gap:4px;border-left:2px solid var(--line);margin-left:8px}
.mmt-js-group{gap:2px}
.mmt-folder{display:flex;align-items:center;gap:7px;color:var(--amber-fg);font-weight:600;padding:2px 0}
.mmt-folder svg{width:14px;height:14px;flex-shrink:0;color:var(--amber)}
.mmt-file{display:flex;align-items:center;gap:7px;padding:5px 8px;border-radius:6px;font-size:12px;font-weight:600}
.mmt-html{background:var(--blue-bg);color:var(--blue-fg)}
.mmt-html svg{width:14px;height:14px;flex-shrink:0}
.mmt-css{background:var(--purple-bg);color:var(--purple-fg)}
.mmt-css svg{width:14px;height:14px;flex-shrink:0}
.mmt-core{background:var(--amber-bg);color:var(--amber-fg);margin-bottom:4px}
.mmt-core svg{width:14px;height:14px;flex-shrink:0}
.mmt-deps{padding-left:16px;display:flex;flex-direction:column;gap:3px;border-left:2px solid var(--line);margin-left:6px}
.mmt-mod{background:var(--plan-bg);color:var(--ink);font-weight:500;font-size:11px}
.mmt-branch{display:inline-block;width:10px;height:1px;background:var(--line);margin-right:4px;vertical-align:middle;flex-shrink:0}
.mmt-branch-last{background:var(--line)}
.mmt-tag{font-size:10px;font-weight:600;font-family:-apple-system,sans-serif;padding:1px 6px;border-radius:4px;background:rgba(0,0,0,.06);color:var(--muted);margin-left:auto;flex-shrink:0;white-space:nowrap}
.mmt-tag-core{background:var(--amber-bg);color:var(--amber-fg)}
.modmap-legend{margin-top:14px;display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--line);padding-top:12px}
.modmap-leg-item{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--muted);line-height:1.4}
.modmap-leg-item code{font-family:"SF Mono",monospace;background:var(--plan-bg);padding:1px 4px;border-radius:3px;font-size:11px;color:var(--amber)}
.mmt-mod-group{background:var(--plan-bg);color:var(--ink);font-weight:600;font-size:11px;border:1px dashed var(--line)}
.mmt-mod-group svg{width:14px;height:14px;flex-shrink:0;color:var(--muted)}
.mmt-mod-panel{background:var(--done-bg);color:var(--done-fg);font-size:11px}
.mmt-mod-panel svg{width:14px;height:14px;flex-shrink:0}
.mmt-tag-panel{background:var(--done-bg);color:var(--done-fg);border:1px solid rgba(22,101,52,.2)}

/* Request flow */
.reqflow{margin-top:16px;border-top:1px solid var(--line);padding-top:14px}
.reqflow-title{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}
.reqflow-steps{display:flex;flex-direction:column;align-items:center;gap:0}
.rqs{width:100%;max-width:320px;border-radius:8px;padding:8px 12px;text-align:center}
.rqs-label{font-size:12px;font-weight:600;line-height:1.3}
.rqs-file{font-size:10px;font-weight:400;color:var(--muted);font-family:"SF Mono",monospace;display:block;margin-top:1px}
.rqs-in{background:var(--blue-bg);color:var(--blue-fg)}
.rqs-mw{background:var(--plan-bg);color:var(--ink)}
.rqs-auth{background:var(--amber-bg);color:var(--amber-fg)}
.rqs-router{background:var(--purple-bg);color:var(--purple-fg)}
.rqs-cache{background:var(--wip-bg);color:var(--wip-fg)}
.rqs-b44{background:var(--done-bg);color:var(--done-fg)}
.rqs-out{background:var(--blue-bg);color:var(--blue-fg)}
.rqs-arrow{font-size:16px;color:var(--muted);line-height:1.4;padding:1px 0}
.rqs-arrow-sm{font-size:12px;color:var(--muted);line-height:1.4;padding:1px 0}
.rqs-fork{width:100%;max-width:320px}
.rqs-fork-branch{display:flex;flex-direction:column;align-items:center;border:1px dashed var(--line);border-radius:8px;padding:8px;gap:0;background:rgba(0,0,0,.015)}

.hidden{display:none!important}

/* === C4 Diagram === */
.c4-tabs{display:flex;gap:8px;margin-bottom:16px}
.c4-tab{padding:6px 14px;border-radius:6px;border:1px solid var(--line);background:var(--bg);color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}
.c4-tab-active{background:var(--accent);color:#fff;border-color:var(--accent)}
.c4-level{display:flex;flex-direction:column;align-items:center;gap:4px}
.c4-row{display:flex;justify-content:center;width:100%}
.c4-arrow-down{font-size:11px;color:var(--muted);text-align:center;padding:2px 0}
.c4-box{border-radius:10px;padding:12px 16px;text-align:center;min-width:160px;max-width:280px}
.c4-person{background:var(--blue-bg);border:1.5px solid var(--blue-fg)}
.c4-system{background:var(--done-bg);border:2px solid var(--accent)}
.c4-external{background:var(--plan-bg);border:1.5px dashed var(--muted)}
.c4-container{background:var(--surface);border:1.5px solid var(--line)}
.c4-container-api{border-color:var(--accent)}
.c4-container-pb{border-color:var(--amber)}
.c4-tag{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.c4-name{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:4px}
.c4-desc{font-size:11px;color:var(--muted);line-height:1.5}
.c4-boundary{border:1.5px dashed var(--line);border-radius:12px;padding:16px;width:100%;margin-bottom:8px}
.c4-boundary-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px;text-align:center}
.c4-containers{display:flex;align-items:center;gap:6px;overflow-x:auto;padding:2px 0;scrollbar-width:none}
.c4-containers::-webkit-scrollbar{display:none}
.c4-conn-h{font-size:10px;color:var(--muted);white-space:nowrap;flex-shrink:0}
.c4-conn-down{font-size:11px;color:var(--muted);text-align:center;margin-top:8px}
.c4-ext-center{margin:0 auto}
