:root{font-family:Inter,system-ui,Segoe UI,Roboto,sans-serif;line-height:1.5;color:#0f172a;background:#f8fafc}*{box-sizing:border-box}body{margin:0;min-height:100vh}a{color:#2563eb;text-decoration:none}a:hover{text-decoration:underline}.app-header{padding:1rem 1.25rem;background:#fff;border-bottom:1px solid #e2e8f0}.app-header-main{display:flex;align-items:center}.app-header-home{font-size:1rem;font-weight:600;color:#1d4ed8;text-decoration:none}.app-header-home:hover{text-decoration:underline}.app-header-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.app-header-auth{display:flex;align-items:center;gap:.75rem;font-size:.92rem}.app-header-auth a{color:#1d4ed8;font-weight:500}.app-header-auth-muted{color:#94a3b8}.btn-link{background:none;border:none;padding:0;font:inherit;color:#64748b;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.btn-link:hover{color:#0f172a}.auth-done,.profile-page{max-width:36rem}.profile-avatar{border-radius:50%;display:block;margin:.5rem 0}.profile-name{font-size:1.15rem;font-weight:600;margin:.25rem 0}.profile-email{color:#64748b;margin:0 0 1rem}.profile-vocab-usage{margin:1.25rem 0 1.5rem;padding:1rem 1.1rem;border:1px solid #e2e8f0;border-radius:10px;background:#f8fafc}.profile-vocab-usage h2{margin:0 0 .35rem;font-size:1.1rem;color:#0f172a}.profile-vocab-note{margin:0 0 .75rem;font-size:.85rem;color:#64748b}.profile-vocab-dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:.35rem 1.25rem;font-size:.95rem}.profile-vocab-dl dt{margin:0;color:#64748b;font-weight:500}.profile-vocab-dl dd{margin:0;color:#0f172a}main{max-width:72rem;margin:0 auto;padding:1.25rem}.landing-shell{--landing-accent-blue: #1d4ed8;--landing-accent-emerald: #047857;--landing-accent-violet: #6d28d9;margin:0 auto 2.5rem;max-width:72rem;padding:0 .25rem;background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-radius:.5rem}.landing-hero{position:relative;overflow:hidden;text-align:center;padding:3rem 1.5rem 3.5rem;margin-bottom:0;border-radius:1.25rem;background:radial-gradient(ellipse 85% 55% at 50% -5%,rgba(37,99,235,.045) 0%,transparent 58%),#fff;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0f172a0a}.landing-hero-glow{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;z-index:0;overflow:hidden}.landing-hero-glow:before{content:"";position:absolute;left:50%;top:18%;transform:translate(-50%,-38%);width:min(100%,36rem);height:14rem;background:radial-gradient(ellipse 75% 70% at 50% 45%,rgba(37,99,235,.1) 0%,rgba(16,185,129,.1) 52%,transparent 72%);filter:blur(100px)}.landing-hero-glow:after{content:"";position:absolute;left:22%;top:48%;width:min(90%,26rem);height:12rem;background:radial-gradient(ellipse 70% 65% at 40% 50%,rgba(16,185,129,.09) 0%,rgba(37,99,235,.07) 48%,transparent 70%);filter:blur(100px)}.landing-hero-inner{position:relative;z-index:1;max-width:42rem;margin:0 auto}.landing-hero-title{margin:0 0 .85rem;font-size:clamp(2.1rem,4.2vw,2.85rem);font-weight:800;letter-spacing:-.035em;line-height:1.12;color:#020617}.landing-hero-sub{margin:0 auto;font-size:clamp(1.02rem,1.85vw,1.1rem);line-height:1.65;max-width:40.625rem;color:#475569}.landing-hero-accent{color:var(--landing-accent-blue);font-weight:600}.landing-bridge{display:flex;justify-content:center;margin:2rem 0 1.25rem;padding:0 .5rem}.landing-bridge-pill{margin:0;padding:.25rem 1rem;max-width:min(52rem,100%);font-size:.75rem;line-height:1.45;font-weight:600;color:#475569;background:#eef2ff;border:1px solid #c7d2fe;border-radius:999px;text-align:center;text-wrap:balance}.landing-bridge-pill strong{font-weight:700;color:#3730a3}.landing-bridge-pill em{font-style:italic;font-weight:600;color:#5b21b6}@media(max-width:640px){.landing-bridge-pill{border-radius:1rem;padding:.45rem .85rem;text-align:left}}.landing-cards{list-style:none;margin:0;padding:0;position:relative;z-index:1;display:grid;grid-template-columns:repeat(3,1fr);gap:1.35rem}@media(max-width:960px){.landing-cards{grid-template-columns:1fr}}.landing-card{display:flex;flex-direction:column;height:100%;min-height:100%;padding:1.5rem 1.45rem 1.35rem;background-color:#fff;background-image:none;border:1px solid rgba(241,245,249,.95);border-radius:1rem;box-shadow:0 10px 25px -5px #0f172a0d;text-decoration:none;color:inherit;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease,background .22s ease}.landing-card:hover{transform:translateY(-5px);border:2px solid transparent;background-image:linear-gradient(#fff,#fff),linear-gradient(135deg,#10b981,#2563eb);background-origin:border-box;background-clip:padding-box,border-box;box-shadow:0 18px 45px -12px #0f172a1a;text-decoration:none}.landing-card--vocab{border-color:#e2e8f0f2;box-shadow:0 10px 25px -5px #2563eb0f}.landing-card--vocab:hover{border:2px solid transparent;background-image:linear-gradient(#fff,#fff),linear-gradient(135deg,#10b981,#2563eb);background-origin:border-box;background-clip:padding-box,border-box;box-shadow:0 20px 48px -12px #2563eb24}.landing-card--vocab .landing-card-icon{background:#eff6ff;color:var(--landing-accent-blue)}.landing-card--dialog{border-color:#d1fae5d9;box-shadow:0 10px 25px -5px #10b98112}.landing-card--dialog:hover{border:2px solid transparent;background-image:linear-gradient(#fff,#fff),linear-gradient(135deg,#10b981,#2563eb);background-origin:border-box;background-clip:padding-box,border-box;box-shadow:0 18px 45px -12px #0596691f}.landing-card--dialog .landing-card-icon{background:#ecfdf5;color:var(--landing-accent-emerald)}.landing-card--dialog .landing-card-features li:before{background:#34d399}.landing-card--text{border-color:#ede9fef2;box-shadow:0 10px 25px -5px #7c3aed14}.landing-card--text:hover{border:2px solid transparent;background-image:linear-gradient(#fff,#fff),linear-gradient(135deg,#10b981,#2563eb);background-origin:border-box;background-clip:padding-box,border-box;box-shadow:0 18px 45px -12px #6d28d91f}.landing-card--text .landing-card-icon{background:#faf5ff;color:var(--landing-accent-violet)}.landing-card--text .landing-card-features li:before{background:#a78bfa}.landing-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:.85rem}.landing-card-icon{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;border-radius:.75rem;background:#f1f5f9;color:#1e3a8a;flex-shrink:0}.landing-card-icon-svg{width:1.55rem;height:1.55rem}.landing-card-badge{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:.28rem .6rem;border-radius:999px;background:#f1f5f9;color:#475569;white-space:nowrap}.landing-card--vocab .landing-card-badge{background:#eff6ff;color:#1d4ed8}.landing-card-kicker{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:#64748b;font-weight:600;margin-bottom:.35rem}.landing-card-title{margin:0 0 .6rem;font-size:1.35rem;font-weight:700;color:#0f172a;letter-spacing:-.01em}.landing-card-desc{margin:0 0 1.25rem;font-size:1.02rem;color:#475569;line-height:1.55;flex:1}.landing-card-features{list-style:none;margin:0 0 1.15rem;padding:0;flex:1}.landing-card-features li{position:relative;margin:0 0 .42rem;padding-left:.95rem;font-size:.875rem;line-height:1.45;color:#64748b}.landing-card-features li:before{content:"";position:absolute;left:0;top:.55em;width:.3rem;height:.3rem;border-radius:50%;background:#94a3b8}.landing-card-features li:last-child{margin-bottom:0}.landing-card-features strong{color:#334155;font-weight:600}.landing-card-cta{display:block;width:100%;text-align:center;margin-top:auto;padding:.65rem 1rem;font-size:.98rem;font-weight:600;border-radius:.5rem;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,color .15s ease}.landing-card-cta--primary{background:#fff;color:#1d4ed8;border:1px solid #e2e8f0;box-shadow:0 1px 2px #0f172a0d}.landing-card:hover .landing-card-cta--primary{background:#f8fafc;box-shadow:0 4px 12px #2563eb26;transform:translateY(-1px)}.landing-card-cta--ghost{background:transparent;color:#1d4ed8;border:1px solid #cbd5e1}.landing-card:hover .landing-card-cta--ghost{background:#eff6ff;border-color:#93c5fd;transform:translateY(-1px)}.landing-guide{margin-top:3rem;background:#fff;border:1px solid #e2e8f0;border-radius:1rem;box-shadow:0 4px 6px -1px #0f172a0f;overflow:hidden}.landing-guide-inner{max-width:64rem;margin:0 auto;padding:2rem 1.75rem 2.25rem}.landing-guide-title{margin:0 0 1rem;font-size:1.65rem;font-weight:700;line-height:1.3;color:#0f172a;letter-spacing:-.02em}.landing-guide-lead{margin:0 0 2rem;font-size:1.08rem;line-height:1.7;color:#475569;max-width:48rem}.landing-how-surface{margin-top:.25rem;padding:2.25rem 1.75rem 2.5rem;background:#fff;border-radius:1.25rem;border:1px solid #e2e8f0;box-shadow:0 4px 20px -6px #0f172a0f}.landing-how-section{margin:0}.landing-how-section--spaced{margin-top:2.75rem;padding-top:2.5rem;border-top:1px solid #e2e8f0}.landing-how-group{margin:0 0 1rem}.landing-how-group-title{margin:0 0 .65rem;font-size:1.35rem;font-weight:700;letter-spacing:-.02em;color:#0f172a}.landing-how-group-title--long{font-size:clamp(1.1rem,2.8vw,1.35rem);line-height:1.35;max-width:42rem}.landing-how-group-rule{height:1px;max-width:min(100%,36rem);background:linear-gradient(90deg,#cbd5e1 0%,rgba(203,213,225,.35) 55%,transparent 100%)}.landing-how-intro{margin:0 0 1.75rem;font-size:1.02rem;line-height:1.7;color:#64748b;max-width:42rem}.landing-hiw-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:2.5rem 2.5rem}.landing-hiw-grid--tight-top{margin-top:1.5rem}@media(max-width:768px){.landing-hiw-grid{grid-template-columns:1fr;gap:1.5rem}}.landing-hiw-card{display:flex;flex-direction:column;align-items:flex-start;padding:1.5rem;background:#fff;border-radius:1.125rem;box-shadow:0 1px 2px #0f172a0d;border:1px solid rgba(226,232,240,.8);transition:box-shadow .25s ease,transform .2s ease}.landing-hiw-card:hover{box-shadow:0 8px 24px -6px #0f172a1a,0 4px 8px -4px #0f172a0f;transform:translateY(-1px)}.landing-hiw-card:hover .landing-hiw-card-title{color:#2563eb}.landing-hiw-card:hover .landing-hiw-icon-svg{transform:scale(1.1)}.landing-hiw-icon{width:3rem;height:3rem;border-radius:999px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;flex-shrink:0}.landing-hiw-icon-svg{width:1.35rem;height:1.35rem;transition:transform .22s ease}.landing-hiw-icon--emerald{background:#ccfbf1;color:#047857}.landing-hiw-icon--blue{background:#dbeafe;color:#1d4ed8}.landing-hiw-icon--violet{background:#ede9fe;color:#5b21b6}.landing-hiw-icon--amber{background:#fef3c7;color:#b45309}.landing-hiw-icon--teal{background:#ccfbf1;color:#0f766e}.landing-hiw-icon--indigo{background:#e0e7ff;color:#3730a3}.landing-hiw-icon--orange{background:#ffedd5;color:#c2410c}.landing-hiw-icon--cyan{background:#cffafe;color:#0e7490}.landing-hiw-card-title{margin:0 0 .65rem;font-size:1.125rem;font-weight:700;color:#0f172a;letter-spacing:-.015em;transition:color .2s ease}.landing-hiw-card-desc{font-size:.875rem;line-height:1.7;color:#475569}.landing-hiw-card-desc p{margin:0 0 .65rem;line-height:1.7}.landing-hiw-card-desc p:last-child{margin-bottom:0}.landing-hiw-card-desc code{font-size:.85em;padding:.1rem .35rem;background:#f1f5f9;border-radius:4px;color:#0f172a}.landing-level-pill{display:inline-block;margin:0 .1rem;padding:.12rem .4rem;font-size:.72rem;font-weight:700;letter-spacing:.03em;color:#1e40af;background:#eff6ff;border-radius:.25rem;border:1px solid #bfdbfe;vertical-align:baseline}.landing-hiw-card-illo{margin-top:1.1rem;width:100%;align-self:stretch}.landing-hiw-slider{display:flex;align-items:center;gap:.65rem;padding:.5rem 0 0}.landing-hiw-slider-end{font-size:.65rem;font-weight:800;letter-spacing:.06em;color:#64748b;min-width:1.35rem;text-align:center}.landing-hiw-slider-track{position:relative;flex:1;height:.45rem;border-radius:999px;background:#e2e8f0;overflow:visible}.landing-hiw-slider-fill{position:absolute;left:0;top:0;bottom:0;width:52%;border-radius:999px;background:linear-gradient(90deg,#2563eb,#10b981);opacity:.35}.landing-hiw-slider-thumb{position:absolute;left:52%;top:50%;width:1.05rem;height:1.05rem;margin-top:-.525rem;margin-left:-.525rem;border-radius:999px;background:#fff;border:2px solid #2563eb;box-shadow:0 2px 6px #2563eb40}.landing-hiw-print-svg{width:100%;max-width:7.5rem;height:auto;display:block;margin:0 auto}.landing-hiw-shutter-row{display:flex;align-items:center;gap:.5rem;margin-top:.25rem}.landing-hiw-shutter-icon{width:1.35rem;height:1.35rem;color:#0e7490;flex-shrink:0}.landing-hiw-shutter-caption{font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#64748b}.landing-guide a{font-weight:500;color:#2563eb}.landing-guide code{font-size:.9em;padding:.12rem .35rem;background:#f1f5f9;border-radius:4px;color:#0f172a}.landing-example-label{margin:1rem 0 .45rem;font-size:.95rem;color:#64748b}.landing-example{margin:0 0 1rem;padding:.9rem 1rem;font-size:.95rem;line-height:1.45;background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;overflow-x:auto;color:#334155;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.hub-nav{display:flex;gap:.75rem;margin-bottom:1rem}.hub-nav a.active{font-weight:600;color:#0f172a}.search{width:100%;max-width:24rem;padding:.5rem .75rem;font-size:1rem;border:1px solid #cbd5e1;border-radius:6px;margin-bottom:1rem}.topic-list{list-style:none;padding:0;margin:0}.topic-list li{padding:.5rem 0;border-bottom:1px solid #e2e8f0}.vvv-content{font-size:1.2rem;line-height:1.6;margin-bottom:1rem}.vvv-avatar{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;color:#fff;font-weight:600;font-size:.75rem;margin-right:.5rem;vertical-align:middle}.vvv-tr{border-bottom:1px dashed #94a3b8;cursor:help}.vvv-reading-md{font-size:1.2rem;line-height:1.6;white-space:normal}.level-block{margin-bottom:2rem}.level-block h2{font-size:1.1rem;color:#475569;margin:0 0 .75rem}.flash-panel{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:1rem;margin-top:1.5rem}.flash-panel h3{margin:0 0 .75rem;font-size:1rem}.flash-item{margin-bottom:.75rem;font-size:.95rem}.flash-item em{color:#64748b;font-style:normal;font-size:.9rem}.level-tabs{display:flex;gap:.25rem;flex-wrap:wrap;margin:1rem 0 1.25rem;border-bottom:1px solid #e2e8f0;padding-bottom:.5rem}.level-tab{padding:.45rem .85rem;font-size:.95rem;border:1px solid transparent;border-radius:6px 6px 0 0;background:transparent;cursor:pointer;color:#64748b}.level-tab:hover{color:#0f172a;background:#f1f5f9}.level-tab.active{color:#0f172a;font-weight:600;background:#fff;border-color:#e2e8f0;border-bottom-color:#fff;margin-bottom:-1px}.topic-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(14rem,1fr);gap:1.5rem;align-items:start}@media(max-width:768px){.topic-grid{grid-template-columns:1fr}}.topic-side .flash-panel{margin-top:0;position:sticky;top:.5rem;max-height:min(80vh,900px);overflow-y:auto}.no-content{color:#64748b;margin:1rem 0}.flash-section-title{margin:.75rem 0 .35rem;font-size:.9rem;font-weight:600}.flash-row{margin-bottom:.5rem}.flash-check-label{display:flex;align-items:flex-start;gap:.5rem;font-size:.92rem;cursor:pointer}.flash-example{margin:-.15rem 0 .5rem 1.2rem;font-size:.85rem;color:#475569;font-style:italic}.vvv-reading-md h3{font-size:1.35rem;font-weight:600;margin-top:.9em;margin-bottom:.4em;color:#1e293b}.vvv-reading-md p{margin:0 0 .85em}.export-buffer{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid #e2e8f0}.export-buffer-title{font-size:1.1rem;margin:0 0 .75rem}.fmt-row{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:.75rem}.fmt-option{display:inline-flex;align-items:center;gap:.35rem;cursor:pointer;font-size:.95rem}.export-textarea{width:100%;max-width:100%;font-family:ui-monospace,monospace;font-size:.88rem;padding:.6rem .75rem;border:1px solid #cbd5e1;border-radius:6px;resize:vertical}.export-actions{display:flex;align-items:center;gap:1rem;margin-top:.75rem}.btn-secondary{padding:.4rem .85rem;font-size:.9rem;border:1px solid #cbd5e1;border-radius:6px;background:#fff;cursor:pointer}.btn-secondary:hover{background:#f1f5f9}.cart-count{font-size:.9rem;color:#64748b}.hub-shell{margin:-.5rem -.25rem 2rem}.hub-hero{background:linear-gradient(135deg,#1e3a5f,#2563eb 48%,#0d9488);color:#f8fafc;padding:2rem 1.5rem 2.25rem;border-radius:12px;margin-bottom:1.5rem;box-shadow:0 10px 40px #2563eb40}.hub-hero-kicker{margin:0 0 .35rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;opacity:.85}.hub-hero-title{margin:0 0 .5rem;font-size:1.75rem;font-weight:700;letter-spacing:-.02em}.hub-hero-sub{margin:0;font-size:.95rem;opacity:.9;max-width:28rem;line-height:1.5}.hub-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem 1.35rem 1.5rem;box-shadow:0 1px 3px #0f172a0f}.hub-pills{display:flex;gap:.5rem;margin-bottom:1.25rem}.hub-pill{display:inline-block;padding:.5rem 1.1rem;border-radius:999px;font-size:.9rem;font-weight:600;border:1px solid transparent;transition:background .15s,color .15s,border-color .15s,transform .12s}.hub-pill--inactive{color:#1e293b;background:#f1f5f9}.hub-pill--inactive:hover{background:#e2e8f0;color:#0f172a;text-decoration:none}.hub-pill--active{background:#2563eb;color:#fff;border-color:#1d4ed8}.hub-pill--active:hover{background:#1d4ed8;color:#fff;text-decoration:none}.hub-card-head{margin-bottom:1rem}.hub-section-title{margin:0;font-size:1.1rem;font-weight:600;color:#0f172a}.hub-search-row{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1rem;margin-bottom:1.25rem}.hub-search-wrap{position:relative;flex:1;min-width:12rem;display:flex;align-items:center}.hub-search-icon{position:absolute;left:.95rem;top:50%;transform:translateY(-50%);display:flex;color:#94a3b8;pointer-events:none}.hub-search-icon-svg{width:1.15rem;height:1.15rem}.hub-search{width:100%;padding:.65rem .95rem;font-size:1rem;border:1px solid #e2e8f0;border-radius:.75rem;background:#f8fafc;color:#0f172a}.hub-search--inset{padding-left:2.65rem}.hub-search:focus{outline:2px solid #93c5fd;outline-offset:1px;background:#fff;border-color:#cbd5e1}.hub-count-badge{flex-shrink:0;font-size:.8rem;font-weight:600;font-variant-numeric:tabular-nums;color:#475569;background:#f1f5f9;border-radius:999px;padding:.35rem .85rem}.hub-error{color:#b91c1c;font-size:.95rem}.hub-loading,.hub-empty{color:#64748b;margin:.5rem 0}.hub-category-stack--catalog{display:flex;flex-direction:column;gap:0}.hub-category-block--catalog{margin:0;padding-top:0}.hub-category-block--divider{margin-top:1.75rem;padding-top:1.5rem;border-top:1px solid #e2e8f0}.hub-category-title--emerald{margin:0 0 .85rem;padding:0;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:#10b981;background:none;border:none}.catalog-list{list-style:none;padding:0;margin:0}.catalog-row{display:block;padding:1rem .85rem;margin-bottom:.35rem;border-radius:.65rem;text-decoration:none;color:inherit;transition:background .15s ease}.catalog-row:hover{background:#f8fafc;text-decoration:none}.catalog-row:focus-visible{outline:2px solid #93c5fd;outline-offset:2px}.catalog-row-head{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:.5rem .75rem}.catalog-row-title{font-size:1.125rem;font-weight:600;color:#1e3a8a;transition:color .15s,text-decoration-color .15s}.catalog-row:hover .catalog-row-title{color:#1d4ed8;text-decoration:underline;text-underline-offset:3px}.catalog-row-levels{display:inline-flex;flex-wrap:wrap;gap:.35rem}.catalog-level-badge{font-size:.65rem;font-weight:700;letter-spacing:.04em;padding:.2rem .45rem;border-radius:.25rem;color:#fff;background:linear-gradient(135deg,#2563eb,#0d9488)}.catalog-level-badge:nth-child(4n+2){background:linear-gradient(135deg,#7c3aed,#2563eb)}.catalog-level-badge:nth-child(4n+3){background:linear-gradient(135deg,#0d9488,#059669)}.catalog-level-badge:nth-child(4n+4){background:linear-gradient(135deg,#ea580c,#dc2626)}.catalog-row-desc{display:block;margin-top:.4rem;max-width:42rem;font-size:.875rem;line-height:1.5;color:#64748b;font-weight:400}.info-banner{margin:0 0 1rem;padding:.75rem 1rem;font-size:.92rem;line-height:1.5;color:#334155;background:#fffbeb;border:1px solid #fde68a;border-radius:8px}.info-banner code{font-size:.85em;background:#fef3c7;padding:.1em .35em;border-radius:4px}.topic-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1.25rem;margin-bottom:.75rem}.dialog-inline-toggle{display:inline-flex;align-items:center;gap:.45rem;font-size:.92rem;color:#334155;cursor:pointer;-webkit-user-select:none;user-select:none}.dialog-inline-toggle input{width:1rem;height:1rem;accent-color:#2563eb}.dialogue-turn{margin-bottom:.25rem}.dialogue-turn .vvv-content{margin-bottom:.2rem}.dialogue-inline-native{margin:0 0 .85rem 2.25rem;padding:0;font-size:.95rem;line-height:1.5;color:#475569;font-style:italic}.btn-print{padding:.45rem 1rem;font-size:.9rem;font-weight:500;color:#fff;background:#1e293b;border:none;border-radius:8px;cursor:pointer}.btn-print:hover:not(:disabled){background:#334155}.btn-print:disabled{opacity:.45;cursor:not-allowed}.print-sheet{max-width:52rem;margin:0 auto;padding:1rem 1.25rem 2rem;font-family:system-ui,sans-serif;color:#333}.print-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid #e2e8f0}.print-body{padding-top:.25rem}.print-title{margin:0 0 1rem;font-size:1.5rem;border-bottom:2px solid #333;padding-bottom:.5rem}.print-reading{font-size:1.05rem;line-height:1.6;margin-bottom:2rem}.print-reading h3{font-size:1.2rem;margin-top:1em;margin-bottom:.4em}.print-reading p{margin:0 0 .85em}.print-vocab-heading{font-size:1.15rem;margin:0 0 .75rem}.print-vocab-table{width:100%;border-collapse:collapse;table-layout:fixed;font-size:.9rem}.print-vocab-table th,.print-vocab-table td{border:1px solid #000;padding:8px;text-align:left;vertical-align:top;word-wrap:break-word}.print-vocab-table th{background:#eee}.btn-print-link{display:inline-block;text-align:center;text-decoration:none;color:#fff!important}.btn-print-link:hover{color:#fff!important;text-decoration:none}.btn-print-disabled{display:inline-block;opacity:.45;cursor:not-allowed;pointer-events:none}@media print{.no-print{display:none!important}body:has(.vocab-pack-print-scope) .app-header{display:none!important}body:has(.vocab-pack-print-scope) main{max-width:none;padding:.5rem .75rem}.vocab-pack-table{font-size:.75rem;border:1px solid #000;-webkit-print-color-adjust:exact;print-color-adjust:exact}.vocab-pack-table th,.vocab-pack-table td{border:1px solid #000!important;color:#000}.vocab-pack-table th{background:#d4d4d4!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.vocab-pack-table-wrap{border:1px solid #000;border-radius:0;-webkit-print-color-adjust:exact;print-color-adjust:exact}.vocab-pack-th-hint{color:#333!important}.vocab-pack-page-theme{border:1px solid #000;background:#eee!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.vocab-pack-scene{border:1px solid #000!important;background:#f5f5f5!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.vocab-pack-line dt{color:#222!important}}.topic-description{margin:0 0 .35rem;color:#475569;line-height:1.55}.topic-friction{margin:0 0 .75rem;color:#475569;font-size:.95rem;line-height:1.5}.topic-friction-label{font-weight:600;color:#334155}.topic-card-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:.3rem;align-items:flex-start}.topic-card-friction{font-size:.82rem;line-height:1.35;color:#64748b;font-weight:400}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:#f1f5f9}.login-page-inner{width:100%;max-width:22rem;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;padding:1.5rem 1.35rem;box-shadow:0 1px 2px #0f172a0f}.login-page-back{margin:0 0 1rem;font-size:.92rem}.login-page-title{margin:0 0 .5rem;font-size:1.35rem;font-weight:600}.login-page-lead{margin:0 0 1.25rem;color:#64748b;font-size:.95rem}.login-page-muted{margin:0;color:#94a3b8;font-size:.92rem}.login-page-error{margin:0 0 1rem;color:#b91c1c;font-size:.92rem}.login-page-form{margin:0}.login-page-submit{width:100%;padding:.55rem 1rem;font:inherit;font-weight:600;color:#fff;background:#2563eb;border:none;border-radius:.375rem;cursor:pointer}.login-page-submit:hover{background:#1d4ed8}.vocab-pack{max-width:56rem;margin:0 auto}.vocab-pack-tool{max-width:48rem;margin:0 auto}.vocab-pack-crumb{display:inline-flex;align-items:center;gap:.35rem;margin:0 0 2rem;font-size:.875rem;font-weight:500;color:#64748b;text-decoration:none;transition:color .2s ease}.vocab-pack-crumb:hover{color:#334155;text-decoration:none}.vocab-pack-crumb-arrow{display:inline-block;transition:transform .2s ease}.vocab-pack-crumb:hover .vocab-pack-crumb-arrow{transform:translate(-3px)}.vocab-pack-tool-title{margin:0 0 .75rem;font-size:1.75rem;font-weight:700;letter-spacing:-.02em;color:#0f172a}.vocab-pack-tool-lead{margin:0 0 2rem;font-size:1.125rem;line-height:1.6;color:#334155;max-width:none}.vocab-pack-signin-hint{font-size:1rem;color:#334155}.vocab-pack-quota-wrap{margin-bottom:2rem}.vocab-pack-quota-warn{margin:0 0 .75rem;padding:.75rem 1rem;font-size:.9rem;line-height:1.45;color:#9a3412;background:#fff7ed;border:1px solid #fed7aa;border-radius:.75rem}.vocab-pack-quota-info{padding:.85rem 1.1rem;background:#eff6ff;border:1px solid #dbeafe;border-radius:.75rem;font-size:.875rem;line-height:1.5;color:#1e40af}.vocab-pack-quota-info-label{font-weight:600;color:#1e3a8a}.vocab-pack-quota-info-text{font-weight:400;color:#1d4ed8}.vocab-pack-tool-form{display:flex;flex-direction:column;gap:2rem}.vocab-pack-segment{position:relative;display:flex;width:100%;background:#e2e8f0;border-radius:9999px;padding:4px;gap:0}.vocab-pack-segment-pill{position:absolute;top:4px;bottom:4px;left:4px;width:calc(50% - 6px);border-radius:9999px;background:#fff;box-shadow:0 1px 3px #0f172a14;transition:left .2s ease-in-out;z-index:0;pointer-events:none}.vocab-pack-segment[data-mode=photo] .vocab-pack-segment-pill{left:calc(50% + 2px)}.vocab-pack-segment-btn{position:relative;z-index:1;flex:1;margin:0;padding:.65rem .5rem;font:inherit;font-size:.9375rem;font-weight:600;color:#64748b;background:transparent;border:none;border-radius:9999px;cursor:pointer;transition:color .2s ease-in-out,transform .2s ease-in-out}.vocab-pack-segment-btn:hover:not(:disabled){color:#334155}.vocab-pack-segment-btn:disabled{opacity:.55;cursor:not-allowed}.vocab-pack-segment-btn--active{color:#0f172a}.vocab-pack-mode-help{margin:0;padding:.85rem 1rem;font-size:1.0625rem;line-height:1.6;color:#475569;background:#f8fafc;border:1px solid #e2e8f0;border-radius:.65rem}.vocab-pack-lang{display:flex;align-items:stretch;gap:.75rem}.vocab-pack-lang-icon-wrap{display:flex;align-items:center;justify-content:center;width:2.75rem;flex-shrink:0;color:#1e3a8a;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.5rem}.vocab-pack-lang-icon{width:1.35rem;height:1.35rem}.vocab-pack-lang-label{flex:1;display:flex;flex-direction:column;gap:.35rem;min-width:0}.vocab-pack-lang-text{font-size:.8125rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.vocab-pack-lang-select{width:100%;padding:.65rem .85rem;font:inherit;font-size:1rem;color:#0f172a;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}.vocab-pack-lang-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb40}.vocab-pack-lang-select:disabled{opacity:.6;cursor:not-allowed}.vocab-pack-field-label{display:flex;flex-direction:column;gap:.5rem}.vocab-pack-field-caption{font-size:.8125rem;font-weight:600;color:#64748b}.vocab-pack-textarea{width:100%;min-height:12rem;padding:.85rem 1rem;font-size:1rem;line-height:1.5;color:#0f172a;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;resize:vertical;transition:border-color .2s ease,box-shadow .2s ease}.vocab-pack-textarea--mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.vocab-pack-textarea::placeholder{color:#94a3b8}.vocab-pack-textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb40}.vocab-pack-textarea:disabled{opacity:.65;cursor:not-allowed}.vocab-pack-photo-block{display:flex;flex-direction:column;gap:1rem}.vocab-pack-file-input-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.vocab-pack-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;width:100%;min-height:11rem;padding:2rem 1.5rem;background:#f8fafc;border:2px dashed #cbd5e1;border-radius:1rem;cursor:pointer;font:inherit;text-align:center;color:#334155;transition:border-color .2s ease,background .2s ease,transform .2s ease}.vocab-pack-dropzone:hover:not(:disabled){border-color:#2563eb;background:#eff6ff}.vocab-pack-dropzone--active{border-color:#2563eb;background:#dbeafe}.vocab-pack-dropzone:disabled{opacity:.55;cursor:not-allowed}.vocab-pack-drop-icon{width:2.5rem;height:2.5rem;color:#1e3a8a}.vocab-pack-dropzone-title{font-size:1rem;font-weight:600;color:#0f172a}.vocab-pack-dropzone-hint{font-size:.8125rem;color:#64748b}.vocab-pack-previews{display:flex;flex-wrap:wrap;gap:.75rem}.vocab-pack-preview{margin:0;max-width:20rem;font-size:.75rem;color:#64748b}.vocab-pack-preview img{display:block;width:100%;height:auto;border-radius:6px;border:1px solid #e2e8f0}.vocab-pack-preview figcaption{margin-top:.25rem;word-break:break-all}.vocab-pack-checkbox{display:flex;align-items:flex-start;gap:.5rem;font-size:.9rem;font-weight:500;color:#334155;cursor:pointer}.vocab-pack-checkbox input{margin-top:.2rem;accent-color:#2563eb}.vocab-pack-error{margin:0;padding:.65rem .85rem;font-size:.9rem;color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem}.vocab-pack-submit{width:100%;padding:.9rem 1.25rem;font:inherit;font-size:1.05rem;font-weight:600;color:#fff;background:#2563eb;border:none;border-radius:.5rem;cursor:pointer;box-shadow:0 4px 14px #2563eb59;transition:background .2s ease,transform .2s ease,box-shadow .2s ease,opacity .2s ease}.vocab-pack-submit:hover:not(:disabled){background:#1d4ed8;transform:translateY(-2px);box-shadow:0 8px 20px #2563eb66}.vocab-pack-submit:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}@media(prefers-reduced-motion:reduce){.vocab-pack-submit:hover:not(:disabled){transform:none}}.vocab-pack-submit-inner{display:inline-flex;align-items:center;justify-content:center;gap:.6rem}.vocab-pack-spinner--btn{width:1.1rem;height:1.1rem;border-width:2px}.vocab-pack-muted{color:#94a3b8;text-align:center;padding:2rem}.vocab-pack-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1.25rem 0;color:#475569;font-size:.95rem}.vocab-pack-spinner{width:1.25rem;height:1.25rem;border:2px solid #e2e8f0;border-top-color:#2563eb;border-radius:50%;animation:vocab-pack-spin .7s linear infinite}@keyframes vocab-pack-spin{to{transform:rotate(360deg)}}.vocab-pack-page-theme{font-size:.92rem;color:#334155;margin:0 0 1rem;padding:.65rem .85rem;background:#f1f5f9;border-radius:8px;border:1px solid #e2e8f0}.vocab-pack-results h2{margin-top:0;font-size:1.2rem;color:#0f172a}.vocab-pack-results h3{margin-top:1.5rem;font-size:1.05rem;color:#0f172a}.vocab-pack-table-wrap{overflow-x:auto;border:1px solid #64748b;border-radius:8px}.vocab-pack-table{width:100%;border-collapse:collapse;font-size:.88rem;border:1px solid #64748b}.vocab-pack-table th,.vocab-pack-table td{border:1px solid #94a3b8;padding:.5rem .6rem;text-align:left;vertical-align:top}.vocab-pack-table th{background:#e2e8f0;font-weight:600}.vocab-pack-th-hint{display:block;margin-top:.2rem;font-weight:400;font-size:.78rem;color:#64748b}.vocab-pack-examples{margin:0;padding-left:1.1rem}.vocab-pack-scene{margin-bottom:1.25rem;padding:.75rem 1rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.vocab-pack-scene h4{margin:0 0 .5rem;font-size:1rem;color:#0f172a}.vocab-pack-scene-kind{font-weight:500;color:#64748b;font-size:.88rem}.vocab-pack-prose{margin:0}.vocab-pack-prose p{margin:0 0 .65rem;line-height:1.5;color:#334155}.vocab-pack-prose p:last-child{margin-bottom:0}.vocab-pack-lines{margin:0}.vocab-pack-line{display:grid;grid-template-columns:6rem 1fr;gap:.5rem;margin-bottom:.35rem}.vocab-pack-line dt{margin:0;font-weight:600;color:#64748b}.vocab-pack-line dd{margin:0;color:#334155}.vocab-pack-results-toolbar{margin-bottom:.75rem}
