@keyframes welcomeFadeIn{0%{opacity:0}to{opacity:1}}@keyframes welcomeCardIn{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes gridFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes tooltipIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:translate(-50%,-48%) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes errorSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes loadingPulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes legendIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.appShell{height:100vh;display:flex;flex-direction:column;font-family:var(--font-app);font-feature-settings:normal;background:linear-gradient(175deg,rgba(59,130,246,.03) 0%,transparent 30%),linear-gradient(195deg,transparent 70%,rgba(139,92,246,.025) 100%),var(--bg-app-linear);color:var(--text-primary)}.topbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg);padding:var(--space-xl) var(--space-xl);border-bottom:1px solid var(--border-surface);background:var(--surface-glass-card);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:var(--shadow-md),0 0 0 1px #ffffff73 inset,0 1px #ffffffa6 inset;position:fixed;top:0;left:0;right:0;z-index:100;flex-shrink:0}.welcomeScreen{position:relative;min-height:100vh;min-height:100dvh;display:grid;place-items:center;padding:clamp(16px,4.5vw,48px) clamp(18px,5vw,64px);font-family:var(--font-app);font-feature-settings:normal;box-sizing:border-box;background:radial-gradient(ellipse 80% 60% at 50% 10%,rgba(59,130,246,.07) 0%,transparent 58%),radial-gradient(ellipse 60% 50% at 80% 90%,rgba(139,92,246,.06) 0%,transparent 58%),var(--bg-app-linear);animation:welcomeFadeIn .6s var(--ease-out);overflow:hidden}@keyframes welcomeGraphDriftA{0%,to{transform:translate(0) rotate(0)}50%{transform:translate(.8%,-.5%) rotate(.2deg)}}@keyframes welcomeGraphDriftB{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-.6%,.4%) scale(1.015)}}@keyframes welcomeGraphBgPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.75;transform:scale(1.02)}}@keyframes welcomeGraphNodePulse{0%,to{opacity:.92;transform:scale(1)}50%{opacity:1;transform:scale(1.018)}}@keyframes welcomeGraphRingSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.welcomeGraphBackdrop{position:absolute;inset:-8%;z-index:0;pointer-events:auto;opacity:.72}.welcomeGraphSvg{width:100%;height:100%;display:block;cursor:default}.welcomeGraphParallax--a{transform-origin:50% 45%;animation:welcomeGraphDriftA 26s ease-in-out infinite;will-change:transform}.welcomeGraphParallax--b{transform-origin:50% 50%;animation:welcomeGraphDriftB 32s ease-in-out infinite reverse;will-change:transform}.welcomeGraphBgCircle{animation:welcomeGraphBgPulse 18s ease-in-out infinite}.welcomeGraphBgCircle--1{animation-delay:0s}.welcomeGraphBgCircle--2{animation-duration:22s;animation-delay:-4s}.welcomeGraphBgCircle--3{animation-duration:20s;animation-delay:-8s}.welcomeGraphBgCircle--4{animation-duration:24s;animation-delay:-2s}.welcomeGraphRing{fill:none;transform-origin:50px 50px}.welcomeGraphRing--1{stroke:#007fff0a;stroke-width:.12;stroke-dasharray:2 6;animation:welcomeGraphRingSpin 120s linear infinite}.welcomeGraphRing--2{stroke:#00007008;stroke-width:.1;stroke-dasharray:1.5 5;animation:welcomeGraphRingSpin 90s linear infinite reverse}.welcomeGraphEdge{stroke:#00000038;stroke-width:.5;transition:opacity .3s ease-out,stroke .3s ease-out,stroke-width .3s ease-out}.welcomeGraphEdge--dim{opacity:.18}.welcomeGraphEdge--highlight{opacity:1;stroke:#00000085;stroke-width:.65}.welcomeGraphNode{transform-origin:center;animation:welcomeGraphNodePulse 7s ease-in-out infinite;transform-box:fill-box;transition:opacity .3s ease-out,transform .3s ease-out,filter .3s ease-out;cursor:pointer}.welcomeGraphNode--dim{animation:none;opacity:.35}.welcomeGraphNode--hover{animation:none;opacity:1;transform:scale(1.1);filter:drop-shadow(0 .5px 2px rgba(0,127,255,.3))}.welcomeGraphNodeHalo{fill:#007fff14;stroke:none;transition:fill .3s ease-out}.welcomeGraphNode--hover .welcomeGraphNodeHalo{fill:#007fff2e}.welcomeGraphNodeDisc{fill:#007fff;fill-opacity:.88;filter:drop-shadow(0 .3px .6px rgba(0,0,80,.2))}.welcomeGraphNodeStroke{stroke:#000070;stroke-opacity:.65;stroke-width:.42;transition:stroke-opacity .3s ease-out,stroke-width .3s ease-out}.welcomeGraphNode--hover .welcomeGraphNodeStroke{stroke-opacity:.9;stroke-width:.55}@media(prefers-reduced-motion:reduce){.welcomeGraphParallax--a,.welcomeGraphParallax--b,.welcomeGraphBgCircle,.welcomeGraphRing,.welcomeGraphNode{animation:none!important;will-change:auto}.welcomeGraphNode--hover{transform:none;opacity:1;filter:none}.welcomeGraphNodeHalo{fill:#007fff1f}}.welcomeForeground{position:relative;z-index:1;display:flex;flex-direction:column;align-items:stretch;width:min(100%,92vw,820px);gap:clamp(18px,3.5vw,36px);overflow:visible}.welcomeVersion{margin:0;padding:0;text-align:center;font-size:clamp(11px,1.35vw,13px);font-weight:650;letter-spacing:.04em;color:var(--text-muted);opacity:.78}.welcomeHeroTitle{margin:0 auto;width:100%;max-width:100%;box-sizing:border-box;padding:.08em clamp(14px,4vw,36px) 0;text-align:center;font-weight:800;font-size:clamp(42px,min(11vw,12vh),88px);line-height:1.05;overflow:visible}.welcomeHeroTitle-text,.brandTitleWord{display:inline-block;overflow:visible;color:#007fff;filter:drop-shadow(0 1px 3px rgba(0,0,112,.12)) drop-shadow(0 4px 12px rgba(0,127,255,.08));background-image:linear-gradient(135deg,#1a8cff,#007fff 30%,#06d 55%,#04b 75%,navy);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.welcomeHeroTitle-text{max-width:100%;letter-spacing:-.03em;padding:.06em clamp(.12em,2vw,.24em) .1em clamp(.06em,1.5vw,.12em)}.brandTitleWord{font-size:clamp(21px,3.2vw,30px);font-weight:800;letter-spacing:-.025em;line-height:1.12;padding:3px 8px 4px 5px;vertical-align:middle}@supports not ((-webkit-background-clip: text) or (background-clip: text)){.welcomeHeroTitle-text,.brandTitleWord{background-image:none;-webkit-text-fill-color:unset;color:#007fff}}.welcomeHeroTitle:after{content:“”;display:block;width:min(140px,36vw);height:2.5px;margin:clamp(10px,2vw,16px) auto 0;border-radius:var(--radius-full);background:linear-gradient(90deg,transparent,rgba(0,127,255,.5),rgba(0,0,128,.35),transparent)}.welcomeCard{position:relative;z-index:1;width:100%;border-radius:clamp(var(--radius-xl),2vw,20px);border:1px solid rgba(255,255,255,.35);background:#ffffffd1;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 20px 50px #00002814,0 8px 20px #0000280a,0 0 0 1px #ffffff80 inset;padding:clamp(var(--space-2xl),4.5vw,40px);animation:welcomeCardIn .5s var(--ease-spring) .1s both;overflow:hidden}.welcomeCard:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 10%,rgba(255,255,255,.7) 50%,transparent 90%);pointer-events:none}.welcomeSelectRow{display:grid;gap:clamp(var(--space-sm),1.5vw,var(--space-md));margin-bottom:clamp(var(--space-md),2.5vw,var(--space-lg))}.welcomeLabel{font-weight:850;color:var(--text-secondary)}.welcomeLabel--prompt{font-weight:800;font-size:clamp(15px,2.1vw,18px);letter-spacing:-.02em;line-height:1.35;color:var(--color-gray-700)}.welcomeSelect{width:100%;min-height:clamp(48px,10vw,54px);padding:clamp(12px,2vw,14px) clamp(14px,2.5vw,16px);border-radius:var(--radius-lg);border:1.5px solid var(--color-gray-300);font-weight:800;font-size:clamp(14px,1.85vw,17px);box-shadow:var(--shadow-xs);transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.welcomeSelect:hover:not(:disabled){border-color:var(--color-gray-400)}.welcomeSelect:focus{outline:none;border-color:#007fff;box-shadow:0 0 0 3px #007fff1a,0 0 0 1px #007fff33,var(--shadow-xs)}.welcomeSelect,.carreraSelect,.menuRow select,.toggle select{appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer;background-color:#fff;background-image:var(--select-chevron);background-repeat:no-repeat;background-position:right .65rem center;background-size:1.15rem 1.15rem;padding-inline-end:2.35rem;color:var(--text-primary)}.welcomeSelect:disabled,.carreraSelect:disabled,.menuRow select:disabled,.toggle select:disabled{opacity:.58;cursor:not-allowed;background-color:var(--color-gray-50)}.welcomePrimary{width:100%;min-height:clamp(50px,11vw,56px);padding:clamp(14px,2.5vw,18px) clamp(16px,3vw,20px);border-radius:var(--radius-xl);border:none;background:linear-gradient(135deg,#111827,#1e3a5f);color:#fff;font-weight:750;font-size:clamp(15px,2vw,17px);letter-spacing:.01em;cursor:pointer;transition:transform .15s ease-out,box-shadow .15s ease-out,background .2s ease-out;box-shadow:0 2px 8px #0000281f}.welcomePrimary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #00002829,0 2px 8px #00002814;background:linear-gradient(135deg,#1a2744,#264a72);transition:transform .12s ease-in,box-shadow .12s ease-in,background .12s ease-in}.welcomePrimary:active:not(:disabled){transform:translateY(0) scale(.985);box-shadow:0 2px 6px #0000281a;transition:transform 80ms ease-out,box-shadow 80ms ease-out}.welcomePrimary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.welcomeMuted{margin-top:clamp(8px,1.5vw,12px);color:var(--text-muted);font-size:clamp(12px,1.5vw,14px);font-weight:650}.welcomeError{margin:clamp(8px,1.5vw,12px) 0;padding:clamp(10px,2vw,12px) clamp(12px,2vw,14px);border-radius:var(--radius-lg);border:1px solid var(--color-red-300);background:var(--color-red-50);color:var(--color-red-900);font-weight:750;font-size:clamp(13px,1.65vw,14px);animation:errorSlideIn .3s var(--ease-out)}.topbarMobileRow{display:contents}.topbarTrail{display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:var(--space-sm);flex:1 1 auto;min-width:0;order:2}.topbarEnd{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0;order:3}.topbar>.brand{order:1}.topbarMenuBtn{display:inline-flex;align-items:center;gap:var(--space-sm);cursor:pointer;-webkit-user-select:none;user-select:none;padding:8px 14px;border-radius:var(--radius-md);border:1px solid var(--border-default);background:#fff;font-weight:800;font-size:13px;color:var(--text-primary);transition:all var(--duration-fast) var(--ease-out);white-space:nowrap;box-shadow:var(--shadow-xs)}.topbarMenuBtn:hover{background:var(--color-gray-50);border-color:var(--color-gray-300);box-shadow:var(--shadow-sm);transform:translateY(-.5px)}.topbarMenuBtn.active{background:#3b82f61f;border-color:#3b82f659;color:var(--color-blue-900)}.topbarMenuBtn:active{transform:scale(.97);box-shadow:none;transition-duration:60ms}.pill{display:inline-flex;align-items:center;padding:6px 10px;border-radius:var(--radius-full);font-weight:900;font-size:12px;letter-spacing:.2px;border:1px solid var(--border-default);background:var(--color-gray-50);color:var(--text-secondary);white-space:nowrap;transition:transform var(--duration-fast) ease}.pillBlue{border-color:#3b82f659;background:#3b82f61a;color:var(--color-blue-900)}.pillGreen{border-color:#10b98159;background:#10b9811f;color:var(--color-green-800)}.carreraSelector{display:flex;gap:var(--space-sm);align-items:center}.carreraLabel{font-weight:600;white-space:nowrap}.carreraSelect{min-height:42px;padding:8px 12px;border-radius:var(--radius-lg);border:1.5px solid var(--color-gray-300);font-weight:800;font-size:13px;min-width:min(320px,100%);box-shadow:var(--shadow-xs);transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.carreraSelect:hover:not(:disabled){border-color:var(--color-gray-400)}.carreraSelect:focus{outline:none;border-color:var(--color-blue-500);box-shadow:0 0 0 3px #3b82f61f,var(--shadow-xs)}.brandTitle{display:inline-flex;align-items:center;gap:var(--space-sm)}.appVersion{font-size:12px;font-weight:900;letter-spacing:.2px;color:var(--text-muted);border:1px solid var(--border-default);background:var(--color-gray-50);padding:3px 9px;border-radius:var(--radius-full);line-height:1.2;opacity:.8;transition:opacity var(--duration-fast) ease}.brandTitle:hover .appVersion{opacity:1}.brandSub{font-size:12px;color:var(--text-muted);margin-top:2px}.mainOne{flex:1;display:flex;min-height:0;margin-top:60px}.canvas{position:relative;min-width:0;min-height:0;flex:1;background-color:#eef2f7;background-image:radial-gradient(ellipse 80% 60% at 5% 0%,rgba(59,130,246,.08) 0%,transparent 55%),radial-gradient(ellipse 70% 50% at 95% 25%,rgba(139,92,246,.06) 0%,transparent 50%),radial-gradient(ellipse 60% 50% at 40% 95%,rgba(16,185,129,.05) 0%,transparent 50%),radial-gradient(circle,rgba(17,24,39,.045) 1px,transparent 1px);background-size:100% 100%,100% 100%,100% 100%,22px 22px;background-attachment:local,local,local,local;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.materiasGridContainer{width:100%;padding:var(--space-xl);display:flex;flex-direction:column;gap:var(--space-2xl);box-sizing:border-box;animation:gridFadeIn .4s var(--ease-out)}.bandaSection{display:flex;flex-direction:column;gap:var(--space-md);width:100%}.bandaTitle{padding:10px 16px 10px 18px;border-radius:var(--radius-xl);background:linear-gradient(135deg,#ffffffd9,#ffffffa6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(17,24,39,.08);box-shadow:var(--shadow-xs);color:var(--text-secondary);font-weight:800;font-size:14px;position:relative}.bandaTitle:before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:3px;border-radius:0 var(--radius-full) var(--radius-full) 0;background:var(--color-blue-500)}.materiasGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-lg);width:100%;box-sizing:border-box}.materiaCard{width:100%;min-width:0;box-sizing:border-box;border-radius:var(--radius-lg);border:2px solid;display:flex;align-items:center;padding:0 12px 0 10px;min-height:56px;font-weight:600;line-height:1.1;overflow:visible;position:relative;cursor:pointer;transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.materiaCard[data-status=disabled]{background:linear-gradient(135deg,#f3f4f6f2,#e5e7ebe6);border-color:var(--color-gray-300);color:var(--text-primary);box-shadow:var(--shadow-xs)}.materiaCard[data-status=enabled]{background:linear-gradient(135deg,#fef9c3,#fef3c7);border-color:var(--color-yellow-500);color:var(--color-yellow-800);box-shadow:0 0 0 3px #eab30826,0 2px 8px #eab3081a}.materiaCard[data-status=approved]{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-color:var(--color-green-500);color:var(--color-green-800);box-shadow:0 2px 8px #10b98126}.materiaCard:hover{z-index:9999;transform:translateY(-2px);box-shadow:0 6px 16px #1118271f}.materiaCard[data-status=enabled]:hover{box-shadow:0 0 0 3px #eab30826,0 6px 16px #1118271f}.materiaCard:active{transform:translateY(0) scale(.98);box-shadow:none;transition-duration:60ms}.materiaCard--plan{padding-left:22px}.materiaCard--plan:before{content:"";position:absolute;left:0;top:0;bottom:0;width:10px;background:linear-gradient(180deg,var(--color-purple-500),var(--color-purple-600));border-radius:var(--radius-lg) 0 0 var(--radius-lg)}.materiaCard--optativa{border-style:dashed}.materiaObligBadge{position:absolute;top:-8px;right:8px;font-size:9px;font-weight:800;letter-spacing:.04em;line-height:1;padding:2.5px 5px;border-radius:4px;pointer-events:none;z-index:2}.materiaObligBadge--obl{background:#007fff;color:#fff;box-shadow:0 1px 3px #007fff40}.materiaObligBadge--opt{background:#ffffffe6;color:var(--color-gray-500);border:1px solid var(--color-gray-300)}.materiaCardContent{flex:1;min-width:0;display:flex;align-items:center;gap:10px}.materiaCardLabel{flex:1;min-width:0;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.materiaCardBadge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full);font-size:11px;font-weight:950;border:1px solid rgba(17,24,39,.14);background:#ffffff8c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:88px}@keyframes conflictBadgePop{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.conflictBadge{position:absolute;top:-9px;right:-9px;width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:13px;font-weight:900;line-height:1;border:2px solid #fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;box-shadow:0 2px 6px #d9770673;padding:0;animation:conflictBadgePop .25s var(--ease-out) both;transition:transform .12s var(--ease-out),box-shadow .12s var(--ease-out)}.conflictBadge:hover{transform:scale(1.2);box-shadow:0 4px 12px #d977068c}.conflictBadge:active{transform:scale(.9)}.conflictWarning{margin-bottom:10px;padding:10px 12px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.35);border-radius:var(--radius-md)}.conflictWarningHeader{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:900;color:#92400e;text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px}.conflictWarningBody{font-size:12px;color:#78350f;line-height:1.45}.conflictWarningDismiss{margin-top:7px;font-size:11px;color:#b45309;font-style:italic}.materiaInfoBtn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;flex-shrink:0;border-radius:50%;border:1.5px solid currentColor;background:#ffffff80;color:inherit;font-size:12px;font-weight:900;font-style:italic;font-family:Georgia,Times New Roman,serif;cursor:pointer;padding:0;margin-right:8px;opacity:.55;transition:opacity var(--duration-fast) ease,transform var(--duration-fast) ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation;line-height:1}.materiaInfoBtn:hover{opacity:.85}.materiaInfoBtn:active{transform:scale(.9)}.materiaCard .nodeTooltip{display:none;position:absolute;left:0;width:360px;max-width:min(88vw,360px);padding:var(--space-md);border-radius:var(--radius-xl);border:1px solid rgba(229,231,235,.8);background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);color:var(--text-primary);box-shadow:var(--shadow-lg);z-index:30;pointer-events:auto}.materiaCard .nodeTooltip-top{bottom:calc(100% + 10px);top:auto}.materiaCard .nodeTooltip-bottom{top:calc(100% + 10px);bottom:auto}.materiaCard .nodeTooltip.nodeTooltipOpen{display:block;animation:tooltipIn .15s var(--ease-out)}@media(max-width:640px){.materiaCard .nodeTooltip{left:auto;right:0}.materiaCard .nodeTooltip-top{bottom:auto;top:calc(100% + 10px)}.materiaCard .nodeTooltip-bottom{top:calc(100% + 10px);bottom:auto}}.react-flow__node .nodeTooltip{display:none;position:absolute;left:0;top:calc(100% + 10px);width:320px;max-width:min(85vw,320px);padding:var(--space-md);border-radius:var(--radius-xl);border:1px solid rgba(229,231,235,.8);background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);color:var(--text-primary);box-shadow:var(--shadow-lg);z-index:30;pointer-events:auto;font-size:13px}.react-flow__node .nodeTooltip.nodeTooltipOpen{display:block;animation:tooltipIn .15s var(--ease-out)}@media(max-width:640px){.react-flow__node .nodeTooltip{width:260px;max-width:80vw;left:auto;right:0;font-size:12px}}.graphWrap{width:100%;height:100%;min-height:0;flex:1}.muted{color:var(--text-muted);font-size:12px}.menu{position:relative}.menuButton{list-style:none;cursor:pointer;-webkit-user-select:none;user-select:none;padding:10px 12px;border-radius:var(--radius-lg);border:1px solid var(--border-default);background:#fff;font-weight:800;color:var(--text-primary)}.menuButton::-webkit-details-marker{display:none}.menu[open] .menuButton{border-color:var(--color-gray-300);background:var(--color-gray-50)}.menuPanel{position:absolute;right:0;top:46px;width:360px;padding:var(--space-md);border-radius:var(--radius-xl);border:1px solid var(--border-default);background:#fff;box-shadow:var(--shadow-lg);z-index:20}.hamburgerBtn{display:inline-flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none;padding:10px 12px;border-radius:var(--radius-lg);border:1px solid var(--border-default);background:#fff;font-weight:900;color:var(--text-primary);transition:all var(--duration-fast) var(--ease-out)}.hamburgerBtn:hover{background:var(--color-gray-50);border-color:var(--color-gray-300);box-shadow:var(--shadow-sm)}.hamburgerBtn:active{transform:scale(.96);transition-duration:60ms}.hamburgerIcon{display:inline-flex;flex-direction:column;gap:4px;width:18px}.hamburgerIcon>span{display:block;height:2px;width:18px;background:var(--text-primary);border-radius:var(--radius-full);transition:transform var(--duration-normal) var(--ease-spring),opacity var(--duration-fast) ease}.hamburgerIcon.open>span:nth-child(1){transform:translateY(6px) rotate(45deg)}.hamburgerIcon.open>span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburgerIcon.open>span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.hamburgerText{display:inline-block}.drawerOverlay{position:fixed;inset:0;background:#11182759;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity var(--duration-normal) ease;z-index:80}.drawerOverlay.open{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;right:0;height:100vh;width:min(420px,92vw);background:#fff;border-left:1px solid var(--border-default);box-shadow:-20px 0 40px #1118272e;transform:translate(105%);transition:transform .22s var(--ease-out);z-index:90;display:flex;flex-direction:column}.drawer.open{transform:translate(0)}.slidingMenu{position:fixed;top:0;right:0;height:100vh;width:min(420px,92vw);background:linear-gradient(180deg,var(--color-gray-50) 0%,white 100%);border-left:1px solid var(--border-default);box-shadow:var(--shadow-xl);transform:translate(100%);transition:transform var(--duration-slow) var(--ease-out);z-index:90;display:flex;flex-direction:column;will-change:transform;box-sizing:border-box;overflow-y:auto;overscroll-behavior:contain}.slidingMenu.open{transform:translate(0)}.drawerHeader{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:80px 18px 14px;border-bottom:1px solid var(--border-default);background:#ffffffeb;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);flex-shrink:0;position:sticky;top:0;z-index:1}.drawerHeaderLeft{display:flex;align-items:center;gap:var(--space-sm)}.drawerTitle{font-weight:950;font-size:20px;letter-spacing:-.3px;color:var(--text-primary)}.drawerClose{cursor:pointer;width:36px;height:36px;display:grid;place-items:center;border-radius:var(--radius-lg);border:1px solid var(--border-default);background:#fff;font-weight:900;font-size:16px;color:var(--text-secondary);transition:all var(--duration-fast) ease;flex-shrink:0}.drawerClose:hover{background:var(--color-gray-100);border-color:var(--color-gray-300);color:var(--text-primary)}.drawerClose:active{transform:scale(.95)}.drawerBack{cursor:pointer;width:36px;height:36px;display:grid;place-items:center;border-radius:var(--radius-md);border:1px solid var(--border-default);background:#fff;font-weight:800;font-size:16px;color:var(--text-secondary);transition:all var(--duration-fast) var(--ease-out);flex-shrink:0}.drawerBack:hover{background:var(--color-gray-100);border-color:var(--color-gray-300);color:var(--text-primary)}.drawerBack:active{transform:scale(.95)}.drawerBody{padding:var(--space-lg);overflow:visible;-webkit-overflow-scrolling:touch;flex:1;display:flex;flex-direction:column}.menuSectionTitle{font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.8px;color:var(--color-gray-400);margin-bottom:var(--space-sm);margin-top:var(--space-lg)}.menuSectionTitle:first-child{margin-top:0}.menuRow{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;border-radius:var(--radius-md);background:#11182708;border:1px solid var(--border-subtle);font-size:14px;font-weight:700;color:var(--text-secondary);margin-bottom:var(--space-sm);transition:background var(--duration-fast) ease,border-color var(--duration-fast) ease}.menuRow:hover{background:#1118270f}.menuRowText{flex:1;min-width:0}.menuRow.noMargin{margin-bottom:0}.menuRowSwitch{cursor:pointer;-webkit-user-select:none;user-select:none}.menuNavRow{width:100%;cursor:pointer;text-align:left;font-weight:800;transition:background var(--duration-fast) ease,border-color var(--duration-fast) ease,transform var(--duration-fast) ease}.menuNavRow:hover{transform:translate(2px);background:#1118270f}.menuNavRow:active{transform:scale(.97);transition-duration:60ms}.switch{position:relative;width:46px;height:26px;flex:0 0 auto}.switch input{position:absolute;inset:0;opacity:0;margin:0;cursor:pointer}.switchSlider{position:absolute;inset:0;border-radius:var(--radius-full);border:1.5px solid rgba(17,24,39,.18);background:#1118271a;transition:background var(--duration-normal) var(--ease-out),border-color var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out)}.switchSlider:before{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:var(--radius-full);background:#fff;box-shadow:0 2px 8px #1118272e;transition:transform var(--duration-normal) var(--ease-spring)}.switch input:checked+.switchSlider{background:var(--color-green-500);border-color:var(--color-green-500)}.switch input:checked+.switchSlider:before{transform:translate(20px)}.switch input:focus-visible+.switchSlider{box-shadow:0 0 0 3px #3b82f640}.menuRow select{min-height:38px;padding:8px 12px;border-radius:var(--radius-lg);border:1.5px solid var(--color-gray-300);font-weight:800;font-size:13px;box-shadow:var(--shadow-xs);transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.menuRow select:hover:not(:disabled){border-color:var(--color-gray-400)}.menuRow select:focus{outline:none;border-color:var(--color-blue-500);box-shadow:0 0 0 3px #3b82f61f,var(--shadow-xs)}.menuDivider{height:1px;background:linear-gradient(90deg,transparent,var(--border-default),transparent);margin:var(--space-lg) 0}.menuHint{font-size:12px;color:var(--text-muted);margin-bottom:var(--space-sm);line-height:1.6}.menuRowCol{display:flex;flex-direction:column;gap:var(--space-sm)}.menuInput{padding:10px 12px;border-radius:var(--radius-lg);border:1.5px solid var(--color-gray-300);font-weight:700;transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.menuInput:focus{outline:none;border-color:var(--color-blue-500);box-shadow:0 0 0 3px #3b82f61f}.miniRow{margin-bottom:0;justify-content:space-between}.menuNum{width:110px;padding:8px 10px;border-radius:var(--radius-md);border:1px solid var(--color-gray-300);font-weight:800;transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.menuNum:focus{outline:none;border-color:var(--color-blue-500);box-shadow:0 0 0 3px #3b82f61f}.menuBtn{padding:10px 12px;border-radius:var(--radius-lg);border:none;background:linear-gradient(135deg,var(--color-gray-900),#2D3748);color:#fff;font-weight:900;cursor:pointer;transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.menuBtn:hover{transform:translateY(-.5px);box-shadow:var(--shadow-sm)}.menuBtn:active{transform:scale(.98)}.menuBtn.danger{background:var(--color-red-50);color:var(--color-red-900);border:1px solid var(--color-red-300)}.menuBtn.danger:hover{background:var(--color-red-100);transform:translateY(-.5px)}.menuList{margin-top:10px;display:flex;flex-direction:column;gap:var(--space-sm)}.menuListRow{display:flex;gap:var(--space-sm);align-items:center;justify-content:space-between}.menuListRow .menuRow{flex:1}.menuIcon{width:32px;height:32px;border-radius:var(--radius-md);display:grid;place-items:center;flex-shrink:0}.menuIcon svg{width:16px;height:16px}.menuIcon--gray{background:var(--color-gray-100);color:var(--color-gray-700)}.menuIcon--blue{background:var(--color-blue-50);color:var(--color-blue-600)}.menuIcon--purple{background:var(--color-purple-50);color:var(--color-purple-600)}.menuIcon--green{background:var(--color-green-50);color:var(--color-green-500)}.menuIcon--yellow{background:var(--color-yellow-50);color:var(--color-yellow-800)}.menuChevron{width:20px;height:20px;color:var(--color-gray-400);flex-shrink:0;transition:transform var(--duration-fast) ease}.menuNavRow:hover .menuChevron{transform:translate(2px);color:var(--text-secondary)}.drawerUserFooter{margin-top:auto;padding:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--border-default)}.drawerUserCard{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--color-gray-50);border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}.drawerUserAvatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--color-gray-900),#2D3748);color:#fff;font-weight:900;font-size:15px;display:grid;place-items:center;flex-shrink:0}.drawerUserDetails{flex:1;min-width:0}.drawerUserEmail{font-size:13px;font-weight:700;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drawerUserRole{display:flex;align-items:center;gap:var(--space-xs);margin-top:2px}.drawerLogoutBtn{display:block;width:100%;margin-top:var(--space-sm);padding:10px;border-radius:var(--radius-md);border:1px solid var(--color-red-300);background:var(--color-red-50);color:var(--color-red-600);font-weight:800;font-size:13px;cursor:pointer;text-align:center;transition:all var(--duration-fast) ease}.drawerLogoutBtn:hover{background:var(--color-red-100)}.drawerLogoutBtn:active{transform:scale(.98)}.drawerLoginBtn{display:block;width:100%;padding:12px;border-radius:var(--radius-lg);border:none;background:linear-gradient(135deg,var(--color-gray-900),#2D3748);color:#fff;font-weight:900;font-size:14px;cursor:pointer;text-align:center;transition:all var(--duration-fast) ease}.drawerLoginBtn:hover{transform:translateY(-.5px);box-shadow:var(--shadow-sm)}.drawerLoginBtn:active{transform:scale(.98)}.tutorialBanner{background:var(--color-blue-50);border:1px solid var(--color-blue-100);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);margin-bottom:var(--space-lg);animation:tutorialBannerIn .3s var(--ease-out)}@keyframes tutorialBannerIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.tutorialBannerStep{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--color-blue-600);margin-bottom:var(--space-xs)}.tutorialBannerText{font-size:14px;font-weight:700;color:var(--text-primary);line-height:1.5;margin-bottom:var(--space-md)}.tutorialBannerActions{display:flex;gap:var(--space-sm);justify-content:flex-end}.tutorialBannerBtn{padding:8px 16px;border-radius:var(--radius-md);font-weight:800;font-size:13px;cursor:pointer;border:1.5px solid;transition:all var(--duration-fast) ease}.tutorialBannerBtn--primary{background:var(--color-blue-500);color:#fff;border-color:var(--color-blue-500)}.tutorialBannerBtn--primary:hover{background:var(--color-blue-600);border-color:var(--color-blue-600)}.tutorialBannerBtn--secondary{background:#fff;color:var(--text-secondary);border-color:var(--color-gray-300)}.tutorialBannerBtn--secondary:hover{background:var(--color-gray-50)}.menuRow.tutorialActive{border-color:var(--color-blue-500);box-shadow:0 0 0 3px #3b82f626;animation:tutorialRowPulse 2s ease-in-out infinite}@keyframes tutorialRowPulse{0%,to{box-shadow:0 0 0 3px #3b82f626}50%{box-shadow:0 0 0 3px #3b82f64d}}.tutorialInlineHint{font-size:13px;font-weight:600;color:var(--color-blue-600);background:var(--color-blue-50);border:1px solid var(--color-blue-100);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);margin-top:calc(-1 * var(--space-sm));margin-bottom:var(--space-sm);line-height:1.5;animation:tutorialBannerIn .2s var(--ease-out)}.slidingMenu.open .drawerBody>*{animation:drawerItemIn .25s var(--ease-out) both}.slidingMenu.open .drawerBody>*:nth-child(1){animation-delay:30ms}.slidingMenu.open .drawerBody>*:nth-child(2){animation-delay:60ms}.slidingMenu.open .drawerBody>*:nth-child(3){animation-delay:90ms}.slidingMenu.open .drawerBody>*:nth-child(4){animation-delay:.12s}.slidingMenu.open .drawerBody>*:nth-child(5){animation-delay:.15s}.slidingMenu.open .drawerBody>*:nth-child(6){animation-delay:.18s}.slidingMenu.open .drawerBody>*:nth-child(7){animation-delay:.21s}.slidingMenu.open .drawerBody>*:nth-child(8){animation-delay:.24s}@keyframes drawerItemIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.switch input:checked+.switchSlider:before{box-shadow:0 2px 8px #1118272e,0 0 8px #10b9814d}.legend{position:fixed;z-index:5;bottom:16px;right:16px;display:flex;gap:12px;align-items:center;padding:10px 14px;border-radius:var(--radius-xl);border:1px solid rgba(229,231,235,.8);background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);animation:legendIn .3s var(--ease-out)}.legendItems{display:contents}.legendCollapseBtn{display:none}.legendItem{display:flex;gap:8px;align-items:center;font-size:13px;font-weight:700;color:var(--text-secondary)}.swatch{width:18px;height:18px;border-radius:5px;border:2px solid transparent;display:inline-block;transition:transform var(--duration-fast) ease}.legendItem:hover .swatch{transform:scale(1.15)}.swatchNoHab{background:var(--color-gray-200);border-color:var(--color-gray-400)}.swatchCurso,.swatchExamen{background:var(--color-green-100);border-color:var(--color-green-500)}.swatchHab{background:var(--color-yellow-100);border-color:var(--color-yellow-500)}.swatchPlan{position:relative;background:var(--color-gray-100);border-color:var(--color-purple-500);overflow:hidden}.swatchPlan:before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:var(--color-purple-500)}.menuHint.planHint{background:#8b5cf614;border:1px solid rgba(139,92,246,.2);padding:10px;border-radius:var(--radius-lg);color:var(--color-purple-900)}.creditsOverlay{position:fixed;z-index:6;top:80px;right:10px;max-height:calc(100vh - 100px);overflow-y:auto;-webkit-overflow-scrolling:touch}.creditsCollapseTab{display:none}.creditsOverlayInner{display:flex;flex-direction:column;gap:10px}.nodeTooltipTop{padding-bottom:10px;border-bottom:1px solid rgba(17,24,39,.08);margin-bottom:10px}.nodeTooltipTitle{font-weight:950;margin-bottom:6px;letter-spacing:.1px}.nodeTooltipMeta{font-size:12px;color:var(--text-secondary);display:grid;gap:2px}.nodeTooltipSection{margin-top:10px}.nodeTooltipHdr{font-size:11px;font-weight:900;color:var(--text-muted);margin-bottom:var(--space-sm);letter-spacing:.6px;text-transform:uppercase}.nodeTooltipLine{font-size:12px;color:var(--text-primary);line-height:1.35}.nodeTooltipKey{font-weight:900;color:var(--text-secondary)}.nodeTooltipPill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full);font-size:11px;font-weight:950;letter-spacing:.2px;border:1px solid rgba(17,24,39,.1);background:#1118270a;color:var(--text-secondary)}.nodeTooltipPill.blue{border-color:#3b82f64d;background:#3b82f61a;color:var(--color-blue-900)}.nodeTooltipPill.green{border-color:#10b9814d;background:#10b9811f;color:var(--color-green-800)}.nodeTooltipOk{color:var(--text-primary);font-weight:700}.nodeTooltipBad{color:#b91c1c;font-weight:900}.tooltipPrevTree{display:flex;flex-direction:column;gap:3px}.tooltipPrevNone{font-size:12px;color:var(--text-secondary);font-weight:600}.tooltipPrevItem{display:flex;align-items:center;gap:6px;font-size:12px;line-height:1.35;min-height:22px}.tooltipPrevDot{flex-shrink:0;width:7px;height:7px;border-radius:50%}.tooltipPrevName{flex:1;min-width:0}.tooltipPrevStatus--ok .tooltipPrevDot{background:#059669}.tooltipPrevStatus--ok .tooltipPrevName{color:#065f46;font-weight:600}.tooltipPrevStatus--bad .tooltipPrevDot{background:#dc2626}.tooltipPrevStatus--bad .tooltipPrevName{color:#991b1b;font-weight:700}.tooltipPrevStatus--muted .tooltipPrevDot{background:#9ca3af}.tooltipPrevStatus--muted .tooltipPrevName{color:var(--text-muted);font-weight:500}.tooltipPrevGroup{margin-top:2px}.tooltipPrevGroupLabel{font-size:11px;font-weight:800;color:var(--text-secondary);margin-bottom:2px;letter-spacing:.2px}.tooltipPrevGroupLabel--ok{color:#059669}.tooltipPrevGroupLabel--ok:before{content:"✓ "}.tooltipPrevGroupLabel--bad{color:#b91c1c}.tooltipPrevGroupLabel--bad:before{content:"✗ "}.tooltipPrevGroupItems{padding-left:13px;border-left:2px solid rgba(17,24,39,.08);display:flex;flex-direction:column;gap:2px}.errorBox{position:absolute;z-index:6;top:64px;left:10px;right:10px;padding:10px 12px;border-radius:var(--radius-lg);border:1px solid rgba(239,68,68,.3);background:var(--color-red-50);color:var(--color-red-900);font-size:13px;animation:errorSlideIn .3s var(--ease-out)}.loadingBox{position:absolute;z-index:6;top:64px;left:10px;padding:10px 12px;border-radius:var(--radius-lg);border:1px solid rgba(229,231,235,.8);background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);color:var(--text-secondary);font-size:13px;animation:loadingPulse 1.5s ease-in-out infinite}.controlsOverlay{position:absolute;z-index:6;top:10px;right:10px;display:flex;flex-direction:column;gap:10px;align-items:flex-end}.toggle{display:inline-flex;gap:10px;align-items:center;padding:10px 12px;border-radius:var(--radius-xl);border:1px solid rgba(229,231,235,.8);background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);font-size:14px;font-weight:700;color:var(--text-secondary)}.toggle select{margin-left:10px;min-height:36px;padding:6px 12px;border-radius:var(--radius-lg);border:1.5px solid var(--color-gray-300);font-weight:700;font-size:13px;box-shadow:var(--shadow-xs);transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.toggle select:hover:not(:disabled){border-color:var(--color-gray-400)}.toggle select:focus{outline:none;border-color:var(--color-blue-500);box-shadow:0 0 0 3px #3b82f61f,var(--shadow-xs)}.creditsBox{width:280px;padding:var(--space-md);border-radius:var(--radius-xl);border:1px solid rgba(229,231,235,.8);background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);transition:all .3s var(--ease-out);box-shadow:var(--shadow-md)}.creditsBox.minimized{padding:10px 12px}.creditsHeader{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);margin-bottom:var(--space-sm)}.creditsTitle{font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.3px;color:var(--text-muted);flex:1;min-width:0}.creditsToggle{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:1px solid var(--border-default);background:#ffffffe6;color:var(--text-secondary);font-size:14px;font-weight:900;cursor:pointer;transition:all var(--duration-fast) ease;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.creditsToggle:hover{background:var(--color-gray-50);border-color:var(--color-gray-300);transform:scale(1.05);box-shadow:var(--shadow-sm)}.creditsToggle:active{transform:scale(.95)}.creditsMinimizedContent{display:flex;align-items:center;justify-content:center;padding:4px 0}.creditsMinimizedContent .creditVal{font-size:18px;font-weight:900;color:var(--text-primary)}.creditsGrid{display:grid;gap:6px;transition:opacity .3s var(--ease-out),max-height .3s var(--ease-out);overflow:hidden}.creditRow{display:flex;justify-content:space-between;align-items:center;padding:6px 8px;border-radius:var(--radius-md);background:#1118270a;border:1px solid var(--border-subtle);font-size:13px}.creditRow.okRow{background:linear-gradient(135deg,#10b98114,#10b98124);border-color:#10b9814d}.creditRow.okRow .creditKey,.creditRow.okRow .creditVal{color:var(--color-green-800)}.creditKey{font-weight:900;color:var(--text-secondary)}.creditVal{font-weight:800;color:var(--text-primary)}.totalRow{background:linear-gradient(135deg,#3b82f60f,#3b82f61f);border-color:#3b82f633}@media(max-width:853px){.topbar{flex-wrap:wrap;gap:10px}.mainOne{margin-top:110px}.drawerHeader{padding-top:120px}.controlsOverlay{top:8px;right:8px;gap:8px}.toggle{font-size:13px;padding:8px 10px;gap:8px}.toggle select{margin-left:6px;min-height:32px;padding:4px 10px;font-size:12px}}@media(max-width:720px){.mainOne{margin-top:128px}.topbar{flex-direction:column;align-items:stretch;gap:10px;padding:10px 14px}.topbarMobileRow{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:8px;width:100%;min-width:0}.topbarMobileRow .brand{min-width:0}.topbarEnd{flex-shrink:0}.topbarTrail{flex:none;width:100%;flex-direction:column;align-items:stretch;justify-content:flex-start}.topbarTrail .pill{align-self:flex-start}.topbarTrail .carreraSelector{width:100%;min-width:0}.carreraLabel{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.topbarMenuBtn{font-size:12px;padding:7px 12px;flex:1;min-width:calc(50% - 4px);justify-content:center}.carreraSelect{min-width:0;width:100%}.appVersion,.hamburgerText{display:none}.slidingMenu{width:100vw;border-left:none;box-shadow:none}.drawerHeader{padding:132px 14px 12px}.menuPanel{left:0;right:0;width:auto;max-width:92vw;max-height:calc(100vh - 90px);overflow:auto}.legend{bottom:12px;right:10px;left:auto;width:auto;max-width:calc(100vw - 20px);flex-wrap:nowrap;gap:0;padding:0;overflow:hidden;transition:max-width var(--duration-normal) var(--ease-out),padding var(--duration-normal) var(--ease-out)}.legendCollapseBtn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;flex-shrink:0;border:none;background:none;color:var(--text-muted);font-size:10px;cursor:pointer;padding:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.legendItems{display:flex;gap:10px;align-items:center;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:8px 10px 8px 0;transition:opacity var(--duration-normal) var(--ease-out),max-width var(--duration-normal) var(--ease-out)}.legendItems::-webkit-scrollbar{display:none}.legend.legendCollapsed{max-width:44px;border-radius:var(--radius-lg)}.legend.legendCollapsed .legendItems{opacity:0;max-width:0;padding:0;overflow:hidden}.legendItem{font-size:11px;white-space:nowrap;flex-shrink:0}.swatch{width:14px;height:14px;border-radius:4px}.creditsOverlay{right:0;top:110px;max-height:calc(100vh - 130px);display:flex;align-items:flex-start;transition:transform var(--duration-slow) var(--ease-out)}.creditsCollapseTab{display:flex;align-items:center;justify-content:center;width:24px;min-height:48px;border:1px solid rgba(229,231,235,.8);border-right:none;border-radius:var(--radius-md) 0 0 var(--radius-md);background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);box-shadow:-2px 2px 8px #11182714;cursor:pointer;font-size:18px;font-weight:700;line-height:1;padding:0;color:var(--text-muted);-webkit-tap-highlight-color:transparent;touch-action:manipulation;flex-shrink:0;margin-top:8px}.creditsCollapseTab:active{background:var(--color-gray-100)}.creditsOverlayInner{max-width:240px}.creditsOverlay.creditsOverlayHidden{transform:translate(calc(100% - 24px))}.creditsBox{width:240px;max-width:calc(100vw - 34px);border-radius:0 0 0 var(--radius-xl)}.creditsBox:first-child{border-radius:var(--radius-xl) 0 0 var(--radius-xl)}.creditsToggle{width:36px;height:36px;font-size:16px}.drawerOverlay.open{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.materiasGridContainer{padding:var(--space-md);gap:var(--space-xl)}.materiasGrid{grid-template-columns:1fr;gap:var(--space-md)}.bandaTitle{font-size:13px;padding:8px 12px 8px 16px}.controlsOverlay{top:6px;right:8px;left:8px;align-items:stretch;gap:6px}.toggle{font-size:12px;padding:8px 10px;gap:6px;justify-content:space-between}.toggle select{margin-left:auto;min-height:30px;padding:4px 8px;font-size:12px;flex-shrink:0}.userMenuDropdown{right:-10px;min-width:180px}.errorBox,.loadingBox{top:8px;left:8px;right:8px;font-size:12px}.authModal{padding:var(--space-xl)}.authTitle{font-size:20px}.legalModal{width:min(640px,96vw);max-height:90vh;padding:var(--space-xl)}.deleteConfirmModal{width:min(420px,94vw);padding:var(--space-xl)}.deleteConfirmActions{flex-direction:column}.deleteConfirmActions button{width:100%}}@media(max-width:400px){.topbar{padding:8px 10px;gap:6px}.brandTitleWord{font-size:20px}.hamburgerBtn{padding:8px 10px}.authBtn{padding:6px 10px;font-size:12px}.authBtnLoggedIn{width:28px;height:28px;font-size:12px}.pill{font-size:11px;padding:4px 8px}.legend{padding:6px 10px;gap:8px}.legendItem{font-size:10px}.creditsBox{padding:var(--space-sm)}.creditRow{padding:5px 6px;font-size:12px}.drawerTitle{font-size:18px}.menuRow{padding:10px 12px;font-size:13px}}@supports (padding: max(0px)){.topbar{padding-top:max(14px,env(safe-area-inset-top))}.slidingMenu{padding-bottom:max(0px,env(safe-area-inset-bottom))}}.authBtn{padding:6px 14px;border-radius:var(--radius-md);border:1px solid var(--color-gray-300);background:#fff;font-weight:800;font-size:13px;color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all var(--duration-fast) var(--ease-out)}.authBtn:hover{background:var(--color-gray-100);border-color:var(--color-gray-300);box-shadow:var(--shadow-xs)}.authBtnLoggedIn{width:32px;height:32px;padding:0;border-radius:50%;background:linear-gradient(135deg,var(--color-gray-900),#2D3748);color:#fff;font-weight:900;font-size:14px;display:grid;place-items:center;border:none;transition:transform var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.authBtnLoggedIn:hover{background:linear-gradient(135deg,var(--color-gray-700),var(--color-gray-800));transform:scale(1.05);box-shadow:var(--shadow-sm)}.userMenuWrapper{position:relative}.userMenuDropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border-default);min-width:200px;z-index:200;overflow:hidden;animation:dropdownIn .15s var(--ease-out)}.userMenuEmail{padding:12px 16px;font-size:13px;color:var(--text-muted);border-bottom:1px solid var(--border-default);word-break:break-all}.userMenuLogout{display:block;width:100%;padding:12px 16px;background:none;border:none;text-align:left;font-size:14px;color:var(--color-red-600);cursor:pointer;transition:background var(--duration-fast) ease}.userMenuLogout:hover{background:var(--color-red-50)}.userMenuDelete{display:block;width:100%;padding:10px 16px;background:none;border:none;border-top:1px solid var(--border-default);text-align:left;font-size:12px;color:var(--text-muted);cursor:pointer;transition:background var(--duration-fast) ease,color var(--duration-fast) ease}.userMenuDelete:hover{background:var(--color-red-50);color:var(--color-red-600)}.deleteConfirmModal{width:min(420px,92vw)}.deleteConfirmBody{margin:12px 0 20px;font-size:14px;color:var(--text-secondary);line-height:1.6}.deleteConfirmBody p{margin:0 0 8px}.deleteConfirmBody ul{margin:4px 0 10px;padding-left:20px}.deleteConfirmBody li{margin:2px 0}.deleteConfirmActions{display:flex;gap:10px;justify-content:flex-end}.deleteConfirmCancel{padding:8px 18px;font-size:14px;font-weight:600;border-radius:var(--radius-lg);background:#fff;color:var(--text-secondary);border:1px solid var(--border-default);cursor:pointer;transition:background var(--duration-fast) ease}.deleteConfirmCancel:hover{background:var(--color-gray-50)}.deleteConfirmBtn{padding:8px 18px;font-size:14px;font-weight:700;border-radius:var(--radius-lg);background:var(--color-red-600);color:#fff;border:none;cursor:pointer;transition:background var(--duration-fast) ease}.deleteConfirmBtn:hover{background:#b91c1c}.deleteConfirmBtn:disabled,.deleteConfirmCancel:disabled{opacity:.6;cursor:not-allowed}.authOverlay{position:fixed;inset:0;background:#00000059;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:500;animation:overlayFadeIn .2s ease}.authModal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(400px,92vw);background:#fff;border-radius:var(--radius-2xl);padding:var(--space-3xl);z-index:501;box-shadow:var(--shadow-xl);animation:modalIn .3s var(--ease-spring)}.authClose{position:absolute;top:12px;right:16px;background:none;border:none;font-size:24px;color:var(--text-muted);cursor:pointer;line-height:1;transition:color var(--duration-fast) ease}.authClose:hover{color:var(--text-primary)}.authTitle{font-weight:950;font-size:22px;letter-spacing:-.2px;color:var(--text-primary);margin-bottom:18px}.authField{display:grid;gap:4px;margin-bottom:14px}.authLabel{font-weight:800;font-size:13px;color:var(--text-secondary)}.authInput{padding:10px 12px;border-radius:var(--radius-lg);border:1.5px solid var(--color-gray-300);background:#fff;font-weight:700;font-size:14px;transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.authInput:focus{outline:none;border-color:var(--color-blue-500);box-shadow:0 0 0 3px #3b82f626}.authPrimary{width:100%;padding:12px 14px;border-radius:var(--radius-xl);border:none;background:linear-gradient(135deg,var(--color-gray-900),#2D3748);color:#fff;font-weight:950;font-size:14px;cursor:pointer;margin-top:4px;transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.authPrimary:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md)}.authPrimary:active:not(:disabled){transform:scale(.99);box-shadow:none}.authPrimary:disabled{opacity:.55;cursor:not-allowed}.authError{color:var(--color-red-500);font-size:13px;font-weight:700;margin-bottom:10px}.authSuccess{color:var(--color-green-500);font-size:13px;font-weight:700;margin-bottom:10px}.authSwitch{display:block;margin-top:14px;background:none;border:none;color:var(--text-muted);font-weight:700;font-size:13px;cursor:pointer;text-align:center;width:100%;transition:color var(--duration-fast) ease}.authSwitch:hover{color:var(--color-blue-600)}.authLegalNotice{margin-top:12px;font-size:11px;color:var(--text-muted);text-align:center;line-height:1.5}.authPasswordWrapper{position:relative;display:flex;align-items:center}.authPasswordInput{width:100%;padding-right:42px}.authPasswordToggle{position:absolute;right:8px;background:none;border:none;cursor:pointer;color:var(--color-gray-400);padding:4px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:color var(--duration-fast) ease}.authPasswordToggle:hover{color:var(--text-secondary)}.authForgotLink{background:none;border:none;color:var(--text-muted);font-size:12px;font-weight:700;cursor:pointer;padding:0;margin-bottom:12px;text-align:left;transition:color var(--duration-fast) ease}.authForgotLink:hover{color:var(--color-blue-600);text-decoration:underline}.menuUserInfo{padding:8px 16px;font-size:12px;font-weight:700;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.adminBadge{display:inline-block;margin-left:8px;padding:2px 8px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:#9333ea;background:var(--color-purple-100);border:1px solid #D8B4FE;border-radius:6px;vertical-align:middle}.legalOverlay{position:fixed;inset:0;background:#00000059;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:600;animation:overlayFadeIn .2s ease}.legalModal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(640px,94vw);max-height:85vh;background:#fff;border-radius:var(--radius-2xl);padding:var(--space-3xl);z-index:601;box-shadow:var(--shadow-xl);animation:modalIn .3s var(--ease-spring);display:flex;flex-direction:column}.legalContent{overflow-y:auto;flex:1;padding-right:8px;font-size:14px;line-height:1.7;color:var(--text-primary)}.legalContent h2{font-size:20px;font-weight:800;margin:0 0 4px;color:var(--text-primary)}.legalContent h3{font-size:15px;font-weight:700;margin:20px 0 6px;color:var(--text-primary)}.legalContent h4{font-size:14px;font-weight:700;margin:14px 0 4px;color:var(--text-secondary)}.legalContent p{margin:6px 0}.legalContent ul{margin:6px 0;padding-left:22px}.legalContent li{margin:3px 0}.legalContent code{font-size:12px;background:var(--color-gray-100);padding:1px 5px;border-radius:4px;font-family:monospace}.legalContent a{color:var(--color-blue-600);text-decoration:underline}.legalDate{font-size:12px;color:var(--text-muted);margin-bottom:16px!important}.appFooter{padding:16px 0 8px;text-align:center}.legalLinks{display:flex;gap:16px;justify-content:center;margin-top:8px;flex-wrap:wrap}.legalLink{background:none;border:none;color:var(--text-muted);font-size:11px;cursor:pointer;padding:0;text-decoration:underline;transition:color var(--duration-fast) ease}.legalLink:hover{color:var(--color-blue-600)}@media(prefers-reduced-motion:reduce){.slidingMenu{transition:opacity var(--duration-fast) ease;transform:none!important;opacity:0;pointer-events:none}.slidingMenu.open{opacity:1;pointer-events:auto}.hamburgerIcon>span{transition:none}.slidingMenu.open .drawerBody>*{animation:none}.tutorialHighlight,.menuRow.tutorialActive{animation:none}.switchSlider,.switchSlider:before{transition-duration:0ms}.menuNavRow:hover{transform:none}}.tutorialOverlay{position:fixed;background:transparent;z-index:1000;pointer-events:auto;transition:all .2s ease}.tutorialOverlayFull{inset:0;background:#111827a6}.tutorialHighlight{position:fixed;border:3px solid #3B82F6;border-radius:12px;background:transparent;z-index:1001;pointer-events:none;transition:all .2s ease;animation:tutorialPulse 2s ease-in-out infinite;box-shadow:0 8px 24px #3b82f666}[data-tutorial]{position:relative;z-index:1002!important}@keyframes tutorialPulse{0%,to{box-shadow:0 0 0 9999px #111827a6,0 0 0 3px #3b82f6,0 8px 24px #3b82f666}50%{box-shadow:0 0 0 9999px #111827a6,0 0 0 3px #60a5fa,0 8px 32px #3b82f699}}.tutorialTooltip{position:fixed;z-index:1002;pointer-events:auto;max-width:min(90vw,400px)}.tutorialTooltipContent{background:#fff;border-radius:16px;border:2px solid #3B82F6;box-shadow:0 20px 40px #11182740;padding:18px 20px;margin-bottom:12px}.tutorialTooltipText{margin:0 0 16px;font-size:15px;font-weight:700;color:#111827;line-height:1.5}.tutorialTooltipActions{display:flex;gap:10px;justify-content:flex-end}.tutorialBtn{padding:10px 18px;border-radius:12px;font-weight:900;font-size:14px;cursor:pointer;border:2px solid;transition:all .15s ease;white-space:nowrap}.tutorialBtnPrimary{background:#3b82f6;color:#fff;border-color:#3b82f6}.tutorialBtnPrimary:hover{background:#2563eb;border-color:#2563eb;transform:translateY(-1px)}.tutorialBtnPrimary:active{transform:translateY(0)}.tutorialBtnSecondary{background:#fff;color:#374151;border-color:#d1d5db}.tutorialBtnSecondary:hover{background:#f9fafb;border-color:#9ca3af}.tutorialBtnSecondary:active{transform:scale(.98)}.tutorialIconBtn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1px solid #E5E7EB;background:#fff;color:#374151;font-weight:900;font-size:16px;cursor:pointer;transition:all .15s ease;margin-left:8px}.tutorialIconBtn:hover{background:#f9fafb;border-color:#d1d5db;color:#111827}.tutorialIconBtn:active{transform:scale(.95)}@media(max-width:720px){.tutorialTooltip{max-width:95vw}.tutorialTooltipContent{padding:14px 16px}.tutorialTooltipText{font-size:14px}.tutorialTooltipActions{flex-direction:column}.tutorialBtn{width:100%}}.adminPage{display:flex;flex-direction:column;height:100%;overflow-y:auto;background:#f9fafb;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;font-feature-settings:"cv02","cv03","cv04","cv11"}.adminHeader{display:flex;align-items:center;gap:14px;padding:14px 20px;border-bottom:1px solid #E5E7EB;background:#fff;position:sticky;top:0;z-index:10}.adminHeaderTitle{font-weight:900;font-size:16px;color:#111827}.adminLoading{display:flex;align-items:center;justify-content:center;flex:1;color:#6b7280;font-size:14px;padding:40px 20px}.adminErrorRetry{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 20px;text-align:center;color:#b91c1c;font-size:14px}.adminErrorRetry p{margin:0}.adminErrorRetry .menuBtn{color:#1f2937}.adminToolbar{display:flex;align-items:center;gap:10px;padding:12px 20px;border-bottom:1px solid #E5E7EB;background:#fff}.adminTabs{display:flex;gap:0;padding:0 20px;border-bottom:1px solid #E5E7EB;background:#fff}.adminTab{padding:10px 18px;font-size:13px;font-weight:700;color:#6b7280;background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .15s,border-color .15s}.adminTab:hover{color:#374151}.adminTab.active{color:#111827;border-bottom-color:#3b82f6}.adminContent{flex:1;padding:20px;overflow-y:auto}.adminCard{background:#fff;border:1px solid #E5E7EB;border-radius:14px;padding:20px;max-width:900px}.adminSectionTitle{font-weight:900;font-size:14px;color:#111827;margin-bottom:12px}.adminDivider{border:none;border-top:1px solid #E5E7EB;margin:16px 0}.adminField{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.adminFieldInline{flex-direction:row;align-items:center;gap:10px}.adminLabel{font-weight:700;font-size:12px;color:#374151}.adminInput{padding:8px 12px;border:1px solid #D1D5DB;border-radius:10px;font-size:13px;font-weight:600;color:#111827;background:#fff;outline:none;transition:border-color .15s}.adminInput:focus{border-color:#3b82f6;outline:2px solid rgba(59,130,246,.15)}.adminInput:disabled{background:#f3f4f6;color:#9ca3af}.adminSelect{padding:8px 12px;border:1px solid #D1D5DB;border-radius:10px;font-size:13px;font-weight:600;color:#111827;cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-color:#fff;background-image:var(--select-chevron);background-repeat:no-repeat;background-position:right .55rem center;background-size:1rem 1rem;padding-inline-end:2.1rem;box-shadow:0 1px 2px #1118270d;transition:border-color .12s ease,box-shadow .12s ease}.adminSelect:hover:not(:disabled){border-color:#9ca3af}.adminSelect:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61f,0 1px 2px #1118270d}.adminSelect:disabled{opacity:.55;cursor:not-allowed;background-color:#f3f4f6}.adminSelectSmall{min-width:96px;max-width:140px;padding-inline-end:1.85rem;background-position:right .35rem center;background-size:.9rem .9rem}.adminNumInput{width:90px;padding:8px 10px;border:1px solid #D1D5DB;border-radius:10px;font-size:13px;font-weight:600;color:#111827;text-align:center}.adminFieldsGrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.adminFieldGroup{display:flex;flex-direction:column;gap:8px}.adminFieldRow{display:flex;gap:8px;align-items:flex-start}.adminFieldRowLabel{font-weight:700;font-size:12px;color:#374151;min-width:140px;padding-top:8px}.adminCreditosSum{font-size:13px;font-weight:800;padding:6px 10px;border-radius:8px;margin-top:4px}.adminCreditosSum.valid{color:#065f46;background:#d1fae5}.adminCreditosSum.invalid{color:#7f1d1d;background:#fee2e2}.adminTable{border:1px solid #E5E7EB;border-radius:10px;overflow:hidden}.adminTableHeader{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f3f4f6;font-size:11px;font-weight:800;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.adminTableRow{display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:13px;color:#374151;border-top:1px solid #F3F4F6;transition:background .1s}.adminTableRow:hover{background:#f9fafb}.adminTableRowEditing{background:#fffbeb}.adminFilterBar{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}.adminSmallBtn{padding:4px 10px;border:1px solid #D1D5DB;border-radius:8px;font-size:11px;font-weight:700;color:#374151;background:#fff;cursor:pointer;transition:background .1s}.adminSmallBtn:hover{background:#f3f4f6}.adminSmallBtnDanger{color:#7f1d1d;border-color:#fecaca;background:#fef2f2}.adminSmallBtnDanger:hover{background:#fee2e2}.adminAddBtn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border:1px dashed #D1D5DB;border-radius:8px;font-size:12px;font-weight:700;color:#6b7280;background:transparent;cursor:pointer;transition:border-color .15s,color .15s}.adminAddBtn:hover{border-color:#3b82f6;color:#3b82f6}.adminAddBtnGroup{display:flex;gap:8px;flex-wrap:wrap}.adminCancelBtn{padding:6px 12px;border:1px solid #D1D5DB;border-radius:8px;font-size:12px;font-weight:700;color:#6b7280;background:#fff;cursor:pointer}.adminRemoveBtn{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:8px;font-size:16px;font-weight:900;color:#9ca3af;background:transparent;cursor:pointer;flex-shrink:0;transition:color .1s,background .1s}.adminRemoveBtn:hover{color:#ef4444;background:#fef2f2}.adminActions{display:flex;align-items:center;gap:10px;margin-top:16px}.adminError{color:#7f1d1d;background:#fef2f2;border:1px solid #FECACA;border-radius:10px;padding:8px 12px;font-size:13px;font-weight:700;margin-bottom:10px}.adminSuccess{color:#065f46;background:#d1fae5;border:1px solid #6EE7B7;border-radius:10px;padding:8px 12px;font-size:13px;font-weight:700;margin-bottom:10px}.adminModalOverlay{position:fixed;inset:0;background:#00000073;z-index:500}.adminModal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(720px,96vw);max-height:92vh;background:#fff;border-radius:18px;box-shadow:0 20px 60px #0003;z-index:501;display:flex;flex-direction:column;overflow:hidden}.adminModalHeader{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #E5E7EB;flex-shrink:0}.adminModalTitle{font-weight:900;font-size:16px;color:#111827}.adminModalBody{padding:20px;overflow-y:auto;flex:1}.previasGroup{border-left:3px solid;border-radius:6px;padding:10px 12px 10px 14px;margin:6px 0}.previasGroup--allOf{border-left-color:#3b82f6;background:#3b82f60a}.previasGroup--anyOf{border-left-color:#f59e0b;background:#f59e0b0a}.previasGroupHeader{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.previasGroupLabel{font-weight:800;font-size:12px;color:#374151;text-transform:uppercase;letter-spacing:.3px}.previasGroup--allOf>.previasGroupHeader>.previasGroupLabel{color:#1e40af}.previasGroup--anyOf>.previasGroupHeader>.previasGroupLabel{color:#92400e}.previasLeaf{display:flex;align-items:center;gap:8px;padding:6px 10px;margin:4px 0;border:1px solid #E5E7EB;border-radius:8px;background:#fff;flex-wrap:wrap}.previasLeaf--special{border-color:#a7f3d0;background:#f0fdf4}.previasSpecialLabel{font-weight:700;font-size:12px;color:#065f46;white-space:nowrap}.previasAddPanel{display:flex;gap:8px;align-items:center;padding:8px 10px;margin-top:6px;border:1px dashed #D1D5DB;border-radius:8px;background:#fafafa;flex-wrap:wrap}.previasAddActions{display:flex;gap:6px}.adminToggle{display:inline-flex;align-items:center;justify-content:center;min-width:52px;padding:5px 14px;border-radius:20px;border:none;font-size:12px;font-weight:800;cursor:pointer;transition:background .15s,color .15s}.adminToggleOn{background:#d1fae5;color:#065f46}.adminToggleOn:hover{background:#a7f3d0}.adminToggleOff{background:#fee2e2;color:#7f1d1d}.adminToggleOff:hover{background:#fecaca}.adminHiddenBadge{display:inline-block;font-size:10px;font-weight:800;color:#7f1d1d;background:#fee2e2;border-radius:6px;padding:1px 6px;margin-left:6px;vertical-align:middle}.adminNewChoices{display:flex;gap:12px;flex-wrap:wrap}.adminChoiceBtn{flex:1;min-width:200px;display:flex;flex-direction:column;gap:6px;padding:16px;border:1px solid #D1D5DB;border-radius:12px;background:#fff;cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.adminChoiceBtn:hover{border-color:#3b82f6;background:#f0f7ff}.adminChoiceTitle{font-weight:800;font-size:14px;color:#111827}.adminChoiceDesc{font-size:12px;font-weight:500;color:#6b7280;line-height:1.4}.adminJsonTextarea{width:100%;min-height:420px;padding:12px 14px;border:1px solid #D1D5DB;border-radius:10px;font-family:SF Mono,Cascadia Code,Fira Code,Consolas,monospace;font-size:12px;line-height:1.5;color:#111827;background:#fafafa;resize:vertical;tab-size:2;outline:none;transition:border-color .15s}.adminJsonTextarea:focus{border-color:#3b82f6;outline:2px solid rgba(59,130,246,.15)}.adminImportProgress{display:flex;flex-direction:column;gap:6px;margin-top:12px}.adminImportProgressBar{height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden}.adminImportProgressFill{height:100%;background:#3b82f6;border-radius:3px;transition:width .2s ease}.adminImportProgressText{font-size:12px;font-weight:600;color:#6b7280}@media(max-width:600px){.adminFieldsGrid{grid-template-columns:1fr}.adminToolbar{flex-wrap:wrap}.adminModal{width:100vw;max-height:100vh;border-radius:0;top:0;left:0;transform:none}.adminTableRow{flex-wrap:wrap}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-feature-settings:"cv02","cv03","cv04","cv11";letter-spacing:-.011em;color:#111827;background-color:#f9fafb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-gray-50: #F9FAFB;--color-gray-100: #F3F4F6;--color-gray-200: #E5E7EB;--color-gray-300: #D1D5DB;--color-gray-400: #9CA3AF;--color-gray-500: #6B7280;--color-gray-700: #374151;--color-gray-800: #1F2937;--color-gray-900: #111827;--color-blue-50: #EFF6FF;--color-blue-100: #DBEAFE;--color-blue-500: #3B82F6;--color-blue-600: #2563EB;--color-blue-900: #1E3A8A;--color-green-50: #ECFDF5;--color-green-100: #D1FAE5;--color-green-200: #A7F3D0;--color-green-500: #10B981;--color-green-800: #065F46;--color-yellow-50: #FEFCE8;--color-yellow-100: #FEF9C3;--color-yellow-500: #EAB308;--color-yellow-800: #713F12;--color-red-50: #FEF2F2;--color-red-100: #FEE2E2;--color-red-300: #FCA5A5;--color-red-500: #EF4444;--color-red-600: #DC2626;--color-red-800: #991B1B;--color-red-900: #7F1D1D;--color-purple-50: #FAF5FF;--color-purple-100: #F3E8FF;--color-purple-500: #8B5CF6;--color-purple-600: #7C3AED;--color-purple-900: #4C1D95;--bg-page: var(--color-gray-50);--bg-surface: #ffffff;--text-primary: var(--color-gray-900);--text-secondary: var(--color-gray-700);--text-muted: var(--color-gray-500);--border-default: var(--color-gray-200);--border-subtle: rgba(17, 24, 39, .06);--font-app: "Outfit", Inter, system-ui, sans-serif;--font-welcome: var(--font-app);--bg-app-linear: linear-gradient(168deg, var(--color-blue-50) 0%, #eef2f7 42%, var(--color-gray-100) 100%);--surface-glass: rgba(248, 250, 252, .88);--surface-glass-card: rgba(248, 250, 252, .86);--border-surface: rgba(148, 163, 184, .35);--select-chevron: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M6 9l6 6 6-6'/%3E%3C/svg%3E");--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 20px;--space-2xl: 24px;--space-3xl: 32px;--radius-sm: 8px;--radius-md: 10px;--radius-lg: 12px;--radius-xl: 14px;--radius-2xl: 18px;--radius-full: 999px;--shadow-xs: 0 1px 2px rgba(17, 24, 39, .05);--shadow-sm: 0 2px 6px rgba(17, 24, 39, .06), 0 1px 2px rgba(17, 24, 39, .04);--shadow-md: 0 4px 12px rgba(17, 24, 39, .08), 0 2px 4px rgba(17, 24, 39, .04);--shadow-lg: 0 12px 32px rgba(17, 24, 39, .1), 0 4px 8px rgba(17, 24, 39, .04);--shadow-xl: 0 24px 56px rgba(17, 24, 39, .14), 0 8px 16px rgba(17, 24, 39, .06);--ease-out: cubic-bezier(.2, 0, 0, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--duration-fast: .12s;--duration-normal: .2s;--duration-slow: .32s;--glass-bg: rgba(255, 255, 255, .72);--glass-border: rgba(255, 255, 255, .5);--glass-blur: blur(16px)}html{scroll-behavior:smooth}::selection{background:#3b82f62e}body{margin:0;min-width:320px;min-height:100vh}*{box-sizing:border-box}
