@import"https://cdn.jsdelivr.net/npm/geist@1.3.0/dist/fonts/geist-sans/style.css";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}:root{--hop-navy: #2B4C7E;--hop-navy-dark: #1E3A5F;--hop-navy-light: #3D6098;--hop-green: #6DB33F;--hop-green-dark: #5A9A2F;--hop-green-light: #8BC764;--hop-blue: #1E2740;--hop-blue-dark: #151C30;--hop-blue-light: #384560;--hop-white: #FFFFFF;--hop-bg: #FAFBFC;--hop-surface: #FFFFFF;--hop-card: #FFFFFF;--hop-border: #EBEEF2;--hop-border-light: #F3F5F7;--hop-muted: #6B7280;--hop-ink: #1A2332;--hop-ink-secondary: #4A5568;--hop-success: #6DB33F;--hop-success-bg: #EFF8E8;--hop-error: #DC3545;--hop-error-bg: #FDF2F2;--hop-info: #1E2740;--hop-info-bg: #EBEDF2;--hop-shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--hop-shadow-md: 0 2px 8px rgba(0, 0, 0, .06);--hop-shadow-lg: 0 4px 16px rgba(0, 0, 0, .08);--hop-radius-sm: 8px;--hop-radius-md: 12px;--hop-radius-lg: 16px;--hop-radius-xl: 20px;--hop-radius-pill: 999px;--hop-ease: .18s ease-out;--hop-neutral-bg: #F3F4F6;--hop-placeholder: #C4C9D2;--hop-panel-dark: #1A1A2E}:root[data-theme=dark]{--hop-navy: #5B8CC8;--hop-navy-dark: #7BA3D6;--hop-navy-light: #4A7AB8;--hop-green: #7BC74F;--hop-green-dark: #6DB33F;--hop-green-light: #90D66A;--hop-blue: #4A6FA5;--hop-blue-dark: #3D5F90;--hop-blue-light: #6B8FC0;--hop-white: #1A1D23;--hop-bg: #12151A;--hop-surface: #1E2128;--hop-card: #252A34;--hop-border: #2D3340;--hop-border-light: #252B36;--hop-muted: #8896A6;--hop-ink: #E8ECF1;--hop-ink-secondary: #B0BAC5;--hop-success: #7BC74F;--hop-success-bg: #1A2E1A;--hop-error: #F06060;--hop-error-bg: #2E1A1A;--hop-info: #6B8FC0;--hop-info-bg: #1A2030;--hop-shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--hop-shadow-md: 0 2px 8px rgba(0, 0, 0, .3);--hop-shadow-lg: 0 4px 16px rgba(0, 0, 0, .4);--hop-neutral-bg: #252B36;--hop-placeholder: #555E6B;--hop-panel-dark: #0F1118}body{margin:0;color:var(--hop-ink);background:var(--hop-bg);font-family:Geist Sans,Geist,system-ui,-apple-system,Segoe UI,sans-serif;font-weight:400;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:-.011em}h1,h2,h3,h4,h5,h6{font-family:Geist Sans,Geist,system-ui,-apple-system,Segoe UI,sans-serif;font-weight:700;letter-spacing:-.025em}.hop-wrap{min-height:100vh;display:flex;flex-direction:column;background:var(--hop-white)}.hop-content{padding:16px 2.5rem 32px;max-width:1600px;margin:0 auto;width:100%;box-sizing:border-box}.hop-header{padding:1rem 2.5rem;display:flex;align-items:center;justify-content:space-between;background:#ffffffb8;backdrop-filter:blur(16px) saturate(1.6);-webkit-backdrop-filter:blur(16px) saturate(1.6);border-bottom:1px solid rgba(255,255,255,.4);box-shadow:0 1px 3px #0000000a,inset 0 -1px #0000000a;position:sticky;top:0;z-index:30}.hop-header__left{display:flex;align-items:center;gap:14px}.hop-logo{height:48px;width:auto;display:block;animation:none}.hop-header__back-btn{display:inline-flex;align-items:center;gap:4px;padding:.35rem .75rem;font-size:.78rem;font-weight:600;font-family:inherit;border:1.5px solid var(--hop-border);border-radius:var(--hop-radius-pill);background:transparent;color:var(--hop-muted);cursor:pointer;transition:none}.hop-header__back-btn:hover{border-color:var(--hop-blue);color:var(--hop-blue)}.hop-app-title{font-size:18px;font-weight:700;color:var(--hop-ink)}.hop-header__right{display:flex;align-items:center;gap:14px}.hop-header__divider{width:4px;height:4px;border-radius:50%;background:var(--hop-border)}.hop-header__signout{padding:.45rem 1.4rem;font-size:.85rem;font-weight:500;font-family:inherit;border-radius:var(--hop-radius-pill);border:1.5px solid var(--hop-border);background:transparent;color:var(--hop-ink-secondary);cursor:pointer;transition:border-color .15s,color .15s,box-shadow .15s}.hop-header__signout:hover{border-color:var(--hop-blue);color:var(--hop-blue);box-shadow:0 2px 8px #1e27401a}.hop-download{position:relative}.hop-header__download{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem 1.4rem;font-size:.85rem;font-weight:500;font-family:inherit;border-radius:var(--hop-radius-pill);border:1.5px solid var(--hop-blue);background:var(--hop-blue);color:#fff;cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s,transform .15s}.hop-header__download:hover{background:var(--hop-blue-dark);border-color:var(--hop-blue-dark);box-shadow:0 2px 12px #2b5ea740;transform:translateY(-1px)}.hop-download__arrow{font-size:.65rem;transition:transform .2s}.hop-download__arrow--open{transform:rotate(180deg)}.hop-download__menu{position:absolute;top:calc(100% + 6px);right:0;min-width:240px;background:#ffffffd1;backdrop-filter:blur(20px) saturate(1.6);-webkit-backdrop-filter:blur(20px) saturate(1.6);border:1px solid rgba(255,255,255,.5);border-radius:var(--hop-radius-md);box-shadow:0 8px 32px #0000001f,0 2px 8px #0000000a;z-index:50;padding:4px;animation:dropdownFadeIn .15s ease-out}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.hop-download__item{display:flex;align-items:center;gap:.6rem;width:100%;padding:.6rem .75rem;font-size:.85rem;font-weight:500;font-family:inherit;color:var(--hop-ink);background:transparent;border:none;border-radius:var(--hop-radius-sm);cursor:pointer;text-align:left;transition:background .1s}.hop-download__item:hover{background:var(--hop-bg)}.hop-download__item--disabled{opacity:.45;cursor:not-allowed}.hop-download__item--disabled:hover{background:transparent}.hop-download__icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:24px;font-size:.65rem;font-weight:700;letter-spacing:.03em;border-radius:4px;flex-shrink:0;color:#fff;background:var(--hop-blue)}.hop-download__lock{margin-left:auto;font-size:.68rem;font-weight:600;color:var(--hop-muted);background:var(--hop-neutral-bg);padding:1px 6px;border-radius:999px}.badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:4px 12px;border-radius:999px;background:var(--hop-success-bg);color:var(--hop-green-dark);border:1px solid rgba(30,39,64,.25)}.badge--error{background:var(--hop-error-bg);color:var(--hop-error);border-color:#dc354540}.badge--success{background:#1a8a7d1a;color:#1a8a7d;border-color:#1a8a7d40}.badge--neutral{background:var(--hop-neutral-bg);color:var(--hop-muted);border-color:var(--hop-border)}.step-progress{display:flex;align-items:center;justify-content:center;gap:0;margin:0 auto 12px;max-width:820px;padding:10px 16px}.step-progress__item{display:flex;align-items:center;flex:1}.step-progress__item:last-child{flex:0}.step-progress__dot{width:32px;height:32px;border-radius:50%;border:2px solid var(--hop-border);background:var(--hop-surface);color:var(--hop-muted);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s cubic-bezier(.32,1.28,.48,1);flex-shrink:0;position:relative;z-index:1;font-family:inherit;box-shadow:inset 0 1px 3px #0000000f}.step-progress__dot:hover{border-color:var(--hop-blue-light);color:var(--hop-blue);transform:scale(1.15);box-shadow:0 0 0 4px #1e27400f,inset 0 1px 3px #0000000f}.step-progress__dot--active{background:linear-gradient(135deg,var(--hop-blue) 0%,var(--hop-blue-dark) 100%);border-color:var(--hop-blue);color:#fff;box-shadow:0 0 0 4px #1e27401f,0 3px 10px #1e274033;transform:scale(1.1);animation:none}.step-progress__dot--completed{background:linear-gradient(135deg,var(--hop-green) 0%,var(--hop-green-dark) 100%);border-color:var(--hop-green);color:#fff;box-shadow:0 2px 8px #6db33f40}.step-progress__dot--active.step-progress__dot--completed{background:linear-gradient(135deg,var(--hop-green) 0%,var(--hop-green-dark) 100%);border-color:var(--hop-green);box-shadow:0 0 0 4px #6db33f2e,0 3px 10px #6db33f40}.step-progress__line{flex:1;height:3px;background:var(--hop-border);margin:0 -2px;border-radius:2px}.step-progress__line--completed{background:linear-gradient(90deg,var(--hop-green) 0%,var(--hop-green-light) 100%);box-shadow:0 0 6px #6db33f33}.hop-diagram{display:flex;align-items:center;justify-content:center;gap:16px;max-width:1200px;margin:4px auto 16px;padding:24px 20px;position:relative;border-radius:var(--hop-radius-xl);background:radial-gradient(ellipse 80% 60% at 30% 40%,rgba(43,76,126,.04) 0%,transparent 70%),radial-gradient(ellipse 60% 80% at 70% 60%,rgba(109,179,63,.04) 0%,transparent 70%)}.hop-diagram:before,.hop-diagram:after{display:none}.hop-diagram__col{display:flex;flex-direction:column;gap:14px;flex:1;max-width:168px}.hop-diagram__col--single,.hop-diagram__col--pair{justify-content:center}.hop-step-card{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:18px 14px;min-height:110px;border:none;border-radius:22px;background:var(--card-color);color:#fff;cursor:pointer;font-family:inherit;transition:transform .25s cubic-bezier(.32,1.28,.48,1),box-shadow .25s ease,filter .25s ease;box-shadow:0 2px 8px #00000014,inset 0 1px #ffffff26;animation:hopCardIn .45s cubic-bezier(.32,1.28,.48,1) both;overflow:hidden}.hop-step-card--img{background:transparent;padding:0;box-shadow:none}.hop-step-card--img:before{display:none}.hop-step-card__img{width:100%;height:100%;object-fit:contain;display:block;border-radius:inherit}.hop-step-card:before{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(135deg,rgba(255,255,255,.22) 0%,rgba(255,255,255,.05) 40%,transparent 70%),linear-gradient(to bottom,rgba(255,255,255,.08) 0%,transparent 50%,rgba(0,0,0,.06) 100%);pointer-events:none}.hop-step-card__num{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;opacity:.85;margin-bottom:4px}.hop-step-card__label{font-size:.82rem;font-weight:600;line-height:1.35;letter-spacing:-.01em}.hop-step-card:hover{transform:translateY(-5px) scale(1.03);box-shadow:0 8px 24px #00000024,inset 0 1px #fff3}.hop-step-card--active{transform:translateY(-4px) scale(1.05);box-shadow:0 0 0 3px #ffffffe6,0 0 0 6px var(--card-color),0 0 24px color-mix(in srgb,var(--card-color) 35%,transparent),0 8px 28px #0000001f;animation:none;overflow:hidden}.hop-step-card--active:not(.hop-step-card--completed):after{display:none}.hop-step-card--active:hover{transform:translateY(-5px) scale(1.06)}.hop-diagram:has(.hop-step-card--active) .hop-step-card:not(.hop-step-card--active){filter:brightness(.88) saturate(.75);transform:scale(.97)}.hop-diagram:has(.hop-step-card--active) .hop-step-card:not(.hop-step-card--active):hover{filter:brightness(1) saturate(1);transform:translateY(-5px) scale(1.03)}.hop-step-card:focus-visible{outline:3px solid var(--hop-blue);outline-offset:3px}@keyframes hopCardIn{0%{opacity:0;transform:translateY(16px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}.hop-diagram__col:last-child .hop-step-card{min-height:140px;border-radius:28px}@media (max-width: 900px){.hop-diagram{flex-wrap:wrap;gap:10px;padding:14px 10px}.hop-diagram__col{max-width:120px;min-width:100px}.hop-step-card{min-height:90px;padding:14px 10px}.hop-step-card__label{font-size:.75rem}}@media (max-width: 600px){.hop-diagram{gap:8px}.hop-diagram__col{max-width:100px;min-width:80px}.hop-step-card{min-height:75px;padding:10px 8px;border-radius:16px}.hop-step-card__num{font-size:.6rem}.hop-step-card__label{font-size:.68rem}}.pin-layout{display:flex;width:100%;min-height:calc(100vh - 280px);max-height:calc(100vh - 280px);gap:0;padding:12px 0 80px}.pin-panel{width:0;min-width:0;overflow:hidden;flex:0 0 0;display:flex;flex-direction:row;transition:none;contain:layout style paint}.pin-panel--left{flex-direction:row}.pin-panel--right{flex-direction:row-reverse}.pin-panel--open{flex:1 1 0;min-width:280px}.pin-panel--right.pin-panel--open{flex:1.4 1 0;min-width:320px}.pin-panel__accent{display:none}.pin-panel__inner{flex:1;display:flex;flex-direction:column;min-width:0;background:#ffffffa6;backdrop-filter:blur(12px) saturate(1.4);-webkit-backdrop-filter:blur(12px) saturate(1.4);box-shadow:0 4px 24px #0000000a,inset 0 1px #fff9,inset 0 0 0 1px #ffffff26;border:1px solid rgba(255,255,255,.5);border-radius:var(--hop-radius-lg);overflow:hidden}.pin-panel__header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;flex-shrink:0;border-bottom:1px solid rgba(0,0,0,.06)}.pin-panel__header--navy,.pin-panel__header--green{background:transparent}.pin-panel__header-content{display:flex;align-items:center;gap:10px;flex:1;justify-content:center}.pin-panel__header--navy .pin-panel__header-content svg{color:var(--hop-navy)}.pin-panel__header--green .pin-panel__header-content svg{color:var(--hop-navy)}.pin-panel__title{font-size:14px;font-weight:700;color:var(--hop-ink);letter-spacing:-.01em;white-space:nowrap}.pin-panel__close{width:30px;height:30px;border-radius:8px;border:none;background:transparent;color:var(--hop-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:none;flex-shrink:0}.pin-panel__close:hover{background:#1e274014;color:var(--hop-ink);transform:scale(1.1)}.pin-panel__content{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;min-height:0}.pin-panel__content .embed-card{border:none;box-shadow:none;padding:8px 8px 0;height:100%;width:100%;display:flex;flex-direction:column;background:transparent}.pin-panel__content .embed-tabs{align-self:center;flex-shrink:0}.pin-panel__content .embed-frame-wrap{max-height:none;height:100%;width:100%;aspect-ratio:auto;flex:1;min-height:0}.pin-panel__content .embed-frame-wrap--video{aspect-ratio:16 / 9;flex:none;height:auto;margin-top:auto;margin-bottom:auto}.pin-panel__content .chat-wrap{border:none;box-shadow:none;border-radius:0;padding:0;flex:1;min-height:0;background:transparent}.cmd-bar{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:45;display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:var(--hop-radius-xl);background:#ffffffb8;backdrop-filter:blur(20px) saturate(1.8);-webkit-backdrop-filter:blur(20px) saturate(1.8);border:1px solid rgba(255,255,255,.5);box-shadow:0 8px 32px #0000001a,0 2px 8px #0000000a,inset 0 1px #fff9;transition:none}@keyframes cmdBarSlideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.cmd-bar__divider{width:1px;height:28px;background:#0000001a;margin:0 4px}.cmd-bar__btn{display:flex;align-items:center;gap:8px;padding:10px 20px;font-size:13.5px;font-weight:600;font-family:inherit;border:1.5px solid transparent;background:transparent;color:var(--hop-ink-secondary);cursor:pointer;border-radius:var(--hop-radius-md);transition:none;position:relative}.cmd-bar__btn:hover{background:#1e27400f;color:var(--hop-ink)}.cmd-bar__btn--lesson.cmd-bar__btn--active{background:var(--hop-navy);color:#fff;border-color:var(--hop-navy);box-shadow:0 4px 16px #2b4c7e4d}.cmd-bar__btn--assistant.cmd-bar__btn--active{background:var(--hop-green-dark);color:#fff;border-color:var(--hop-green-dark);box-shadow:0 4px 16px #5a9a2f4d}.cmd-bar__icon{display:flex;align-items:center;justify-content:center}.cmd-bar__label{letter-spacing:-.01em}.cmd-bar__hint{font-size:11px;font-weight:500;color:var(--hop-muted);letter-spacing:-.01em;white-space:nowrap;padding:0 4px}.pin-layout__main{flex:1 1 0;min-width:0;background:#ffffffa6;backdrop-filter:blur(12px) saturate(1.4);-webkit-backdrop-filter:blur(12px) saturate(1.4);border:1px solid rgba(255,255,255,.5);border-radius:var(--hop-radius-lg);padding:20px;overflow-y:auto;box-shadow:0 4px 24px #0000000a,inset 0 1px #fff9,inset 0 0 0 1px #ffffff26;transition:none}.pin-layout__main-title{margin:0 0 12px;font-size:.92rem;font-weight:700;color:var(--hop-ink);letter-spacing:.01em;text-align:center}:root[data-theme=dark] .pin-panel__inner{background:#1e21288c;border-color:#ffffff0f;box-shadow:0 4px 24px #00000026,inset 0 1px #ffffff0a,inset 0 0 0 1px #ffffff08}:root[data-theme=dark] .pin-panel__header{border-bottom-color:#ffffff0f}:root[data-theme=dark] .pin-panel__header--navy{background:transparent}:root[data-theme=dark] .pin-panel__header--green{background:transparent}:root[data-theme=dark] .pin-panel__close:hover{background:#ffffff1a}:root[data-theme=dark] .cmd-bar{background:#1e2128c7;border-color:#ffffff1a;box-shadow:0 8px 32px #0000004d,0 2px 8px #00000026,inset 0 1px #ffffff0f}:root[data-theme=dark] .cmd-bar__divider{background:#ffffff1a}:root[data-theme=dark] .cmd-bar__btn:hover{background:#ffffff14}:root[data-theme=dark] .cmd-bar__btn--lesson.cmd-bar__btn--active{background:var(--hop-navy);border-color:var(--hop-navy);box-shadow:0 4px 16px #5b8cc84d}:root[data-theme=dark] .cmd-bar__btn--assistant.cmd-bar__btn--active{background:var(--hop-green-dark);border-color:var(--hop-green-dark);box-shadow:0 4px 16px #6db33f4d}@media (max-width: 900px){.pin-layout{flex-direction:column;max-height:none}.pin-panel--open{width:100%;min-width:0}.pin-panel{width:100%;height:0;min-height:0;transition:none}.pin-panel--open{height:320px;min-height:200px}.cmd-bar{bottom:16px;left:12px;right:12px;transform:none;justify-content:center}@keyframes cmdBarSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}}.embed-card{border:1px solid var(--hop-border);border-radius:var(--hop-radius-lg);padding:14px;background:var(--hop-surface);box-shadow:var(--hop-shadow-sm);transition:box-shadow var(--hop-ease),transform var(--hop-ease);animation:fadeSlideIn .35s ease-out}.embed-card:hover{box-shadow:var(--hop-shadow-md)}.embed-title{margin:0 0 10px;font-size:14px;font-weight:600;color:var(--hop-navy)}.embed-frame-wrap{position:relative;width:100%;aspect-ratio:3 / 4;max-height:650px;border-radius:var(--hop-radius-md);overflow:hidden;background:#fff;border:1px solid var(--hop-border-light)}.embed-frame-wrap--video{aspect-ratio:16 / 9}:root[data-theme=dark] .embed-frame-wrap{background:#000}.embed-frame-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:none}.embed-placeholder{font-size:.9rem;color:var(--hop-muted)}.embed-step-title{margin:0 0 10px;font-size:.85rem;font-weight:700;color:var(--hop-navy);text-transform:uppercase;letter-spacing:.03em}.embed-tabs{display:flex;gap:0;border:1.5px solid var(--hop-border);border-radius:var(--hop-radius-pill);overflow:hidden;width:fit-content;margin-bottom:10px}.embed-tabs__btn{padding:.4rem 1rem;font-size:.78rem;font-weight:600;font-family:inherit;border:none;background:transparent;color:var(--hop-muted);cursor:pointer;transition:none}.embed-tabs__btn--active{background:var(--hop-blue);color:#fff}.embed-tabs__btn:not(.embed-tabs__btn--active):hover{background:#1e27400a;color:var(--hop-ink)}.step-details{display:flex;flex-direction:column;gap:14px;animation:fadeSlideIn .35s ease-out}.step-details .hop-card{animation:scaleIn .3s ease-out both}.step-details .hop-card:nth-child(1){animation-delay:.05s}.step-details .hop-card:nth-child(2){animation-delay:.12s}.step-details .hop-card:nth-child(3){animation-delay:.19s}.step-details .badge{margin-top:8px}.hop-card{width:100%;border:1px solid var(--hop-border);border-radius:var(--hop-radius-lg);padding:22px;background:var(--hop-surface);box-shadow:var(--hop-shadow-sm);transition:border-color var(--hop-ease),box-shadow var(--hop-ease),transform var(--hop-ease)}.hop-card:hover{border-color:var(--hop-blue-light);box-shadow:var(--hop-shadow-md);transform:translateY(-1px)}.step-details .hop-card:first-child{border-left:3px solid var(--hop-blue)}.hop-title{font-size:20px;font-weight:700;margin:0 0 8px;color:var(--hop-navy-dark)}.hop-desc{color:var(--hop-ink-secondary);font-size:14px;line-height:1.55;font-weight:400}.hop-desc strong{color:var(--hop-ink);font-weight:600}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 24px;border-radius:var(--hop-radius-pill);border:1px solid var(--hop-border);background:var(--hop-surface);color:var(--hop-ink);cursor:pointer;font-size:14px;font-weight:500;font-family:inherit;transition:all var(--hop-ease)}.btn:hover{background:var(--hop-bg);border-color:var(--hop-blue-light);color:var(--hop-blue);transform:translateY(-1px);box-shadow:var(--hop-shadow-sm)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn--primary,.btn.dark{background:var(--hop-blue);border-color:var(--hop-blue);color:var(--hop-white);box-shadow:0 2px 8px #1e274040}.btn--primary:hover,.btn.dark:hover{background:var(--hop-blue-dark);border-color:var(--hop-blue-dark);color:var(--hop-white);box-shadow:0 4px 14px #1e274059}.btn--outline{background:transparent;border-color:var(--hop-border);color:var(--hop-ink-secondary)}.btn--outline:hover{border-color:var(--hop-blue);color:var(--hop-blue);background:#1e27400a}.btn--green{background:var(--hop-green);border-color:var(--hop-green);color:var(--hop-white)}.btn--green:hover{background:var(--hop-green-dark);border-color:var(--hop-green-dark)}.input,.textarea,select.input{width:100%;border:1px solid var(--hop-border);border-radius:var(--hop-radius-sm);padding:10px 12px;font-size:14px;font-family:inherit;color:var(--hop-ink);background:var(--hop-surface);transition:border-color var(--hop-ease),box-shadow var(--hop-ease)}.input:focus,.textarea:focus,select.input:focus{outline:none;border-color:var(--hop-blue);box-shadow:0 0 0 4px #1e27401f}.input:disabled,.textarea:disabled{background:var(--hop-bg);color:var(--hop-muted);cursor:not-allowed}.chat-wrap{display:flex;flex-direction:column;gap:0;border-radius:0;padding:0;background:transparent;border:none;box-shadow:none;height:100%}.chat-wrap:hover{box-shadow:none}.chat-body{flex:1;min-height:0;overflow-y:auto;padding:4px 2px 8px 0;display:flex;flex-direction:column;gap:6px}.chat-body::-webkit-scrollbar{width:5px}.chat-body::-webkit-scrollbar-track{background:transparent}.chat-body::-webkit-scrollbar-thumb{background:#94a3b866;border-radius:999px}.chat-body:hover::-webkit-scrollbar-thumb{background:#1e274059}.chat-row{display:flex;width:100%;font-size:.84rem}.chat-row.user{justify-content:flex-end}.chat-row.assistant{justify-content:flex-start}.chat-row.system{justify-content:center}.chat-event{font-size:.78rem;font-weight:600;color:var(--hop-muted);background:var(--hop-surface);border:1px solid var(--hop-border);border-radius:999px;padding:4px 14px;text-align:center}.chat-bubble{max-width:88%;border-radius:14px;padding:10px 14px;line-height:1.55;position:relative;border:1px solid transparent;letter-spacing:-.011em;transition:none}.chat-bubble--assistant{background:#ffffff8c;border-color:#0000000f;color:var(--hop-ink);box-shadow:0 1px 4px #0000000a;border-radius:4px 14px 14px}.chat-bubble--user{background:linear-gradient(135deg,#2b5ea7,#1e3a5f);color:#fff;box-shadow:0 2px 10px #1e3a5f4d;border-radius:14px 14px 4px}.chat-bubble--assistant:hover{border-color:#2b4c7e26;box-shadow:0 2px 8px #0000000f}.chat-bubble--user:hover{box-shadow:0 4px 16px #1e3a5f66}.chat-bubble--assistant p{margin:0 0 8px}.chat-bubble--assistant ul{margin:6px 0 8px 20px}.chat-bubble--assistant li{margin:2px 0}.chat-step-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:8px;vertical-align:middle;flex-shrink:0}.chat-step-group{margin:2px 0}.chat-step-group__header{display:flex;align-items:center;gap:8px;width:100%;padding:5px 8px;border:none;background:#00000005;cursor:pointer;border-radius:8px;border-left:3px solid var(--step-color, transparent);transition:none;font-family:inherit}.chat-step-group__header:hover{background:#0000000d}.chat-step-group__header:active{background:#00000012}.chat-step-group__header--open{background:#0000000a}.chat-step-group__pill{display:inline-flex;align-items:center;padding:2px 7px;border-radius:6px;color:#fff;font-size:10px;font-weight:700;letter-spacing:.03em;white-space:nowrap;text-transform:uppercase}.chat-step-group__label{font-size:11.5px;font-weight:600;color:var(--hop-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-step-group__count{font-size:10px;color:var(--hop-muted);margin-left:auto;white-space:nowrap;opacity:.7}.chat-step-group__arrow{font-size:9px;color:var(--hop-muted);transition:none}.chat-step-group__arrow--open{transform:rotate(180deg)}.chat-step-group__body{padding:4px 0 6px 6px;border-left:2px solid color-mix(in srgb,var(--step-color, transparent) 20%,transparent);margin-left:4px;contain:content}.chat-step-group__body--collapsed{display:none}.chat-bubble[style*=border-left]{padding-left:18px}.chat-empty{font-size:.82rem;color:var(--hop-muted);text-align:center;padding:2rem 1rem;margin:auto 0;line-height:1.6;background:#6db33f0a;border:1px dashed rgba(109,179,63,.18);border-radius:12px}.quick-options{display:flex;flex-wrap:wrap;gap:.5rem;margin:.3rem 0 .4rem}.btn.pill{border-radius:var(--hop-radius-pill);padding:.4rem 1rem;font-size:.85rem;background:var(--hop-blue);color:var(--hop-white);border:none;box-shadow:0 2px 6px #1e274040;transition:transform var(--hop-ease),box-shadow var(--hop-ease),background var(--hop-ease)}.btn.pill:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #1e274059;background:var(--hop-blue-dark)}.btn.pill:disabled{opacity:.55;cursor:not-allowed}.chat-input{margin-top:auto;padding-top:8px;display:flex;gap:6px;align-items:flex-end;border-top:1px solid rgba(0,0,0,.05)}.chat-input textarea{flex:1;resize:none;border-radius:10px;border:1px solid rgba(0,0,0,.08);padding:8px 12px;font-size:.84rem;background:#fff9;font-family:inherit;line-height:1.45;transition:none}.chat-input textarea:focus{outline:none;border-color:var(--hop-green-dark);box-shadow:0 0 0 2px #6db33f1f;background:#ffffffd9}.chat-body{position:relative;overflow-x:hidden}.chat-ripple{display:none}.collapsible{margin-top:.5rem}.collapsible__btn{width:100%;display:flex;justify-content:space-between;align-items:center;font-size:.8rem;padding:.4rem .55rem;border-radius:var(--hop-radius-md);border:1px dashed rgba(30,39,64,.25);background:var(--hop-info-bg);color:var(--hop-ink-secondary);cursor:pointer;font-family:inherit}.collapsible__body{margin-top:.45rem}.source-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:.5rem}.source-card{border-radius:var(--hop-radius-md);padding:.55rem .7rem;background:var(--hop-bg);border:1px solid var(--hop-border-light);font-size:.8rem}.source-chip{display:inline-flex;padding:.1rem .4rem;border-radius:999px;font-size:.7rem;background:var(--hop-info-bg);color:var(--hop-info)}.link-btn{margin-top:.25rem;background:none;border:none;padding:0;font-size:.78rem;color:var(--hop-blue);cursor:pointer;text-decoration:underline;font-family:inherit}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.typing-indicator{display:flex;gap:8px;align-items:center;margin:8px 0 8px 8px;background:transparent}.hop-grid-loader{background:transparent;overflow:visible}.hop-sq{opacity:.25;animation:hop-sq-light 2.7s infinite ease-in-out}.sq-1{animation-delay:0s}.sq-2{animation-delay:.2s}.sq-3{animation-delay:.4s}.sq-4{animation-delay:.6s}.sq-5{animation-delay:.8s}.sq-6{animation-delay:1s}.sq-7{animation-delay:1.2s}.sq-8{animation-delay:1.4s}.sq-9{animation-delay:1.6s}.hop-bot-label{font-size:13px;font-weight:600;color:var(--hop-navy-dark);opacity:.7;animation:hop-label-pulse 2.7s infinite ease-in-out}@keyframes hop-sq-light{0%,to{opacity:.25;transform:scale(1)}11%,22%{opacity:1;transform:scale(1.15)}}@keyframes hop-label-pulse{0%,to{opacity:.7}50%{opacity:.35}}.step-heading{font-size:22px;font-weight:700;margin:0 0 4px;color:var(--hop-navy-dark)}.step-subheading{font-size:16px;font-weight:700;margin:4px 0 6px;color:var(--hop-navy-dark)}.step-text{font-size:14px;line-height:1.5;margin:0 0 8px}.step-save-row{display:flex;align-items:center;gap:10px;margin:4px 0 8px}.checkbox-label{display:flex;align-items:baseline;gap:8px;padding:4px 0;font-size:14px;line-height:1.5;cursor:pointer}.checkbox-label input[type=checkbox]{flex-shrink:0;margin-top:3px;accent-color:var(--hop-blue)}.checkbox-desc{color:var(--hop-muted);font-size:13px}.methodology-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:14px}.methodology-col{background:var(--hop-bg);border:1px solid var(--hop-border);border-radius:var(--hop-radius-md);padding:18px}.methodology-heading{font-size:15px;font-weight:700;margin:0 0 10px;color:var(--hop-navy)}.methodology-list{font-size:13px;line-height:1.7;padding-left:18px;margin:0 0 14px}.methodology-list li{margin-bottom:4px}.methodology-col--recommended{border-color:var(--hop-blue);box-shadow:0 0 0 1px var(--hop-blue)}.methodology-badge{display:inline-block;margin-left:8px;padding:2px 8px;font-size:11px;font-weight:600;color:#fff;background:var(--hop-blue);border-radius:10px;vertical-align:middle;letter-spacing:.02em}.methodology-confirmed{display:flex;align-items:center;padding:10px 16px;background:var(--hop-success-bg);border:1px solid rgba(30,39,64,.25);border-radius:var(--hop-radius-sm);font-size:14px;color:var(--hop-green-dark)}@media (max-width: 700px){.methodology-grid{grid-template-columns:1fr}}@media (max-width: 840px){.hop-content{padding:8px 12px 20px}.hop-header{flex-direction:column;gap:8px;padding:.75rem 1rem}.hop-header__right{justify-content:center;flex-wrap:wrap}.step-progress__dot{width:28px;height:28px;font-size:11px}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.text-navy{color:var(--hop-navy)}.text-green{color:var(--hop-green)}.text-muted{color:var(--hop-muted)}.text-error{color:var(--hop-error)}.login-page{min-height:100vh;display:flex;flex-direction:column;background:var(--hop-white)}.login-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2.5rem;border-bottom:1px solid var(--hop-border)}.login-header__left{display:flex;align-items:center;gap:.75rem}.login-header-logo{height:60px;width:360px;object-fit:contain;object-position:left center}.login-header-brand{font-size:.95rem;font-weight:700;letter-spacing:.04em;color:var(--hop-ink)}.login-hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem 6rem}.login-hero__gradient{font-size:clamp(2.4rem,5vw,3.8rem);font-weight:700;letter-spacing:-.025em;margin:0;background:linear-gradient(135deg,var(--hop-navy) 0%,var(--hop-green) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.15}.login-hero__rotating{font-size:clamp(2.4rem,5vw,3.8rem);font-weight:700;letter-spacing:-.025em;color:var(--hop-ink);margin:0;line-height:1.15;transition:opacity .35s ease,transform .35s ease}.login-hero__rotating.fade-in{opacity:1;transform:translateY(0)}.login-hero__rotating.fade-out{opacity:0;transform:translateY(8px)}.login-hero__desc{max-width:600px;font-size:1.05rem;line-height:1.7;color:var(--hop-ink-secondary);margin:2rem 0 2.5rem}.login-hero__hopscotch{margin:0 0 1.8rem;animation:heroGridFadeIn 1s ease-out .2s both}.hop-grid-hero{filter:drop-shadow(0 4px 16px rgba(30,39,64,.12))}@keyframes heroGridFadeIn{0%{opacity:0;transform:translateY(16px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.login-hero__actions{display:flex;flex-direction:column;align-items:stretch;gap:.75rem;width:100%;max-width:340px}.login-btn-filled{padding:.9rem 2.2rem;font-size:1rem;font-weight:600;border-radius:var(--hop-radius-pill);background:var(--hop-navy);color:var(--hop-white);border:none;cursor:pointer;transition:background .15s,box-shadow .15s;text-align:center}.login-btn-filled:hover{background:var(--hop-navy-dark);box-shadow:0 4px 14px #1e27404d}.login-btn-outline{padding:.9rem 2.2rem;font-size:1rem;font-weight:600;border-radius:var(--hop-radius-pill);background:transparent;color:var(--hop-ink);border:1.5px solid var(--hop-border);cursor:pointer;transition:border-color .15s,color .15s,box-shadow .15s;text-align:center}.login-btn-outline:hover{border-color:var(--hop-blue);color:var(--hop-blue);box-shadow:0 2px 8px #1e27401a}.login-hero__divider{display:flex;align-items:center;gap:.75rem;margin:.25rem 0}.login-hero__divider:before,.login-hero__divider:after{content:"";flex:1;height:1px;background:var(--hop-border)}.login-hero__divider span{font-size:.8rem;font-weight:500;color:var(--hop-muted);text-transform:lowercase;letter-spacing:.02em}.login-split{display:flex;min-height:100vh}.login-split__left{flex:1;display:flex;flex-direction:column;align-items:center;padding:2.5rem 4rem;background:var(--hop-white)}.login-split__back{background:none;border:none;color:var(--hop-muted);font-size:.9rem;cursor:pointer;padding:0;margin-bottom:2rem;font-family:inherit;transition:color .15s;align-self:flex-start}.login-split__back:hover{color:var(--hop-blue)}.login-split__form-area{flex:1;display:flex;flex-direction:column;justify-content:center;width:100%;max-width:400px}.login-split__title{font-size:1.75rem;font-weight:700;color:var(--hop-ink);margin:0 0 .5rem}.login-split__subtitle{font-size:.9rem;color:var(--hop-muted);margin:0 0 2.5rem}.login-split__form{display:flex;flex-direction:column;gap:1.5rem}.login-field__label{display:block;font-size:.8rem;font-weight:500;color:var(--hop-blue);margin-bottom:.4rem;letter-spacing:.01em}.login-field__input{width:100%;padding:.65rem 0;font-size:.95rem;border:none;border-bottom:1.5px solid var(--hop-border);background:transparent;color:var(--hop-ink);font-family:inherit;transition:border-color .2s;outline:none;box-sizing:border-box}.login-field__input::placeholder{color:var(--hop-placeholder)}.login-field__input:focus{border-bottom-color:var(--hop-blue)}.login-field__password-wrap{position:relative;display:flex;align-items:center}.login-field__password-wrap .login-field__input{padding-right:2.4rem}.login-field__eye{position:absolute;right:0;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:.3rem;color:var(--hop-muted);display:flex;align-items:center;transition:color .15s}.login-field__eye:hover{color:var(--hop-ink)}.login-split__submit{margin-top:1rem;width:100%;padding:.9rem;font-size:1rem;font-weight:600;font-family:inherit;border:none;border-radius:var(--hop-radius-pill);background:var(--hop-ink);color:var(--hop-white);cursor:pointer;transition:background .15s,box-shadow .15s}.login-split__submit:hover{background:var(--hop-blue-dark);box-shadow:0 4px 16px #0003}.login-split__submit:disabled{opacity:.6;cursor:not-allowed}.login-split__toggle{margin-top:1.5rem;font-size:.85rem;color:var(--hop-muted)}.login-split__right{width:45%;display:flex;flex-direction:column;align-items:center;background:var(--hop-panel-dark);color:#fff}.login-split__center{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem}.login-split__logo{width:220px}.login-split__hopscotch{animation:heroGridFadeIn 1s ease-out .4s both;filter:drop-shadow(0 4px 20px rgba(255,255,255,.08))}.login-split__affiliations{display:flex;align-items:center;gap:1.5rem;padding-bottom:2rem}.login-split__affiliation{height:40px;width:auto;opacity:.85;transition:opacity .2s}.login-split__affiliation:hover{opacity:1}.login-split__affiliation--ksu{height:36px}.login-split__brand{font-size:1.1rem;font-weight:700;letter-spacing:.08em;opacity:.9}@media (max-width: 768px){.login-split{flex-direction:column}.login-split__right{width:100%;min-height:180px;order:-1}.login-split__left{padding:2rem}}.login-btn-school{padding:.8rem 2.2rem;font-size:.92rem;font-weight:500;font-family:inherit;border-radius:var(--hop-radius-pill);background:#1e274008;color:var(--hop-ink-secondary);border:1.5px solid var(--hop-border);cursor:pointer;transition:border-color .15s,color .15s,background .15s;text-align:center;width:100%}.login-btn-school:hover{border-color:var(--hop-blue);color:var(--hop-blue);background:#2b5ea70a}.login-account-type{margin-bottom:.5rem}.login-account-type__grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-top:.35rem}.login-account-type__btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.65rem .5rem;border:1.5px solid var(--hop-border);border-radius:var(--hop-radius);background:transparent;color:var(--hop-muted);font-family:inherit;font-size:.8rem;font-weight:600;cursor:pointer;transition:none}.login-account-type__btn--active{border-color:var(--hop-blue);background:#2b5ea714;color:var(--hop-blue)}.login-account-type__btn:not(.login-account-type__btn--active):hover{border-color:var(--hop-muted);background:#1e274008;color:var(--hop-ink)}.login-account-type__icon{font-size:1.3rem;line-height:1}.login-account-type__label{line-height:1.2;text-align:center}.hop-user{display:flex;align-items:center;gap:10px}.hop-user__avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--hop-navy),var(--hop-green));color:#fff;font-size:.85rem;font-weight:700;display:flex;align-items:center;justify-content:center;letter-spacing:.02em;box-shadow:0 2px 8px #1e274040}.hop-user__name{font-size:.9rem;color:var(--hop-ink);font-weight:600;letter-spacing:-.01em}.td{min-height:100vh;background:var(--hop-bg);display:flex;flex-direction:column}.td-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 2rem;background:var(--hop-surface);border-bottom:1px solid var(--hop-border)}.td-header__left{display:flex;align-items:center;gap:1rem}.td-header__logo{height:44px;width:auto}.td-header__right{display:flex;align-items:center;gap:.75rem}.td-header__user{display:flex;align-items:center;gap:.5rem}.td-header__avatar{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--hop-blue);color:#fff;font-size:.85rem;font-weight:700;flex-shrink:0}.td-header__name{font-size:.85rem;font-weight:600;color:var(--hop-ink)}.td-header__signout{padding:.4rem .9rem;font-size:.8rem;font-weight:600;font-family:inherit;border:1.5px solid var(--hop-border);border-radius:var(--hop-radius-pill);background:transparent;color:var(--hop-ink-secondary);cursor:pointer;transition:all var(--hop-ease)}.td-header__signout:hover{border-color:var(--hop-red, #D94040);color:var(--hop-red, #D94040);background:#d940400f}.td-nav{background:var(--hop-surface);border-bottom:1px solid var(--hop-border)}.td-nav__inner{display:flex;gap:0;padding:0 2rem;max-width:1200px;margin:0 auto}.td-nav__tab{padding:.75rem 1.5rem;font-size:.88rem;font-weight:600;font-family:inherit;border:none;background:transparent;color:var(--hop-muted);cursor:pointer;border-bottom:2.5px solid transparent;transition:color .15s,border-color .15s;white-space:nowrap}.td-nav__tab:hover{color:var(--hop-ink)}.td-nav__tab--active{color:var(--hop-blue);border-bottom-color:var(--hop-blue)}.td-content{flex:1;padding:2rem;max-width:1200px;width:100%;margin:0 auto;box-sizing:border-box}.td-card{background:var(--hop-surface);border:1px solid var(--hop-border);border-radius:var(--hop-radius-lg);padding:1.75rem;box-shadow:var(--hop-shadow-sm)}.td-card__header{margin-bottom:1.25rem}.td-card__title{font-size:1.1rem;font-weight:700;color:var(--hop-ink);margin:0 0 .3rem}.td-card__desc{font-size:.85rem;color:var(--hop-muted);margin:0;line-height:1.5}.td-form{display:flex;flex-direction:column;gap:1rem}.td-form__grid{display:flex;gap:1rem;flex-wrap:wrap}.td-form__group{display:flex;flex-direction:column;gap:.3rem}.td-form__group--grow{flex:1;min-width:180px}.td-form__group--narrow{flex:0 0 100px;min-width:100px}.td-form__label{font-size:.78rem;font-weight:600;color:var(--hop-ink-secondary);text-transform:uppercase;letter-spacing:.03em}.td-form__input{padding:.55rem .75rem;border:1.5px solid var(--hop-border);border-radius:var(--hop-radius-md);font-family:inherit;font-size:.9rem;color:var(--hop-ink);background:var(--hop-bg);transition:border-color .15s;width:100%;box-sizing:border-box}.td-form__input:focus{outline:none;border-color:var(--hop-blue);box-shadow:0 0 0 3px #2b5ea71a}.td-btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;font-family:inherit;font-weight:600;border-radius:var(--hop-radius-pill);cursor:pointer;transition:all var(--hop-ease);white-space:nowrap}.td-btn--primary{padding:.6rem 1.6rem;font-size:.88rem;background:var(--hop-blue);color:#fff;border:none}.td-btn--primary:hover{background:var(--hop-navy-dark);box-shadow:var(--hop-shadow-md)}.td-btn--primary:disabled{opacity:.5;cursor:not-allowed}.td-btn--outline{background:transparent;border:1.5px solid var(--hop-border);color:var(--hop-ink-secondary)}.td-btn--outline:hover{border-color:var(--hop-blue);color:var(--hop-blue);background:#2b5ea70a}.td-btn--sm{padding:.35rem .9rem;font-size:.8rem}.td-alert{padding:.65rem 1rem;border-radius:var(--hop-radius-md);font-size:.85rem;font-weight:500}.td-alert--error{background:#d9404014;color:var(--hop-red, #D94040);border:1px solid rgba(217,64,64,.2)}.td-result{margin-top:1.5rem;padding:1.25rem;background:var(--hop-success-bg);border:1px solid rgba(109,179,63,.25);border-radius:var(--hop-radius-md)}.td-result__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.td-result__badge{display:inline-block;padding:2px 10px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;background:var(--hop-green, #6db33f);color:#fff;border-radius:999px}.td-result__dismiss{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--hop-green-dark);cursor:pointer;font-size:1.1rem;border-radius:50%;transition:background .15s}.td-result__dismiss:hover{background:#0000000f}.td-kv-row{display:flex;gap:2rem;flex-wrap:wrap;margin-bottom:.75rem}.td-kv{display:flex;flex-direction:column;gap:2px}.td-kv__label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--hop-muted)}.td-kv__value{font-size:.92rem;font-weight:600;font-family:Geist Mono,monospace;color:var(--hop-ink)}.td-roster{display:flex;flex-wrap:wrap;gap:6px}.td-roster__chip{display:inline-block;padding:4px 10px;font-size:.78rem;font-family:Geist Mono,monospace;background:var(--hop-neutral-bg);border:1px solid var(--hop-border);border-radius:var(--hop-radius-sm);color:var(--hop-ink)}.td-section{margin-top:2rem}.td-section__title{display:flex;align-items:center;gap:.5rem;font-size:1.05rem;font-weight:700;color:var(--hop-ink);margin:0 0 1rem}.td-section__count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;font-size:.72rem;font-weight:700;background:var(--hop-blue);color:#fff;border-radius:999px}.td-empty{text-align:center;color:var(--hop-muted);padding:3rem 0;font-size:.9rem}.td-empty p{margin:0}.td-muted{color:var(--hop-muted);font-size:.9rem}.td-class-list{display:flex;flex-direction:column;gap:8px}.td-class{background:var(--hop-surface);border:1px solid var(--hop-border);border-radius:var(--hop-radius-md);overflow:hidden;transition:box-shadow var(--hop-ease)}.td-class:hover{box-shadow:var(--hop-shadow-sm)}.td-class--open{box-shadow:var(--hop-shadow-md)}.td-class__header{display:flex;align-items:center;width:100%;padding:.9rem 1.25rem;background:transparent;border:none;cursor:pointer;font-family:inherit;text-align:left;color:var(--hop-ink);gap:1rem}.td-class__title{font-size:.95rem;font-weight:700;color:var(--hop-ink);flex-shrink:0}.td-class__meta{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.td-class__tag{display:inline-block;padding:2px 8px;font-size:.72rem;font-weight:700;font-family:Geist Mono,monospace;background:#2b5ea714;color:var(--hop-blue);border-radius:var(--hop-radius-sm);letter-spacing:.02em;white-space:nowrap}.td-class__stat{font-size:.8rem;color:var(--hop-muted);white-space:nowrap}.td-class__date{font-size:.78rem;color:var(--hop-muted);opacity:.7;white-space:nowrap;margin-left:auto}.td-class__chevron{font-size:.7rem;color:var(--hop-muted);transition:transform .2s;flex-shrink:0}.td-class__chevron--open{transform:rotate(180deg)}.td-class__body{padding:1rem 1.25rem 1.25rem;border-top:1px solid var(--hop-border-light)}.td-class__actions{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--hop-border-light)}.td-table-wrap{overflow-x:auto;border:1px solid var(--hop-border);border-radius:var(--hop-radius-md);background:var(--hop-surface)}.td-table{width:100%;border-collapse:collapse;font-size:.88rem}.td-table th{text-align:left;padding:.7rem 1rem;background:var(--hop-bg);border-bottom:1px solid var(--hop-border);font-weight:600;color:var(--hop-ink-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.td-table td{padding:.7rem 1rem;border-bottom:1px solid var(--hop-border-light);color:var(--hop-ink)}.td-table tr:last-child td{border-bottom:none}.td-table tr:hover td{background:var(--hop-bg)}.td-table__name{font-weight:600}.td-table__mono{font-family:Geist Mono,monospace;font-size:.82rem}.td-table__cap{text-transform:capitalize}.td-table__muted{color:var(--hop-muted);font-size:.82rem}.td-table__row--inactive{opacity:.55}.td-table__not-started{display:inline-block;padding:2px 8px;font-size:.75rem;font-weight:600;background:var(--hop-border);color:var(--hop-muted);border-radius:var(--hop-radius-sm);white-space:nowrap}.td-step-badge{display:inline-block;padding:2px 8px;font-size:.75rem;font-weight:600;background:#2b5ea714;color:var(--hop-blue);border-radius:var(--hop-radius-sm);white-space:nowrap}.td-dots{display:flex;align-items:center;gap:3px}.td-dots__dot{width:10px;height:10px;border-radius:50%;background:var(--hop-border);flex-shrink:0;transition:background .15s}.td-dots__dot--done{background:var(--hop-green)}.td-dots__dot--active{box-shadow:0 0 0 2px #fff,0 0 0 3.5px var(--hop-blue)}.td-dots__count{font-size:.7rem;color:var(--hop-muted);margin-left:4px;font-weight:600;white-space:nowrap}.td-stats{display:flex;gap:16px;max-width:1100px;margin:0 auto;padding:20px 24px 0}.td-stats__card{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:18px 16px;border-radius:var(--hop-radius-lg);background:var(--hop-surface);border:1px solid var(--hop-border);box-shadow:var(--hop-shadow-sm)}.td-stats__number{font-size:1.8rem;font-weight:700;color:var(--hop-blue);line-height:1}.td-stats__label{font-size:.78rem;font-weight:600;color:var(--hop-muted);text-transform:uppercase;letter-spacing:.04em}.td-table__student{display:flex;align-items:center;gap:10px}.td-table__student-avatar{width:32px;height:32px;border-radius:50%;background:var(--hop-blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;flex-shrink:0}.td-progress-cell{display:flex;flex-direction:column;gap:4px;min-width:140px}.td-progress-bar{height:6px;border-radius:3px;background:var(--hop-border);overflow:hidden}.td-progress-bar__fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--hop-blue),var(--hop-green));transition:width .3s ease}.td-progress-dots{display:flex;align-items:center;gap:3px}.td-progress-pct{font-size:.7rem;color:var(--hop-muted);font-weight:600;margin-left:4px;white-space:nowrap}.td-step-badge{display:inline-block;padding:3px 8px;border-radius:var(--hop-radius);background:var(--hop-surface);border:1px solid var(--hop-border);border-left:3px solid var(--hop-blue);font-size:.75rem;font-weight:600;color:var(--hop-ink);white-space:nowrap}.td-progress__filter{display:flex;align-items:center;gap:10px;margin-bottom:16px}.td-progress__filter-label{font-size:.82rem;font-weight:600;color:var(--hop-muted)}.td-progress__select{padding:6px 12px;border-radius:var(--hop-radius);border:1.5px solid var(--hop-border);background:var(--hop-surface);font-family:inherit;font-size:.82rem;color:var(--hop-ink);cursor:pointer}.td-progress__select:focus{outline:none;border-color:var(--hop-blue)}.td-charts{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.td-chart-card{padding:18px 20px;border-radius:var(--hop-radius-lg);background:var(--hop-surface);border:1px solid var(--hop-border);box-shadow:var(--hop-shadow-sm)}.td-chart-card--wide{grid-column:1 / -1}.td-chart-card__title{margin:0 0 2px;font-size:.9rem;font-weight:700;color:var(--hop-ink)}.td-chart-card__desc{margin:0 0 12px;font-size:.75rem;color:var(--hop-muted)}@media (max-width: 768px){.td-header{flex-direction:column;gap:8px;padding:.75rem 1rem}.td-content{padding:1rem}.td-nav__inner{padding:0 1rem}.td-form__grid{flex-direction:column}.td-form__group--narrow{flex:1}.td-kv-row{gap:1rem}.td-class__header{flex-wrap:wrap}.td-class__meta{flex-wrap:wrap;gap:.5rem}.td-class__date{margin-left:0}.td-charts{grid-template-columns:1fr}.td-stats{flex-direction:column;gap:10px}}@keyframes cardBreathGlow{0%,to{box-shadow:0 0 0 3px #fff,0 0 0 6px var(--card-color),0 8px 24px #0003}50%{box-shadow:0 0 0 3px #fff,0 0 0 8px var(--card-color),0 8px 28px #00000040,0 0 20px #1e274026}}@keyframes activeWobble{0%,to{transform:translateY(-2px) scale(1.05) rotate(0)}20%{transform:translateY(-2px) scale(1.05) rotate(-3deg)}40%{transform:translateY(-2px) scale(1.05) rotate(3deg)}60%{transform:translateY(-2px) scale(1.05) rotate(-2deg)}80%{transform:translateY(-2px) scale(1.05) rotate(1deg)}}@keyframes activeShimmer{0%{transform:translate(-100%) rotate(25deg);opacity:0}15%{opacity:1}50%{transform:translate(200%) rotate(25deg);opacity:0}to{transform:translate(200%) rotate(25deg);opacity:0}}@keyframes shimmerSweep{0%{transform:translate(-100%) rotate(25deg)}to{transform:translate(200%) rotate(25deg)}}.hop-step-card--completed:after{content:"✓";position:absolute;top:8px;right:8px;width:22px;height:22px;border-radius:50%;background:var(--hop-green);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #6db33f59;animation:checkBadgeIn .35s cubic-bezier(.32,1.28,.48,1) both}@keyframes checkBadgeIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}@keyframes dotPulseRing{0%,to{box-shadow:0 0 0 4px #1e27402e}50%{box-shadow:0 0 0 8px #1e274014}}@keyframes lineShimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes floatUpDown{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes floatLeftRight{0%,to{transform:translate(0)}50%{transform:translate(10px)}}@keyframes borderGradientSlide{0%{background-position:0% 50%}to{background-position:200% 50%}}@keyframes gentleFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}:root[data-theme=dark] .hop-step-card--active{box-shadow:0 0 0 3px #ffffff26,0 0 0 6px var(--card-color),0 0 28px color-mix(in srgb,var(--card-color) 30%,transparent),0 8px 28px #00000059}:root[data-theme=dark] .hop-step-card{box-shadow:0 4px 12px #0000004d,inset 0 1px #ffffff14}:root[data-theme=dark] .hop-step-card:hover{box-shadow:0 8px 24px #0006,inset 0 1px #ffffff1f}:root[data-theme=dark] .hop-diagram{background:radial-gradient(ellipse 80% 60% at 30% 40%,rgba(91,140,200,.06) 0%,transparent 70%),radial-gradient(ellipse 60% 80% at 70% 60%,rgba(123,199,79,.06) 0%,transparent 70%)}:root[data-theme=dark] .hop-diagram:before,:root[data-theme=dark] .hop-diagram:after{display:none}:root[data-theme=dark] .panel-tabs--pill .panel-tabs__btn{border-color:#ffffff26}:root[data-theme=dark] .panel-tabs--pill .panel-tabs__btn:hover{background:#ffffff0f;color:var(--hop-ink)}:root[data-theme=dark] .panel-tabs--pill .panel-tabs__btn--active{background:var(--hop-blue);border-color:var(--hop-blue);color:#fff}:root[data-theme=dark] .panel-tabs--pill .panel-tabs__btn--active:after{display:none}:root[data-theme=dark] .panel-tabs--pill .panel-tabs__btn--active:hover{background:var(--hop-blue-dark);box-shadow:0 2px 8px #0000004d;color:#fff}:root[data-theme=dark] .chat-step-group__header{background:#ffffff08}:root[data-theme=dark] .chat-step-group__header:hover{background:#ffffff12}:root[data-theme=dark] .chat-step-group__header--open{background:#ffffff0d}:root[data-theme=dark] .chat-step-group__body{border-left-color:color-mix(in srgb,var(--step-color, transparent) 15%,transparent)}:root[data-theme=dark] .chat-bubble--assistant{background:#ffffff0f;border-color:#ffffff14}:root[data-theme=dark] .chat-bubble--assistant:hover{border-color:#ffffff24;box-shadow:0 2px 8px #00000026}:root[data-theme=dark] .chat-bubble--user{background:linear-gradient(135deg,#3b6db8,#2b4c7e);box-shadow:0 2px 10px #00000059}:root[data-theme=dark] .chat-bubble--user:hover{box-shadow:0 4px 16px #00000073}:root[data-theme=dark] .chat-input{border-top-color:#ffffff0f}:root[data-theme=dark] .chat-input textarea{background:#ffffff0f;border-color:#ffffff14;color:var(--hop-ink)}:root[data-theme=dark] .chat-input textarea:focus{background:#ffffff1a;border-color:var(--hop-green-dark);box-shadow:0 0 0 2px #6db33f26}:root[data-theme=dark] .chat-empty{background:#6db33f0f;border-color:#6db33f1f}:root[data-theme=dark] .chat-body:hover::-webkit-scrollbar-thumb{background:#ffffff4d}:root[data-theme=dark] .chat-body::-webkit-scrollbar-thumb{background:#ffffff26}:root[data-theme=dark] .chat-ripple{background:radial-gradient(circle,rgba(107,143,192,.25) 0%,rgba(255,255,255,.08) 50%,transparent 70%)}:root[data-theme=dark] .hop-header{background:#1e2128c7;border-bottom-color:#ffffff0f;box-shadow:0 1px 3px #0000004d,inset 0 -1px #ffffff0a}:root[data-theme=dark] .hop-download__menu{background:#1e2128e0;border-color:#ffffff14;box-shadow:0 8px 32px #00000073}:root[data-theme=dark] .pin-layout__main{background:#1e21288c;border-color:#ffffff0f;box-shadow:0 4px 24px #00000026,inset 0 1px #ffffff0a,inset 0 0 0 1px #ffffff08}:root[data-theme=dark] .step-progress__dot{box-shadow:inset 0 1px 3px #0003}:root[data-theme=dark] .step-progress__dot--active{box-shadow:0 0 0 4px #4a6fa52e,0 3px 10px #4a6fa540}:root[data-theme=dark] .step-progress__dot--completed{box-shadow:0 2px 8px #7bc74f4d}:root[data-theme=dark] .step-progress__dot--active.step-progress__dot--completed{box-shadow:0 0 0 4px #7bc74f2e,0 3px 10px #7bc74f4d}:root[data-theme=dark] .step-progress__line--completed{box-shadow:0 0 6px #7bc74f40}:root[data-theme=dark] .login-header-logo{width:305px}:root[data-theme=dark] .btn--primary:hover,:root[data-theme=dark] .btn.dark:hover{box-shadow:0 4px 14px #0006}.theme-toggle{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;border:1.5px solid var(--hop-border);background:transparent;color:var(--hop-ink-secondary);cursor:pointer;font-size:16px;transition:border-color .15s,color .15s,background .15s;padding:0;line-height:1}.theme-toggle:hover{border-color:var(--hop-blue);color:var(--hop-blue);background:#1e27400a}:root[data-theme=dark] .theme-toggle:hover{background:#ffffff0f}.hop-tour-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;border:1.5px solid var(--hop-border);background:transparent;color:var(--hop-ink-secondary);cursor:pointer;font-size:15px;font-weight:700;transition:border-color .15s,color .15s,background .15s;padding:0;line-height:1}.hop-tour-btn:hover{border-color:#6aa84f;color:#6aa84f;background:#6aa84f14}:root[data-theme=dark] .hop-tour-btn:hover{background:#6aa84f26}.hop-wrap--touring .hop-header{z-index:1}.__floater.__floater__open{z-index:10001!important}.tour-tooltip{background:var(--hop-surface);border-radius:16px;width:380px;max-width:92vw;overflow:hidden;box-shadow:0 12px 48px #00000026,0 2px 8px #00000014;border:1px solid var(--hop-border);animation:tourFadeIn .25s ease-out}@keyframes tourFadeIn{0%{opacity:0;transform:translateY(6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.tour-tooltip__progress-track{height:4px;background:var(--hop-border)}.tour-tooltip__progress-fill{height:100%;background:linear-gradient(90deg,#2b4c7e,#6aa84f);border-radius:0 4px 4px 0;transition:width .4s ease}.tour-tooltip__body{padding:20px 24px 18px}.tour-tooltip__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.tour-tooltip__icon{font-size:28px;line-height:1}.tour-tooltip__counter{font-size:12px;font-weight:600;color:var(--hop-muted);background:var(--hop-bg);padding:3px 10px;border-radius:20px;letter-spacing:.3px}.tour-tooltip__title{margin:0 0 6px;font-size:18px;font-weight:700;color:var(--hop-ink);letter-spacing:-.2px}.tour-tooltip__content{margin:0 0 18px;font-size:14px;line-height:1.55;color:var(--hop-ink-secondary)}.tour-tooltip__footer{display:flex;align-items:center;justify-content:space-between;gap:8px}.tour-tooltip__skip{background:none;border:none;color:var(--hop-muted);font-size:13px;cursor:pointer;padding:6px 2px;opacity:.7;transition:opacity .15s}.tour-tooltip__skip:hover{opacity:1;text-decoration:underline}.tour-tooltip__nav{display:flex;gap:8px}.tour-tooltip__back{background:var(--hop-bg);border:1px solid var(--hop-border);color:var(--hop-ink-secondary);font-size:13px;font-weight:600;padding:7px 16px;border-radius:8px;cursor:pointer;transition:border-color .15s,background .15s}.tour-tooltip__back:hover{border-color:var(--hop-navy);background:var(--hop-surface)}.tour-tooltip__next{background:linear-gradient(135deg,#2b4c7e,#3d6098);border:none;color:#fff;font-size:13px;font-weight:600;padding:7px 20px;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:6px;transition:filter .15s,transform .1s}.tour-tooltip__next:hover{filter:brightness(1.12);transform:translateY(-1px)}.tour-tooltip__next:active{transform:translateY(0)}.tour-tooltip__arrow{font-size:15px;transition:transform .2s}.tour-tooltip__next:hover .tour-tooltip__arrow{transform:translate(2px)}:root[data-theme=dark] .tour-tooltip{background:#1e2128;border-color:#2d3340;box-shadow:0 12px 48px #00000073,0 2px 8px #0000004d}:root[data-theme=dark] .tour-tooltip__progress-track{background:#2d3340}:root[data-theme=dark] .tour-tooltip__counter{background:#252a34;color:#8896a6}:root[data-theme=dark] .tour-tooltip__back{background:#252a34;border-color:#2d3340;color:#b0bac5}:root[data-theme=dark] .tour-tooltip__back:hover{border-color:#4a6fa5;background:#2d3340}:root[data-theme=dark] .tour-tooltip__next{background:linear-gradient(135deg,#3d6098,#4a7ab8)}:root[data-theme=dark] .tour-tooltip__skip{color:#6b7a8a}[data-theme=dark] .__floater__arrow polygon{fill:#1e2128!important}@media (prefers-reduced-motion: reduce){.hop-step-card--active{animation:none}.hop-step-card--active:not(.hop-step-card--completed):after{animation:none;display:none}.hop-step-card--completed:after{animation:none}.step-progress__dot--active{animation:none}.step-progress__line--completed{animation:none;background:var(--hop-green)}.hop-diagram:before,.hop-diagram:after{animation:none;display:none}.chat-head:after{animation:none}.hop-logo{animation:none}.hop-step-card,.step-details .hop-card,.embed-card{animation-duration:.01s}.hop-grid-loader{width:56px;height:23px}}.session-overlay{position:fixed;inset:0;background:#0000004d;z-index:100;animation:sessionFadeIn .2s ease-out}@keyframes sessionFadeIn{0%{opacity:0}to{opacity:1}}.session-panel{position:fixed;top:0;left:0;width:360px;max-width:90vw;height:100vh;background:var(--hop-surface);border-right:1px solid var(--hop-border);box-shadow:4px 0 24px #0000001f;z-index:101;display:flex;flex-direction:column;animation:slideInLeft .25s ease-out;overflow:hidden}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}.session-panel__header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem .75rem;border-bottom:1px solid var(--hop-border)}.session-panel__title{font-size:1.1rem;font-weight:700;color:var(--hop-ink);margin:0}.session-panel__close{width:30px;height:30px;border-radius:50%;border:1px solid var(--hop-border);background:transparent;color:var(--hop-muted);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all var(--hop-ease)}.session-panel__close:hover{border-color:var(--hop-blue);color:var(--hop-blue)}.session-panel__new{margin:1rem 1.5rem;width:calc(100% - 3rem);text-align:center;padding:.65rem 1.2rem;font-size:.9rem;border-radius:var(--hop-radius-pill)}.session-panel__list{flex:1;overflow-y:auto;padding:0 1.5rem 1.5rem;display:flex;flex-direction:column;gap:8px}.session-panel__empty{text-align:center;color:var(--hop-muted);font-size:.85rem;padding:2rem 0}.session-card{display:flex;flex-direction:column;gap:6px;padding:14px 16px;border:1px solid var(--hop-border);border-radius:var(--hop-radius-md);background:var(--hop-surface);cursor:pointer;text-align:left;font-family:inherit;transition:all var(--hop-ease);width:100%;position:relative}.session-card:hover{border-color:var(--hop-blue-light);box-shadow:var(--hop-shadow-md);transform:translateY(-1px)}.session-card--active{border-left:4px solid var(--hop-green);background:var(--hop-success-bg);border-color:var(--hop-green)}.session-card__topic{font-size:.9rem;font-weight:600;color:var(--hop-ink);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:60px}.session-card__meta{display:flex;justify-content:space-between;font-size:.78rem;color:var(--hop-muted)}.session-card__path{text-transform:capitalize;font-weight:500}.session-card__path--none{font-style:italic;opacity:.7}.session-card__progress{display:flex;align-items:center;gap:4px;margin-top:2px}.session-card__dot{width:8px;height:8px;border-radius:50%;background:var(--hop-border);flex-shrink:0}.session-card__dot--done{background:var(--hop-green)}.session-card__step-count{font-size:.7rem;color:var(--hop-muted);margin-left:4px;font-weight:600}.session-card__current-badge{position:absolute;top:12px;right:12px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--hop-green-dark);background:var(--hop-success-bg);padding:2px 8px;border-radius:999px;border:1px solid var(--hop-green)}.session-history-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1.5px solid var(--hop-border);background:transparent;color:var(--hop-ink-secondary);cursor:pointer;transition:all var(--hop-ease);padding:0;margin-left:12px}.session-history-btn:hover{border-color:var(--hop-blue);color:var(--hop-blue);background:#1e27400a}.session-history-btn[data-tooltip]{position:relative}.session-history-btn[data-tooltip]:after{content:attr(data-tooltip);position:absolute;top:calc(100% + 6px);left:50%;transform:translate(-50%);padding:5px 10px;border-radius:6px;background:#1e2740;color:#fff;font-size:11px;font-weight:500;white-space:nowrap;pointer-events:none;opacity:0;visibility:hidden;z-index:100}.session-history-btn[data-tooltip]:hover:after{opacity:1;visibility:visible}:root[data-theme=dark] .session-overlay{background:#00000080}:root[data-theme=dark] .session-panel{box-shadow:4px 0 24px #0006}:root[data-theme=dark] .session-history-btn:hover{background:#ffffff0f}.cf-overlay{position:fixed;inset:0;z-index:200;background:#e8e8e8;display:flex;flex-direction:column;overflow:auto}.cf-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1.5rem;background:#fff;border-bottom:1px solid #ddd;flex-shrink:0}.cf-toolbar__left,.cf-toolbar__right{display:flex;align-items:center;gap:.75rem}.cf-toolbar__title{font-size:.95rem;font-weight:700;color:#1e2740}.cf-toolbar__hint{font-size:.78rem;color:#999;font-style:italic}.cf-toolbar__btn{padding:.4rem 1rem;font-size:.85rem;font-weight:600;font-family:inherit;border:1.5px solid #ccc;border-radius:999px;background:#fff;color:#555;cursor:pointer;transition:all .15s}.cf-toolbar__btn:hover{border-color:#2b5ea7;color:#2b5ea7}.cf-toolbar__btn--primary{background:#2b5ea7;border-color:#2b5ea7;color:#fff}.cf-toolbar__btn--primary:hover{background:#1e4a8a}.cf-toolbar__center{display:flex;align-items:center}.cf-toolbar__template-toggle{display:flex;border:1.5px solid #ccc;border-radius:999px;overflow:hidden}.cf-toolbar__template-btn{padding:.35rem 1rem;font-size:.82rem;font-weight:600;font-family:inherit;border:none;background:#fff;color:#777;cursor:pointer;transition:all .15s}.cf-toolbar__template-btn+.cf-toolbar__template-btn{border-left:1.5px solid #ccc}.cf-toolbar__template-btn:hover{color:#2b5ea7;background:#f0f4fa}.cf-toolbar__template-btn--active{background:#2b5ea7;color:#fff}.cf-toolbar__template-btn--active:hover{background:#1e4a8a;color:#fff}.cf-page{flex:1;display:flex;align-items:center;justify-content:center;padding:1rem}.cf-diagram{position:relative;width:min(1200px,94vw);aspect-ratio:10 / 6.25;background:#fff;border-radius:4px;box-shadow:0 4px 24px #00000026;overflow:hidden;font-size:14px}.cf-editable{display:inline-block;outline:none;border-radius:3px;padding:1px 3px;transition:background .15s;cursor:text;min-width:40px;word-break:break-word}.cf-editable--placeholder{opacity:.5;font-style:italic}.cf-editable:hover{background:#ffffff26}.cf-editable:focus{background:#ffffff40;box-shadow:0 0 0 2px #ffffff4d}.cf-text--light{color:#fff}.cf-text--dark{color:#1e2740}.cf-text--sm{font-size:.78em;line-height:1.4}.cf-text--name{font-weight:700}.cf-text--footer{color:#073763}.cf-label{display:block;font-weight:700;font-size:.85em;margin-bottom:2px;text-shadow:0 1px 2px rgba(0,0,0,.1)}.cf-label--light{color:#fff}.cf-label--dark{color:#1e2740;text-shadow:none}.cf-shapes-svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}.cf-txt{position:absolute;z-index:11;pointer-events:auto;overflow:hidden}.cf-txt--topical-label{left:.4%;top:.5%;width:16%}.cf-txt--topic{width:23%;font-size:.78em;color:#fff}.cf-txt--fw-label{right:.5%;top:.5%;width:19%;text-align:right}.cf-txt--framework{width:23%;font-size:.78em;color:#fff;text-align:right}.cf-txt--gaps{left:39%;top:.5%;width:23%;text-align:center}.cf-txt--topic-center{left:42%;top:42%;width:17%;max-height:22%;text-align:center}.cf-txt--interests{left:.4%;top:41%;width:29%;max-height:24%}.cf-txt--identity{left:1.4%;top:68%;width:31%}.cf-txt--problem{left:71%;top:44%;width:28%;max-height:22%}.cf-txt--design{left:43%;top:65%;width:15%;max-height:22%;text-align:center}.cf-txt--questions{left:70.5%;top:69%;width:28%;text-align:right}.cf-footer{position:absolute;bottom:0;left:0;right:0;height:9%;display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:#fff;z-index:20;font-size:.68em;color:#073763}.cf-footer__left,.cf-footer__right{flex:1}.cf-footer__right{text-align:right}.cf-footer__center{font-weight:700;font-size:1.15em;text-align:center;flex:2}.cf-footer__logo{height:80%;max-height:36px;width:auto;object-fit:contain;margin-left:12px;flex-shrink:0}.cf-footer__grid{height:70%;max-height:28px;width:auto;margin-left:10px;flex-shrink:0}.cf-tile-bar{position:absolute;bottom:0;left:0;right:0;height:8px;z-index:21;display:flex}.cf-tile-bar span{flex:1}.cf-loading-overlay{position:fixed;inset:0;z-index:200;background:#1e274099;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center}.cf-loading-card{background:#fff;border-radius:16px;padding:2.5rem 3rem;text-align:center;box-shadow:0 12px 40px #0003;max-width:400px}.cf-loading-spinner{width:48px;height:48px;border:4px solid #e8e8e8;border-top-color:#2b5ea7;border-radius:50%;margin:0 auto 1.25rem;animation:cf-spin .8s linear infinite}@keyframes cf-spin{to{transform:rotate(360deg)}}.cf-loading-text{font-size:1.1rem;font-weight:700;color:#1e2740;margin:0 0 .5rem}.cf-loading-sub{font-size:.85rem;color:#888;margin:0;line-height:1.4}.cfb-diagram{position:relative;width:min(1200px,96vw);aspect-ratio:10 / 6.5;background:#fff;border-radius:4px;box-shadow:0 4px 24px #00000026;overflow:hidden;font-size:13px;color:#1e2740;display:flex;flex-direction:column}.cfb-text--meta{color:#8b0000;font-weight:600}.cfb-text--name{font-weight:700;color:#073763}.cfb-text--body{font-size:.92em;line-height:1.4}.cfb-header{display:flex;align-items:flex-start;justify-content:space-between;padding:10px 20px 6px}.cfb-header__meta{font-size:.85em;font-weight:700;color:#8b0000;line-height:1.5}.cfb-header__title{font-size:1.2em;font-weight:700;color:#073763;text-align:right}.cfb-content{flex:1;display:flex;padding:0 14px;gap:0;min-height:0}.cfb-sidebar{width:210px;flex-shrink:0;display:flex;flex-direction:column;align-items:stretch;padding-top:6px;margin-right:8px}.cfb-card{border:2px solid #999;border-radius:4px;overflow:hidden;flex:1;display:flex;flex-direction:column}.cfb-card__header{font-weight:700;font-size:.88em;padding:6px 10px;text-align:center;color:#fff}.cfb-card__header--red{background:#c0504d}.cfb-card__header--yellow{background:#c9960c;color:#fff}.cfb-card__body{padding:12px 10px;flex:1;overflow:hidden}.cfb-card--personal .cfb-card__body{background:#f4cccc}.cfb-card--identity .cfb-card__body{background:#f1c232}.cfb-connector-mid{display:flex;align-items:center;flex-shrink:0}.cfb-connector-v{width:2px;height:28px;background:#555;margin-left:50%;flex-shrink:0}.cfb-arrow-right--connector{flex-shrink:0;padding:0 2px;margin-left:auto}.cfb-main{flex:1;display:flex;flex-direction:column;min-height:0}.cfb-lit-banner{background:#0097a7;color:#fff;text-align:center;font-weight:700;font-size:1em;padding:5px 0;letter-spacing:.5px}.cfb-lit-area{display:flex;border:2px solid #0097A7;border-top:none;flex:1;min-height:0}.cfb-col{flex:1;display:flex;flex-direction:column;padding:8px;gap:6px}.cfb-col__heading{font-weight:700;font-size:.92em;text-align:center;padding-bottom:4px;margin-bottom:2px}.cfb-col__item{padding:4px 6px;font-size:.9em}.cfb-col--topics{background:#cfe2f3}.cfb-col--topics .cfb-col__heading{color:#1c4587}.cfb-col--center{display:flex;align-items:center;justify-content:center;background:#d6e4f0;border-left:2px solid #0097A7;border-right:2px solid #0097A7}.cfb-topic-box{width:85%;aspect-ratio:1;max-width:180px;border-radius:16px;background:#2b5ea7;border:3px solid #1C4587;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:14px;overflow:hidden}.cfb-topic-box__label{font-weight:700;font-size:.95em;margin-bottom:6px}.cfb-col--frameworks{background:#d5b8d5}.cfb-col--frameworks .cfb-col__heading{color:#4a235a}.cfb-flow-box{padding:10px 16px;text-align:center;border:1.5px solid #aaa;overflow:hidden}.cfb-flow-box__label{font-weight:700;font-size:.9em;display:block;margin-bottom:2px}.cfb-flow-box--gaps{background:#d6e4f0;border-color:#999}.cfb-flow-box--problem{background:#fdebd0;border-color:#e0a84c}.cfb-flow-box--questions{background:#93c47d;border-color:#6aa84f;color:#fff;flex:1.6}.cfb-flow-box--questions .cfb-flow-box__label{color:#fff}.cfb-flow-box--design{background:#d5b8d5;border-color:#9c7bbd;flex:1}.cfb-arrow-down{text-align:center;font-size:1.5em;color:#555;line-height:1;padding:2px 0}.cfb-arrow-right{font-size:1.5em;color:#555;padding:0 6px;display:flex;align-items:center}.cfb-bottom-row{display:flex;gap:8px;align-items:stretch}.cfb-footer{padding:8px 16px;display:flex;align-items:center}.cfb-footer__logo{height:44px;width:auto;object-fit:contain}.cfb-footer__grid{height:32px;width:auto;margin-left:10px}.cfe-diagram{position:relative;width:min(1200px,96vw);aspect-ratio:10 / 6.5;background:#fff;border-radius:4px;box-shadow:0 4px 24px #00000026;overflow:hidden;font-size:12px;color:#1e2740;display:flex;flex-direction:column}.cfe-text--meta{color:#8b0000;font-weight:600}.cfe-text--topic{color:#073763}.cfe-text--body{font-size:.92em;line-height:1.35}.cfe-header{display:flex;align-items:flex-start;justify-content:space-between;padding:8px 16px 4px;gap:12px}.cfe-header__meta{font-size:.85em;font-weight:700;color:#8b0000;line-height:1.5;flex-shrink:0}.cfe-header__topic{font-size:1.15em;color:#073763;text-align:center;flex:1}.cfe-header__logo{display:flex;align-items:center;gap:6px;flex-shrink:0}.cfe-header__logo-img{height:36px;width:auto;object-fit:contain}.cfe-header__grid{height:28px;width:auto}.cfe-body{flex:1;display:flex;padding:0 10px 8px;gap:8px;min-height:0}.cfe-col{display:flex;flex-direction:column;gap:6px;min-height:0}.cfe-col--left{flex:0 0 22%}.cfe-col--center{flex:1}.cfe-col--right{flex:0 0 22%}.cfe-card{border:1.5px solid #999;border-radius:3px;overflow:hidden;display:flex;flex-direction:column}.cfe-card__header{font-weight:700;font-size:.9em;padding:5px 10px;text-align:center}.cfe-card__body{padding:8px 10px;flex:1;overflow:hidden}.cfe-card--topics .cfe-card__header,.cfe-card--topics .cfe-card__body{background:#cfe2f3}.cfe-card--topics .cfe-card__header{color:#1c4587}.cfe-card--frameworks .cfe-card__header,.cfe-card--frameworks .cfe-card__body{background:#d5b8d5}.cfe-card--frameworks .cfe-card__header{color:#4a235a}.cfe-card--personal .cfe-card__header,.cfe-card--personal .cfe-card__body{background:#f4cccc}.cfe-card--personal .cfe-card__header{color:#c0504d}.cfe-card--identity .cfe-card__header,.cfe-card--identity .cfe-card__body{background:#fff2cc}.cfe-card--identity .cfe-card__header{color:#7f6000}.cfe-card--litreview .cfe-card__header,.cfe-card--litreview .cfe-card__body{background:#e0f7fa}.cfe-card--litreview .cfe-card__header{color:#0097a7}.cfe-card--problem .cfe-card__header,.cfe-card--problem .cfe-card__body{background:#fdebd0}.cfe-card--problem .cfe-card__header{color:#bf6900}.cfe-card--questions .cfe-card__header,.cfe-card--questions .cfe-card__body{background:#93c47d}.cfe-card--questions .cfe-card__header{color:#1b5e20}.cfe-card--design .cfe-card__header,.cfe-card--design .cfe-card__body{background:#d5b8d5}.cfe-card--design .cfe-card__header{color:#4a235a}.cfe-card__item{padding:3px 0}.cfe-card__label{font-weight:700;font-size:.9em;display:block;margin-bottom:2px}.cfe-col--left .cfe-card:first-child,.cfe-col--right .cfe-card:first-child{flex:1.4}.cfe-col--left .cfe-card:nth-child(2),.cfe-col--left .cfe-card:nth-child(3),.cfe-col--right .cfe-card:nth-child(2),.cfe-col--right .cfe-card:nth-child(3){flex:1}.cfe-infographic{display:flex;flex-direction:column;align-items:center;flex:1;min-height:0}.cfe-infographic__title{font-weight:700;font-size:.95em;color:#c0504d;text-align:center;padding:4px 0 2px}.cfe-infographic__citation{font-size:.75em;font-style:italic;color:#666;text-align:center;padding:2px 0}.cfe-wheel{position:relative;width:95%;max-width:560px;aspect-ratio:1 / 1;margin:4px auto;font-size:14px}.cfe-wheel__svg{position:absolute;inset:0;width:100%;height:100%}.cfe-slabel{position:absolute;width:26%;text-align:center;color:#fff;pointer-events:none;line-height:1.15;z-index:7}.cfe-slabel strong{display:block;font-size:.82em;font-weight:700;margin-bottom:2px}.cfe-slabel span{font-size:.48em;line-height:1.1;display:block}.cfe-slabel--0{left:50%;top:18%;transform:translate(-50%,-50%)}.cfe-slabel--1{left:80%;top:40%;transform:translate(-50%,-50%)}.cfe-slabel--2{left:69%;top:74%;transform:translate(-50%,-50%)}.cfe-slabel--3{left:31%;top:74%;transform:translate(-50%,-50%)}.cfe-slabel--4{left:20%;top:40%;transform:translate(-50%,-50%)}.cfe-wheel__center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:40%;height:40%;border-radius:50%;background:#6aa84f;border:2.5px solid #fff;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5%;text-align:center;color:#fff;z-index:10}.cfe-wheel__center span{font-size:.48em;line-height:1.2}.cfe-design-row{display:flex;align-items:stretch;gap:4px}.cfe-design-row .cfe-card{flex:1}.cfe-design-arrow{display:flex;align-items:center;font-size:1.8em;color:#6aa84f;padding:0 2px;flex-shrink:0}@media print{*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;color-adjust:exact!important}@page{size:landscape;margin:.25in}body>*:not(#root),.no-print{display:none!important}.cf-overlay{position:static!important;background:#fff!important;overflow:visible!important;display:block!important;z-index:auto!important}.cf-page{padding:0!important;margin:0!important;width:100%!important;height:auto!important;display:block!important}.cf-diagram{width:100%!important;height:auto!important;aspect-ratio:10 / 6.25!important;max-width:none!important;box-shadow:none!important;border-radius:0!important;page-break-inside:avoid!important;position:relative!important;overflow:visible!important}.cfb-diagram,.cfe-diagram{width:100%!important;height:auto!important;aspect-ratio:10 / 6.5!important;max-width:none!important;box-shadow:none!important;border-radius:0!important;overflow:visible!important;page-break-inside:avoid!important}.cf-shapes-svg,.cf-footer,.cf-tile-bar,.cf-tile-bar span{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.cf-editable:hover,.cf-editable:focus{background:transparent!important;box-shadow:none!important}.cfb-card__header,.cfb-card__body,.cfb-lit-banner,.cfb-lit-area,.cfb-col--topics,.cfb-col--center,.cfb-col--frameworks,.cfb-topic-box,.cfb-flow-box,.cfb-footer,.cfe-card__header,.cfe-card__body,.cfe-design-arrow,.cfe-wheel__svg,.cfe-wheel__center,.cfe-wheel,[class*=cfe-card--] .cfe-card__header,[class*=cfe-card--] .cfe-card__body{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}}.sdv-overlay{position:fixed;inset:0;z-index:1000;background:var(--hop-bg);display:flex;flex-direction:column;overflow:hidden}.sdv-header{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:var(--hop-surface);border-bottom:1px solid var(--hop-border);gap:12px;flex-shrink:0}.sdv-header__left{display:flex;align-items:center;gap:12px;min-width:0}.sdv-header__right{display:flex;align-items:center;gap:8px;flex-shrink:0}.sdv-close{background:none;border:1px solid var(--hop-border);border-radius:var(--hop-radius-sm);padding:6px 14px;font-size:.85rem;color:var(--hop-ink);cursor:pointer;font-weight:500}.sdv-close:hover{background:var(--hop-border-light)}.sdv-header__name{font-size:1.1rem;font-weight:600;color:var(--hop-ink);margin:0;white-space:nowrap}.sdv-header__class{font-size:.8rem;color:var(--hop-muted);background:var(--hop-border-light);padding:2px 10px;border-radius:var(--hop-radius-pill)}.sdv-badge{display:inline-block;padding:2px 10px;border-radius:var(--hop-radius-pill);font-size:.75rem;font-weight:600;color:#fff;text-transform:capitalize}.sdv-loading{padding:40px;text-align:center;color:var(--hop-muted)}.sdv-body{flex:1;display:flex;overflow:hidden}.sdv-steps{width:200px;flex-shrink:0;border-right:1px solid var(--hop-border);background:var(--hop-surface);overflow-y:auto;padding:12px 0}.sdv-step-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;border:none;background:none;cursor:pointer;text-align:left;font-size:.85rem;color:var(--hop-ink-secondary);transition:background .15s}.sdv-step-btn:hover{background:var(--hop-border-light)}.sdv-step-btn--active{background:var(--hop-info-bg);font-weight:600;color:var(--hop-ink)}.sdv-step-btn__dot{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;background:var(--hop-border);color:var(--hop-muted);flex-shrink:0}.sdv-step-btn--done .sdv-step-btn__dot{color:#fff}.sdv-step-btn__label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sdv-right{flex:1;display:flex;flex-direction:column;overflow:hidden}.sdv-content{flex:1;overflow-y:auto;padding:24px}.sdv-content__title{font-size:1.05rem;font-weight:600;color:var(--hop-ink);margin:0 0 16px;padding-left:12px;border-left:4px solid #ccc}.sdv-empty{color:var(--hop-muted);font-style:italic;padding:16px 0}.sdv-fields{display:flex;flex-direction:column;gap:14px}.sdv-field{padding:10px 14px;background:var(--hop-surface);border:1px solid var(--hop-border);border-radius:var(--hop-radius-sm)}.sdv-field__label{font-size:.78rem;font-weight:600;color:var(--hop-muted);text-transform:uppercase;letter-spacing:.02em;margin-bottom:4px}.sdv-field__value{font-size:.92rem;color:var(--hop-ink);white-space:pre-wrap;line-height:1.5}.sdv-field__empty{font-size:.88rem;color:var(--hop-muted);font-style:italic}.sdv-feedback{border-top:1px solid var(--hop-border);background:var(--hop-surface);padding:14px 24px;flex-shrink:0;max-height:280px;display:flex;flex-direction:column}.sdv-feedback__title{font-size:.95rem;font-weight:600;color:var(--hop-ink);margin:0 0 8px;flex-shrink:0}.sdv-feedback__empty{color:var(--hop-muted);font-size:.85rem;font-style:italic;margin:0 0 8px}.sdv-feedback__list{overflow-y:auto;flex:1;margin-bottom:8px}.sdv-feedback__item{padding:10px 12px;background:var(--hop-border-light);border-radius:var(--hop-radius-sm);margin-bottom:6px}.sdv-feedback__meta{display:flex;align-items:center;gap:8px;font-size:.8rem;margin-bottom:4px}.sdv-feedback__meta strong{color:var(--hop-ink)}.sdv-feedback__time{color:var(--hop-muted);font-size:.75rem}.sdv-feedback__text{font-size:.88rem;color:var(--hop-ink-secondary);margin:0;line-height:1.45;white-space:pre-wrap}.sdv-feedback__input{display:flex;gap:8px;align-items:flex-end;flex-shrink:0}.sdv-feedback__input .textarea{flex:1;min-height:44px;resize:vertical}.fb-bell{background:none;border:none;cursor:pointer;padding:4px 6px;color:var(--hop-ink-secondary);position:relative;display:flex;align-items:center}.fb-bell:hover{color:var(--hop-ink)}.fb-badge{position:absolute;top:-2px;right:-4px;background:var(--hop-error);color:#fff;font-size:.65rem;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}.fb-backdrop{position:fixed;inset:0;background:#00000040;z-index:500}.fb-slide{position:fixed;top:0;right:0;width:380px;max-width:90vw;height:100vh;background:var(--hop-surface);border-left:1px solid var(--hop-border);box-shadow:-4px 0 20px #0000001a;z-index:501;display:flex;flex-direction:column;animation:fb-slide-in .2s ease-out}@keyframes fb-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.fb-slide__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--hop-border);flex-shrink:0}.fb-slide__title{font-size:1.05rem;font-weight:600;color:var(--hop-ink);margin:0}.fb-slide__close{background:none;border:none;font-size:1.4rem;color:var(--hop-muted);cursor:pointer;padding:0 4px;line-height:1}.fb-slide__close:hover{color:var(--hop-ink)}.fb-slide__body{flex:1;overflow-y:auto;padding:16px 20px}.fb-slide__empty{text-align:center;padding:40px 20px}.fb-slide__empty p{color:var(--hop-muted);margin:0 0 8px}.fb-slide__hint{font-size:.83rem;color:var(--hop-muted)}.fb-slide__list{display:flex;flex-direction:column;gap:10px}.fb-slide__item{padding:14px 16px;border-radius:var(--hop-radius-sm);border:1px solid var(--hop-border);background:var(--hop-bg)}.fb-slide__item--unread{background:var(--hop-info-bg);border-color:var(--hop-navy-light)}.fb-slide__item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;font-size:.82rem}.fb-slide__item-header strong{color:var(--hop-ink)}.fb-slide__time{color:var(--hop-muted);font-size:.75rem}.fb-slide__text{font-size:.9rem;color:var(--hop-ink-secondary);margin:0;line-height:1.5;white-space:pre-wrap}.ad-dashboard{min-height:100vh;background:var(--hop-surface, #f8f9fa);color:var(--hop-ink, #1a1a2e)}.ad-header{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:60px;background:var(--hop-card, #fff);border-bottom:1px solid var(--hop-border, #e5e7eb)}.ad-header__left{display:flex;align-items:center;gap:12px}.ad-header__badge{background:#7c3aed;color:#fff;font-size:.7rem;font-weight:700;padding:2px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}.ad-header__right{display:flex;align-items:center;gap:12px}.ad-body{max-width:1280px;margin:0 auto;padding:24px}.ad-stats{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap}.ad-stat-card{flex:1;min-width:140px;background:var(--hop-card, #fff);border-radius:10px;padding:20px;border-top:3px solid #2B5EA7;box-shadow:0 1px 3px #00000014}.ad-stat-card__value{font-size:2rem;font-weight:700;color:var(--hop-ink, #1a1a2e);line-height:1;margin-bottom:4px}.ad-stat-card__label{font-size:.8rem;color:var(--hop-ink-secondary, #6b7280);text-transform:uppercase;letter-spacing:.05em}.ad-tabs{display:flex;gap:4px;border-bottom:2px solid var(--hop-border, #e5e7eb);margin-bottom:20px}.ad-tab{padding:10px 20px;font-size:.9rem;font-weight:500;background:none;border:none;color:var(--hop-ink-secondary, #6b7280);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.ad-tab:hover{color:var(--hop-ink, #1a1a2e)}.ad-tab--active{color:#2b5ea7;border-bottom-color:#2b5ea7;font-weight:600}.ad-tab-content{min-height:300px}.ad-loading{text-align:center;padding:40px;color:var(--hop-ink-secondary, #6b7280)}.ad-empty{color:var(--hop-ink-secondary, #6b7280);font-size:.9rem;padding:16px}.ad-overview{display:flex;flex-direction:column;gap:20px}.ad-chart-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width: 768px){.ad-chart-row{grid-template-columns:1fr}}.ad-chart-card{background:var(--hop-card, #fff);border-radius:10px;padding:20px;box-shadow:0 1px 3px #00000014}.ad-chart-card h4{margin:0 0 16px;font-size:.95rem;color:var(--hop-ink, #1a1a2e)}.ad-chart-card--wide{width:100%}.ad-users__toolbar{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap;align-items:center}.ad-users__search{flex:1;min-width:200px;padding:8px 12px;border:1px solid var(--hop-border, #e5e7eb);border-radius:6px;font-size:.9rem;background:var(--hop-card, #fff);color:var(--hop-ink, #1a1a2e)}.ad-users__filter{padding:8px 12px;border:1px solid var(--hop-border, #e5e7eb);border-radius:6px;font-size:.9rem;background:var(--hop-card, #fff);color:var(--hop-ink, #1a1a2e)}.ad-role-badge{display:inline-block;padding:2px 10px;border-radius:999px;font-size:.7rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.03em}.ad-role-badge--fail{background:#dc2626!important}.ad-status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px}.ad-status-dot--active{background:#16a34a}.ad-status-dot--inactive{background:#dc2626}.ad-actions{display:flex;gap:4px}.ad-action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--hop-border, #e5e7eb);border-radius:6px;background:var(--hop-card, #fff);cursor:pointer;color:var(--hop-ink-secondary, #6b7280);transition:background .15s,color .15s}.ad-action-btn:hover{background:var(--hop-surface, #f3f4f6);color:var(--hop-ink, #1a1a2e)}.ad-action-btn--danger:hover{background:#fee2e2;color:#dc2626;border-color:#fecaca}.ad-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:16px;font-size:.85rem;color:var(--hop-ink-secondary, #6b7280)}.ad-pagination button{padding:6px 14px;border:1px solid var(--hop-border, #e5e7eb);border-radius:6px;background:var(--hop-card, #fff);cursor:pointer;font-size:.85rem;color:var(--hop-ink, #1a1a2e)}.ad-pagination button:disabled{opacity:.4;cursor:not-allowed}.ad-map-wrap{background:var(--hop-card, #fff);border-radius:10px;padding:20px;box-shadow:0 1px 3px #00000014}.ad-map-wrap h4{margin:0 0 16px;font-size:.95rem}.ad-modal-backdrop{position:fixed;inset:0;background:#0006;z-index:1000;display:flex;align-items:center;justify-content:center}.ad-modal{background:var(--hop-card, #fff);border-radius:12px;padding:28px;min-width:380px;max-width:480px;box-shadow:0 8px 30px #0003}.ad-modal h3{margin:0 0 16px;font-size:1.1rem}.ad-modal p{margin:0 0 12px;font-size:.9rem;line-height:1.5}.ad-modal label{display:flex;flex-direction:column;gap:4px;margin-bottom:12px;font-size:.85rem;font-weight:500;color:var(--hop-ink-secondary, #6b7280)}.ad-modal input,.ad-modal select{padding:8px 12px;border:1px solid var(--hop-border, #e5e7eb);border-radius:6px;font-size:.9rem;background:var(--hop-surface, #f8f9fa);color:var(--hop-ink, #1a1a2e)}.ad-modal__checkbox{flex-direction:row!important;align-items:center!important;gap:8px!important}.ad-modal__checkbox input{width:auto}.ad-modal__actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.ad-modal__error{background:#fee2e2;color:#dc2626;padding:8px 12px;border-radius:6px;font-size:.85rem;margin-bottom:12px}.ad-activity{display:flex;flex-direction:column;gap:0}.ad-geo{display:flex;flex-direction:column}.ad-chart-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.ad-chart-card__header h4{margin:0}.ad-clickable{color:var(--hop-navy, #2B4C7E);text-decoration:underline;text-decoration-style:dotted;text-underline-offset:2px}.ad-clickable:hover{color:var(--hop-navy-dark, #1E3A5F)}.ad-back-btn{background:none;border:none;cursor:pointer;font-size:.95rem;color:var(--hop-navy, #2B4C7E);padding:4px 8px;border-radius:6px}.ad-back-btn:hover{background:var(--hop-border-light, #f3f5f7)}.ad-health__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.ad-health-card{background:var(--hop-surface, #fff);border:1px solid var(--hop-border, #ebeef2);border-radius:12px;overflow:hidden}.ad-health-card__header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--hop-border, #ebeef2)}.ad-health-card__header h4{margin:0;font-size:.95rem}.ad-health-card__badge{display:inline-block;padding:2px 10px;border-radius:999px;font-size:.75rem;font-weight:600;color:#fff}.ad-health-card__body{padding:12px 16px}.ad-health-card__row{display:flex;justify-content:space-between;padding:4px 0;font-size:.85rem}.ad-health-card__label{color:var(--hop-muted, #6b7280)}.ad-health-card__value{font-weight:500;color:var(--hop-ink, #1a2332);word-break:break-all;text-align:right;max-width:60%}.ad-user-detail{padding:0 4px}.ad-user-detail__header{display:flex;align-items:flex-start;gap:16px;padding:20px 0;border-bottom:1px solid var(--hop-border, #ebeef2);margin-bottom:4px}.ad-user-detail__avatar{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:#fff;flex-shrink:0}.ad-user-detail__header h2{margin:0 0 2px;font-size:1.3rem}.ad-user-detail__meta{display:flex;align-items:center;gap:12px;margin-top:8px;flex-wrap:wrap;font-size:.85rem;color:var(--hop-muted, #6b7280)}:root[data-theme=dark] .ad-dashboard{background:var(--hop-bg);color:var(--hop-ink)}:root[data-theme=dark] .ad-header{background:var(--hop-surface);border-bottom-color:var(--hop-border)}:root[data-theme=dark] .ad-stat-card{background:var(--hop-card);box-shadow:0 1px 3px #0000004d}:root[data-theme=dark] .ad-chart-card{background:var(--hop-card);box-shadow:0 1px 3px #0000004d}:root[data-theme=dark] .ad-tabs{border-bottom-color:var(--hop-border)}:root[data-theme=dark] .ad-tab--active{color:#5b8cc8;border-bottom-color:#5b8cc8}:root[data-theme=dark] .ad-users__search,:root[data-theme=dark] .ad-users__filter{background:var(--hop-surface);border-color:var(--hop-border);color:var(--hop-ink)}:root[data-theme=dark] .ad-action-btn{background:var(--hop-surface);border-color:var(--hop-border);color:var(--hop-ink-secondary)}:root[data-theme=dark] .ad-action-btn:hover{background:var(--hop-card);color:var(--hop-ink)}:root[data-theme=dark] .ad-action-btn--danger:hover{background:#3d1a1a;color:#f06060;border-color:#5c2020}:root[data-theme=dark] .ad-pagination button{background:var(--hop-surface);border-color:var(--hop-border);color:var(--hop-ink)}:root[data-theme=dark] .ad-modal{background:var(--hop-card);box-shadow:0 8px 30px #00000080}:root[data-theme=dark] .ad-modal h3{color:var(--hop-ink)}:root[data-theme=dark] .ad-modal p{color:var(--hop-ink-secondary)}:root[data-theme=dark] .ad-modal input,:root[data-theme=dark] .ad-modal select{background:var(--hop-surface);border-color:var(--hop-border);color:var(--hop-ink)}:root[data-theme=dark] .ad-modal__error{background:#3d1a1a;color:#f06060}:root[data-theme=dark] .ad-modal-backdrop{background:#0009}:root[data-theme=dark] .ad-health-card{background:var(--hop-card);border-color:var(--hop-border)}:root[data-theme=dark] .ad-health-card__header{border-bottom-color:var(--hop-border)}:root[data-theme=dark] .ad-map-wrap{background:var(--hop-card);box-shadow:0 1px 3px #0000004d}:root[data-theme=dark] .ad-back-btn:hover{background:var(--hop-border)}:root[data-theme=dark] .ad-clickable{color:var(--hop-navy)}:root[data-theme=dark] .ad-clickable:hover{color:var(--hop-navy-dark)}:root[data-theme=dark] .ad-dashboard .recharts-text,:root[data-theme=dark] .ad-dashboard .recharts-cartesian-axis-tick-value{fill:var(--hop-ink-secondary)!important}:root[data-theme=dark] .ad-dashboard .recharts-tooltip-wrapper .recharts-default-tooltip{background:var(--hop-card)!important;border-color:var(--hop-border)!important;color:var(--hop-ink)!important}:root[data-theme=dark] .ad-dashboard .recharts-legend-item-text{color:var(--hop-ink-secondary)!important}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}
