.roadmap-tree-page{--tree-surface:#fff;--tree-surface-soft:#f8fafc;--tree-border:#d8dee9;--tree-border-strong:#111827;--tree-ink:#111827;--tree-muted:#64748b;--tree-yellow:#fef08a;--tree-yellow-strong:#facc15;--tree-cream:#fff7d6;--tree-cream-border:#e7c766;--tree-blue:#2563eb;--tree-blue-soft:rgba(37,99,235,.16);--tree-green:#16a34a;--tree-green-soft:#dcfce7;--tree-amber:#d97706;--tree-amber-soft:#fef3c7;--tree-slate:#334155;--tree-shadow:0 18px 40px rgba(15,23,42,.08);min-height:calc(100dvh - 66px);color:var(--tree-ink);background:radial-gradient(circle at 100% 0,rgba(250,204,21,.12),transparent 24%),#f3f4f6}.roadmap-tree-header{z-index:20;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:rgba(255,255,255,.94);border-bottom:1px solid rgba(148,163,184,.2);position:-webkit-sticky;position:sticky;top:66px}.roadmap-tree-header__inner{max-width:1120px;margin:0 auto;padding:10px 24px 0}.roadmap-tree-header__breadcrumb{color:#94a3b8;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;align-items:center;gap:6px;min-height:28px;font-size:11px;display:flex;overflow-x:auto}.roadmap-tree-header__breadcrumb-segment{align-items:center;gap:6px;display:inline-flex}.roadmap-tree-header__breadcrumb-link{color:#94a3b8;align-items:center;gap:6px;text-decoration:none;transition:color .16s;display:inline-flex}.roadmap-tree-header__breadcrumb-link:hover{color:#334155}.roadmap-tree-header__breadcrumb-current{color:var(--tree-ink);align-items:center;gap:6px;display:inline-flex}.roadmap-tree-header__toolbar{align-items:center;gap:16px;padding:10px 0 8px;display:flex}.roadmap-tree-header__left{flex:auto;align-items:center;gap:12px;min-width:0;display:flex}.roadmap-tree-header__back{border:1px solid var(--tree-border);background:var(--tree-surface);width:40px;height:40px;color:var(--tree-ink);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;text-decoration:none;transition:transform .16s,border-color .16s,background-color .16s;display:inline-flex}.roadmap-tree-header__back:hover{background:var(--tree-surface-soft);border-color:#94a3b8;transform:translateY(-1px)}.roadmap-tree-header__title-group{flex:auto;min-width:0;max-width:min(100%,420px)}.roadmap-tree-header__title-row{flex-wrap:nowrap;align-items:center;gap:8px;min-width:0;display:flex}.roadmap-tree-header__title{color:var(--tree-ink);letter-spacing:-.045em;text-overflow:ellipsis;white-space:nowrap;max-width:100%;margin:0;font-weight:700;line-height:1.08;overflow:hidden;font-size:1.2rem!important}.roadmap-tree-header__description{max-width:56ch;color:var(--tree-muted);margin:8px 0 0;font-size:.95rem;line-height:1.6}.roadmap-tree-header__count{border:1px solid var(--tree-border);background:var(--tree-surface);color:#334155;white-space:nowrap;border-radius:999px;align-items:center;min-height:34px;margin-top:2px;padding:0 12px;font-size:.8rem;font-weight:700;display:inline-flex}.roadmap-tree-header__progress{flex-direction:column;flex:none;gap:8px;width:min(280px,100%);display:flex}.roadmap-tree-header__stats{flex-wrap:wrap;align-items:center;gap:6px;font-size:.82rem;display:flex}.roadmap-tree-header__stats-group{align-items:center;gap:6px;display:inline-flex}.roadmap-tree-header__stat{color:#475569;font-weight:700}.roadmap-tree-header__stat--done{color:var(--tree-green)}.roadmap-tree-header__stat--learning{color:var(--tree-blue)}.roadmap-tree-header__stat--warning{color:var(--tree-amber)}.roadmap-tree-header__stat-dot{color:#cbd5e1}.roadmap-tree-header__progress-bar{align-items:center;gap:10px;display:flex}.roadmap-tree-header__progress-track{background:#e2e8f0;border-radius:999px;flex:auto;height:8px;position:relative;overflow:hidden}.roadmap-tree-header__progress-fill{border-radius:inherit;background:linear-gradient(90deg,var(--tree-green),#22c55e);height:100%;transition:width .22s}.roadmap-tree-header__progress-pct{text-align:right;min-width:40px;color:var(--tree-green);font-size:.9rem;font-weight:700}.roadmap-tree-header__right{flex:none;align-items:center;gap:10px;display:flex}.roadmap-tree-header__search{align-items:center;display:inline-flex;position:relative}.roadmap-tree-header__search-icon{color:#94a3b8;pointer-events:none;position:absolute;left:12px}.roadmap-tree-header__search-input{border:1px solid var(--tree-border);background:var(--tree-surface);width:220px;min-height:42px;color:var(--tree-ink);border-radius:999px;outline:none;padding:0 40px 0 38px;transition:border-color .18s,box-shadow .18s,background-color .18s}.roadmap-tree-header__search-input::placeholder{color:#94a3b8}.roadmap-tree-header__search-input:focus{border-color:#93c5fd;box-shadow:0 0 0 4px rgba(59,130,246,.12)}.roadmap-tree-header__search-clear{color:#94a3b8;background:0 0;border:0;justify-content:center;align-items:center;width:24px;height:24px;display:inline-flex;position:absolute;right:10px}.roadmap-tree-header__tabs{flex-wrap:wrap;gap:8px;padding:0 0 8px;display:flex}.roadmap-tree-header__tab{border:1px solid var(--tree-border);background:var(--tree-surface);min-height:34px;color:var(--tree-muted);border-radius:999px;align-items:center;padding:0 12px;font-size:.84rem;font-weight:700;text-decoration:none;display:inline-flex}.roadmap-tree-header__tab--active{color:#f8fafc;background:#111827;border-color:#111827}.roadmap-vertical-tree{padding:32px 24px 96px;overflow-x:auto}.roadmap-vertical-tree__container{min-width:860px;max-width:1120px;margin:0 auto;padding-right:228px}.roadmap-vertical-tree__root{justify-content:center;margin-bottom:52px;display:flex;position:relative}.roadmap-vertical-tree__root:after{content:"";background:var(--tree-blue);width:2px;height:52px;position:absolute;bottom:-52px;left:50%;transform:translate(-50%)}.roadmap-root-node{border:2px solid var(--tree-border-strong);min-width:280px;max-width:540px;box-shadow:var(--tree-shadow);text-align:center;font-family:var(--font-roadmap-node),system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:linear-gradient(#fff,#f8fafc);border-radius:18px;padding:18px 24px}.roadmap-root-node__title{color:var(--tree-ink);letter-spacing:-.04em;font-size:1.45rem;font-weight:700;line-height:1.08;display:block}.roadmap-vertical-tree__content{flex-direction:column;display:flex}.roadmap-row{grid-template-columns:minmax(220px,1fr) auto minmax(220px,1fr);align-items:start;gap:0 18px;padding:28px 0;display:grid;position:relative}.roadmap-row__connector-top,.roadmap-row__connector-bottom{background:var(--tree-blue);width:2px;position:absolute;left:50%;transform:translate(-50%)}.roadmap-row__connector-top{height:28px;top:0}.roadmap-row__connector-bottom{height:28px;bottom:0}.roadmap-row__left,.roadmap-row__right{flex-direction:column;gap:12px;display:flex}.roadmap-row__left{align-items:flex-end}.roadmap-row__right{align-items:flex-start}.roadmap-row__center{z-index:1;justify-content:center;display:flex;position:relative}.roadmap-main-node,.roadmap-subtopic-node{border:2px solid var(--tree-border-strong);background:var(--tree-yellow);color:var(--tree-ink);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:transform .18s,box-shadow .18s,background-color .18s,border-color .18s,color .18s;position:relative;box-shadow:0 8px 24px rgba(15,23,42,.08)}.roadmap-main-node:hover,.roadmap-subtopic-node:hover{transform:translateY(-2px);box-shadow:0 16px 32px rgba(15,23,42,.12)}.roadmap-main-node{text-align:center;min-width:220px;max-width:300px;font-family:var(--font-roadmap-node),system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;border-radius:16px;padding:14px 42px 14px 24px}.roadmap-main-node__title{font-size:1rem;font-weight:700;line-height:1.2;display:block}.roadmap-main-node--optional,.roadmap-subtopic-node--optional{background:var(--tree-cream);border-color:var(--tree-cream-border)}.roadmap-main-node--beginner,.roadmap-subtopic-node--beginner{background:#ecfccb;border-color:#65a30d}.roadmap-main-node--alternative,.roadmap-subtopic-node--alternative{background:#f8fafc;border-style:dashed;border-color:#94a3b8}.roadmap-main-node--project,.roadmap-subtopic-node--project{background:#fed7aa;border-color:#c2410c}.roadmap-main-node--done,.roadmap-subtopic-node--done{color:#475569!important;background:#e2e8f0!important;border-color:#94a3b8!important}.roadmap-main-node--done .roadmap-main-node__title,.roadmap-subtopic-node--done .roadmap-subtopic-node__title{text-decoration:line-through}.roadmap-main-node--learning,.roadmap-subtopic-node--learning{box-shadow:0 0 0 5px var(--tree-blue-soft);border-color:var(--tree-blue)!important;color:#1d4ed8!important;background:#eff6ff!important}.roadmap-main-node--skipped,.roadmap-subtopic-node--skipped{background:var(--tree-slate)!important;border-color:var(--tree-slate)!important;color:#f8fafc!important}.roadmap-main-node--skipped .roadmap-main-node__title,.roadmap-subtopic-node--skipped .roadmap-subtopic-node__title{text-decoration:line-through}.roadmap-main-node__badge{border:2px solid #fff;border-radius:999px;justify-content:center;align-items:center;width:24px;height:24px;display:inline-flex;position:absolute;top:-8px;right:-8px;box-shadow:0 8px 18px rgba(15,23,42,.16)}.roadmap-main-node__badge--done{background:var(--tree-green)}.roadmap-main-node__badge--learning{background:var(--tree-blue)}.roadmap-main-node__toggle{width:28px;height:28px;color:var(--tree-ink);background:rgba(255,255,255,.8);border:1px solid rgba(15,23,42,.14);border-radius:999px;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.roadmap-subtopic{align-items:center;display:flex}.roadmap-subtopic--left{flex-direction:row-reverse}.roadmap-subtopic__connector{border-top:2px dashed var(--tree-blue);width:30px}.roadmap-subtopic-node{min-width:138px;max-width:220px;font-family:var(--font-roadmap-node),system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;border-radius:14px;padding:10px 16px}.roadmap-subtopic-node__title{font-size:.9rem;font-weight:700;line-height:1.35;display:block}.roadmap-subtopic-node__check{background:var(--tree-green);color:#fff;border:2px solid #fff;border-radius:999px;width:20px;height:20px;padding:2px;position:absolute;top:-7px;right:-7px}.roadmap-tree__legend{border:1px solid var(--tree-border);width:210px;box-shadow:var(--tree-shadow);z-index:15;background:rgba(255,255,255,.96);border-radius:22px;padding:18px;position:fixed;top:166px;right:28px}.roadmap-tree__legend-title{color:var(--tree-ink);letter-spacing:-.02em;margin:0 0 12px;font-weight:700;font-size:1rem!important}.roadmap-tree__legend-section{border-top:1px solid #e2e8f0;margin-top:14px;padding-top:14px}.roadmap-tree__legend-section:first-of-type{border-top:0;margin-top:0;padding-top:0}.roadmap-tree__legend-section-title{color:#94a3b8;letter-spacing:.08em;text-transform:uppercase;margin:0 0 10px;font-weight:700;font-size:.72rem!important}.roadmap-tree__legend-item{align-items:center;gap:10px;margin-bottom:8px;display:flex}.roadmap-tree__legend-item:last-child{margin-bottom:0}.roadmap-tree__legend-color{border:2px solid var(--tree-border-strong);border-radius:6px;flex-shrink:0;width:28px;height:18px}.roadmap-tree__legend-color--topic{background:var(--tree-yellow)}.roadmap-tree__legend-color--subtopic{background:var(--tree-cream);border-color:var(--tree-cream-border)}.roadmap-tree__legend-color--beginner{background:#ecfccb;border-color:#65a30d}.roadmap-tree__legend-color--alternative{background:#f8fafc;border-style:dashed;border-color:#94a3b8}.roadmap-tree__legend-color--project{background:#fed7aa;border-color:#c2410c}.roadmap-tree__legend-color--done{background:#e2e8f0;border-color:#94a3b8}.roadmap-tree__legend-color--learning{border-color:var(--tree-blue);background:#eff6ff}.roadmap-tree__legend-color--skipped{background:var(--tree-slate);border-color:var(--tree-slate)}.roadmap-tree__legend-label{color:#475569;font-size:.84rem;font-weight:700}.roadmap-tree__legend-copy{color:var(--tree-muted);gap:6px;font-size:.78rem;line-height:1.5;display:grid}.roadmap-tree__context-menu{border:1px solid var(--tree-border);z-index:1000;background:rgba(255,255,255,.98);border-radius:20px;min-width:220px;padding:8px;position:fixed;box-shadow:0 18px 40px rgba(15,23,42,.18)}.roadmap-tree__context-menu-header{color:var(--tree-muted);border-bottom:1px solid #e2e8f0;padding:10px 12px;font-size:.82rem;font-weight:700}.roadmap-tree__context-menu-item{color:#334155;cursor:pointer;border-radius:14px;align-items:center;gap:10px;padding:10px 12px;font-size:.88rem;font-weight:700;display:flex}.roadmap-tree__context-menu-item:hover{background:#f8fafc}.roadmap-tree__context-menu-item--active{color:#1d4ed8;background:#eff6ff}.roadmap-tree__context-menu-divider{background:#e2e8f0;height:1px;margin:4px 0}.roadmap-tree__modal-overlay{z-index:80;background:rgba(15,23,42,.48);justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.roadmap-tree__modal{border:1px solid var(--tree-border);background:var(--tree-surface);border-radius:26px;width:min(520px,100%);max-height:calc(100dvh - 48px);overflow-y:auto;box-shadow:0 20px 48px rgba(15,23,42,.18)}.roadmap-tree__modal-header,.roadmap-tree__modal-body,.roadmap-tree__modal-footer{padding:22px 24px}.roadmap-tree__modal-header,.roadmap-tree__modal-footer{border-bottom:1px solid #e2e8f0}.roadmap-tree__modal-footer{border-top:1px solid #e2e8f0;border-bottom:0;justify-content:flex-end;gap:10px;display:flex}.roadmap-tree__modal-title{color:var(--tree-ink);margin:0;font-weight:700;line-height:1.12;font-size:1.3rem!important}.roadmap-tree__modal-description{color:var(--tree-muted);line-height:1.7}.roadmap-tree__modal-meta{flex-wrap:wrap;gap:14px;display:flex}.roadmap-tree__modal-meta-item{color:#475569;align-items:center;gap:8px;font-size:.9rem;font-weight:700;display:inline-flex}.roadmap-tree__modal-techs{flex-wrap:wrap;gap:8px;margin-top:18px;display:flex}.roadmap-tree__modal-tech{border:1px solid var(--tree-border);background:var(--tree-surface-soft);color:#475569;border-radius:999px;align-items:center;min-height:32px;padding:0 12px;font-size:.82rem;font-weight:700;display:inline-flex}.roadmap-tree__modal-btn{border-radius:999px;min-height:42px;padding:0 16px;font-size:.9rem;font-weight:700}.roadmap-tree__modal-btn--secondary{border:1px solid var(--tree-border);background:var(--tree-surface);color:#334155}.roadmap-tree__modal-btn--primary{background:var(--tree-green);color:#fff;border:1px solid rgba(34,197,94,.2)}@media (max-width:1280px){.roadmap-tree__legend{right:16px}.roadmap-vertical-tree__container{padding-right:0}}@media (max-width:1080px){.roadmap-tree__legend{display:none}.roadmap-row{grid-template-columns:minmax(160px,1fr) auto minmax(160px,1fr)}}@media (max-width:900px){.roadmap-tree-header__toolbar{flex-direction:column;align-items:stretch}.roadmap-tree-header__progress,.roadmap-tree-header__right{width:100%}.roadmap-tree-header__right{justify-content:space-between}}@media (max-width:768px){.roadmap-tree-header{top:0}.roadmap-tree-header__inner{padding:10px 16px 0}.roadmap-tree-header__breadcrumb{display:none}.roadmap-tree-header__left{flex-wrap:wrap;align-items:flex-start}.roadmap-tree-header__title-group{max-width:none}.roadmap-tree-header__title-row{flex-wrap:wrap}.roadmap-tree-header__title{text-overflow:initial;white-space:normal;overflow:visible;font-size:1.08rem!important}.roadmap-tree-header__description{font-size:.88rem}.roadmap-tree-header__search-input{width:100%}.roadmap-tree-header__right{flex-direction:column;align-items:stretch}.roadmap-vertical-tree{padding:24px 16px 64px}.roadmap-vertical-tree__container{min-width:0}.roadmap-row{grid-template-columns:1fr;gap:12px;padding:24px 0}.roadmap-row__connector-top,.roadmap-row__connector-bottom{display:none}.roadmap-row__left,.roadmap-row__right{flex-flow:wrap;justify-content:center}.roadmap-subtopic,.roadmap-subtopic--left{flex-direction:column!important}.roadmap-subtopic__connector{border-top:0;border-left:2px dashed var(--tree-blue);width:2px;height:14px}.roadmap-main-node,.roadmap-subtopic-node{width:min(100%,320px);max-width:320px}.roadmap-root-node{width:min(100%,520px);min-width:0}}@media print{.roadmap-tree-header,.roadmap-tree__legend{display:none}.roadmap-vertical-tree__container{min-width:0}}
