﻿:root{--color-primary: #2d6a4f;--color-primary-dark: #1b4332;--color-primary-light: #40916c;--color-accent: #52b788;--color-accent-light: #95d5b2;--color-light-green: #d8f3dc;--color-very-light-green: #edf7f0;--color-beige: #f5f0e8;--color-beige-light: #faf6f0;--color-beige-warm: #e8ddd0;--color-paper: #fefcf9;--color-success: #2d6a4f;--color-danger: #c9184a;--color-danger-light: #ffe0e6;--color-warning: #e09f3e;--color-warning-light: #fff3d6;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-500: #6b7280;--color-gray-700: #374151;--color-gray-900: #111827;--radius: 8px;--radius-lg: 16px;--radius-xl: 20px;--shadow: 0 1px 3px rgba(0,0,0,0.08), 0 1px 2px rgba(0,0,0,0.04);--shadow-md: 0 4px 12px rgba(0,0,0,0.08);--shadow-lg: 0 16px 28px rgba(0,0,0,0.08)}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}img{max-width:100%;height:auto;display:block}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}*:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:4px}::selection{background:rgba(82,183,136,.2);color:var(--color-primary-dark)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:rgba(0,0,0,0)}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-500)}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}}body{font-family:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Segoe UI","Hiragino Kaku Gothic ProN",sans-serif;color:var(--color-gray-900);background:var(--color-beige-light);line-height:1.6;min-height:100vh;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--color-primary);text-decoration:none;transition:color .2s ease}a:hover{text-decoration:underline;color:var(--color-primary-dark)}.container{max-width:960px;margin:0 auto;padding:0 16px}.main-content{flex:1;padding:24px 16px}.app-main{min-height:80vh}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:.85rem;font-weight:600;color:var(--color-gray-700);margin-bottom:4px}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password],.form-group input[type=number],.form-group input[type=datetime-local],.form-group textarea,.form-group select{width:100%;padding:8px 12px;border:1px solid var(--color-gray-300);border-radius:var(--radius);font-size:.9rem;transition:border-color .2s ease,box-shadow .2s ease;background:#fff}.form-group input[type=text]:focus,.form-group input[type=email]:focus,.form-group input[type=password]:focus,.form-group input[type=number]:focus,.form-group input[type=datetime-local]:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(45,106,79,.12)}.form-group textarea{resize:vertical;min-height:120px}@media(max-width: 767px){.form-group input[type=text],.form-group input[type=email],.form-group input[type=password],.form-group textarea{font-size:16px}}.form-group__hint{font-size:.78rem;color:var(--color-gray-500);margin-top:4px}@keyframes skeleton-shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}.skeleton{position:relative;overflow:hidden;background:var(--color-gray-200);border-radius:var(--radius)}.skeleton::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.5), transparent);animation:skeleton-shimmer 1.5s ease-in-out infinite}@keyframes badge-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.app-header{background:#1b4332;padding:12px 0;border-bottom:1px solid hsla(0,0%,100%,.08);box-shadow:0 6px 16px rgba(27,67,50,.25);position:sticky;top:0;z-index:1000}.app-header__container{max-width:960px;margin:0 auto;padding:0 16px;display:flex;align-items:center;gap:24px}.app-header__brand{flex:0 0 auto}.app-header__logo{display:inline-flex;align-items:center;text-decoration:none;font-size:1.6rem;font-weight:800;color:#fff}.app-header__logo:hover{opacity:.9;text-decoration:none}.app-header__logo-image{height:60px;width:auto;max-width:180px;display:block}.app-header__logo-text{font-size:1.5rem;font-weight:800;letter-spacing:.01em;background:linear-gradient(135deg, #ffffff 0%, rgba(149, 213, 178, 0.9) 100%);-webkit-background-clip:text;-webkit-text-fill-color:rgba(0,0,0,0);background-clip:text}.app-header__menu-button{display:none;width:42px;height:42px;align-items:center;justify-content:center;flex-direction:column;gap:5px;border-radius:999px;border:1px solid hsla(0,0%,100%,.2);background:hsla(0,0%,100%,.12);cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.app-header__menu-button span{display:block;width:22px;height:3px;background:#fff;border-radius:999px;box-shadow:0 2px 6px rgba(27,67,50,.35)}.app-header__menu-button:hover{background:hsla(0,0%,100%,.2);border-color:hsla(0,0%,100%,.35)}.app-header__menu{display:flex;align-items:center;gap:24px;flex:1}.app-header__nav{display:flex;gap:8px;flex:1}.app-header__nav-item{position:relative;display:inline-flex;align-items:center}.app-header__nav-link{padding:8px 16px;color:hsla(0,0%,100%,.85);text-decoration:none;border-radius:6px;font-weight:600;transition:all .2s ease;border-bottom:2px solid rgba(0,0,0,0)}.app-header__nav-link:hover{background:hsla(0,0%,100%,.1);color:var(--color-accent-light);text-decoration:none}.app-header__nav-link--active{background:hsla(0,0%,100%,.18);color:#fff;font-weight:700;border-bottom:2px solid var(--color-accent)}.app-header__nav-link--with-caret{display:inline-flex;align-items:center;gap:8px}.app-header__nav-link--mobile-only{display:none}.app-header__nav-caret{width:8px;height:8px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);margin-bottom:2px}.app-header__nav-submenu{display:none}.app-header__nav-dropdown{position:absolute;top:calc(100% + 10px);left:0;min-width:320px;display:none;padding:16px;background:#fff;border-radius:14px;border:1px solid var(--color-gray-200);box-shadow:0 18px 36px rgba(27,67,50,.18);z-index:1002}.app-header__nav-dropdown::before{content:"";position:absolute;top:-10px;left:0;right:0;height:10px}.app-header__nav-item--study:hover .app-header__nav-dropdown,.app-header__nav-item--study:focus-within .app-header__nav-dropdown{display:block}.app-header__nav-dropdown-group+.app-header__nav-dropdown-group{margin-top:14px;padding-top:12px;border-top:1px solid var(--color-gray-100)}.app-header__nav-dropdown-label{font-size:.78rem;font-weight:700;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.app-header__nav-dropdown-item{display:block;padding:8px 12px;border-radius:10px;color:var(--color-gray-900);text-decoration:none;font-weight:600;transition:background-color .2s ease,color .2s ease}.app-header__nav-dropdown-item:hover{background:var(--color-very-light-green);color:var(--color-primary);text-decoration:none}.app-header__nav-submenu-group+.app-header__nav-submenu-group{padding-top:6px;border-top:1px solid rgba(148,163,184,.2)}.app-header__nav-submenu-label{font-size:.65rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--color-gray-500);margin-bottom:4px}.app-header__nav-submenu-item{display:block;padding:6px 8px;border-radius:10px;color:var(--color-primary-dark);text-decoration:none;font-weight:700;font-size:.92rem;transition:background-color .2s ease,color .2s ease}.app-header__nav-submenu-item:hover{background:var(--color-light-green);color:var(--color-primary-dark);text-decoration:none}.app-header__user{flex:0 0 auto}.app-header__user-menu{position:relative}.app-header__user-menu:hover .app-header__user-dropdown,.app-header__user-menu:focus-within .app-header__user-dropdown{display:block}.app-header__user-trigger{border:1px solid hsla(0,0%,100%,.2);background:hsla(0,0%,100%,.08);color:hsla(0,0%,100%,.9);padding:6px 12px;border-radius:999px;display:inline-flex;align-items:center;gap:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.app-header__user-trigger:hover{background:hsla(0,0%,100%,.16);border-color:hsla(0,0%,100%,.35)}.app-header__user-trigger:hover+.app-header__user-dropdown{display:block}.app-header__user-email{color:hsla(0,0%,100%,.75);font-size:.9rem}.app-header__user-dropdown{position:absolute;right:0;top:100%;margin-top:6px;background:#fff;border-radius:12px;border:1px solid var(--color-gray-200);box-shadow:var(--shadow-lg);padding:8px;display:none;min-width:180px;z-index:1001}.app-header__user-dropdown::before{content:"";position:absolute;top:-6px;left:0;right:0;height:6px}.app-header__user-dropdown:hover{display:block}.app-header__user-item{display:block;padding:8px 12px;border-radius:8px;color:var(--color-gray-900);text-decoration:none;font-weight:600;transition:background-color .2s ease,color .2s ease}.app-header__user-item:hover{background:var(--color-very-light-green);color:var(--color-primary);text-decoration:none}.app-header__user-item--danger{color:var(--color-danger)}.app-header__user-item--danger:hover{background:var(--color-danger-light);color:var(--color-danger)}.app-header__auth-links{display:flex;gap:8px}.app-header__auth-link{padding:8px 16px;color:hsla(0,0%,100%,.9);text-decoration:none;border-radius:6px;font-weight:600;transition:all .2s ease;border:1px solid rgba(0,0,0,0)}.app-header__auth-link:hover{background:hsla(0,0%,100%,.1);color:#fff;text-decoration:none}.app-header__auth-link--primary{background:rgba(82,183,136,.3);color:#fff;border-color:rgba(82,183,136,.5)}.app-header__auth-link--primary:hover{background:rgba(82,183,136,.45)}.app-header__backdrop{display:none}.app-header__nav-label--desktop{display:inline}.app-header__nav-label--mobile{display:none}.app-header__user-actions--mobile{display:none;flex-direction:column;gap:8px}@media(max-width: 767px){.app-header{padding:8px 0}.app-header .app-header__container{gap:12px}.app-header .app-header__logo-image{height:42px}.app-header .app-header__menu-button{display:inline-flex;margin-left:auto;border-radius:14px;background:rgba(27,67,50,.18);border-color:rgba(149,213,178,.6);box-shadow:0 10px 18px rgba(27,67,50,.28)}.app-header .app-header__menu-button span{width:18px;height:2px;box-shadow:none;background:#f8fafc}.app-header .app-header__menu{display:none;position:fixed;top:0;right:0;height:100vh;width:min(78vw,320px);flex-direction:column;align-items:stretch;justify-content:flex-start;gap:16px;padding:72px 20px calc(48px + env(safe-area-inset-bottom));background:var(--color-very-light-green);background-image:radial-gradient(8px 8px at 18% 20%, rgba(82, 183, 136, 0.08) 0 60%, rgba(237, 247, 240, 0) 62%),radial-gradient(10px 10px at 78% 28%, rgba(45, 106, 79, 0.06) 0 60%, rgba(237, 247, 240, 0) 62%),radial-gradient(12px 12px at 28% 76%, rgba(82, 183, 136, 0.05) 0 60%, rgba(237, 247, 240, 0) 62%),linear-gradient(145deg, rgba(216, 243, 220, 0.9), rgba(255, 255, 255, 0.95));box-shadow:-16px 0 30px rgba(27,67,50,.4);transform:translateX(100%);transition:transform .2s ease;z-index:1100;overflow-y:auto;overscroll-behavior:contain}.app-header.app-header--menu-open .app-header__menu{display:flex;transform:translateX(0)}.app-header .app-header__backdrop{display:block;position:fixed;inset:0;background:rgba(27,67,50,.45);opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:1050}.app-header.app-header--menu-open .app-header__backdrop{opacity:1;pointer-events:auto}.app-header .app-header__nav{flex-direction:column;gap:6px}.app-header .app-header__nav-item{display:block}.app-header .app-header__nav-submenu{display:flex;flex-direction:column;gap:8px;max-height:0;opacity:0;transform:translateY(-6px);overflow:hidden;padding:0 10px;margin-top:0;border-radius:12px;background:hsla(0,0%,100%,.7);border:1px solid rgba(0,0,0,0);box-shadow:0 10px 20px rgba(27,67,50,.08);pointer-events:none;transition:max-height .25s ease,opacity .2s ease,transform .25s ease,margin-top .25s ease,padding .25s ease,border-color .25s ease}.app-header .app-header__nav-item--study.is-open .app-header__nav-submenu{max-height:520px;opacity:1;transform:translateY(0);padding:8px 10px 6px;margin-top:6px;border-color:rgba(149,213,178,.3);pointer-events:auto}.app-header .app-header__nav-dropdown{display:none !important}.app-header .app-header__nav-link--with-caret{gap:6px}.app-header .app-header__nav-caret{display:none}.app-header .app-header__nav-link{display:flex;align-items:center;padding:10px 12px;font-size:.95rem;color:var(--color-primary-dark);background:hsla(0,0%,100%,.75);border:1px solid rgba(149,213,178,.25);border-bottom:2px solid rgba(0,0,0,0);width:100%}.app-header .app-header__nav-link:hover{background:var(--color-light-green);color:var(--color-primary-dark)}.app-header .app-header__nav-link--active{background:rgba(45,106,79,.12);color:var(--color-primary-dark);border-color:rgba(45,106,79,.35)}.app-header .app-header__nav-link--mobile-only{display:flex}.app-header .app-header__nav-label--mobile{display:inline}.app-header .app-header__nav-label--desktop{display:none}.app-header .app-header__user-email{display:none}.app-header .app-header__user-menu{display:none}.app-header .app-header__user-actions--mobile{display:flex}.app-header .app-header__auth-links{flex-direction:column;align-items:stretch}.app-header .app-header__auth-link{width:100%;text-align:center;color:var(--color-primary-dark);background:hsla(0,0%,100%,.8);border-color:rgba(149,213,178,.3)}.app-header .app-header__auth-link:hover{background:var(--color-light-green);color:var(--color-primary-dark)}.app-header .app-header__auth-link--primary{background:rgba(45,106,79,.12);color:var(--color-primary-dark);border-color:rgba(45,106,79,.35)}.app-header .app-header__auth-link--primary:hover{background:rgba(45,106,79,.18)}}.app-footer{background:linear-gradient(180deg, #1b4332 0%, #14342a 100%);color:hsla(0,0%,100%,.85);padding:32px 0 24px;margin-top:auto;border-top:1px solid hsla(0,0%,100%,.08)}.app-footer__container{max-width:960px;margin:0 auto;padding:0 16px;text-align:left;display:flex;flex-direction:column;gap:20px}.app-footer__content{display:grid;grid-template-columns:minmax(220px, 1fr) minmax(360px, 2.2fr);gap:48px}.app-footer__brand{display:flex;flex-direction:column;gap:12px;justify-content:flex-end}.app-footer__logo{width:160px;height:auto;display:block}.app-footer__logo-text{font-size:1.2rem;font-weight:800;color:#fff;letter-spacing:.01em}.app-footer__nav{display:grid;grid-template-columns:repeat(auto-fit, minmax(160px, 1fr));gap:24px 32px;font-weight:600;font-size:.95rem}.app-footer__nav-group{display:flex;flex-direction:column;gap:10px}.app-footer__nav-title{font-size:.85rem;text-transform:uppercase;letter-spacing:.16em;color:var(--color-accent)}.app-footer__link{color:hsla(0,0%,100%,.85);text-decoration:none;transition:color .2s ease,text-decoration-color .2s ease;width:fit-content}.app-footer__link:hover{color:#fff;text-decoration:underline;text-decoration-color:hsla(0,0%,100%,.7)}.app-footer__copyright{font-size:.95rem;letter-spacing:.02em;border-top:1px solid hsla(0,0%,100%,.08);padding-top:16px;text-align:center}@media(max-width: 767px){.app-footer .app-footer__content{grid-template-columns:1fr}.app-footer .app-footer__nav{grid-template-columns:1fr}}.flash{padding:12px 16px;border-radius:var(--radius);margin-bottom:16px;font-size:.9rem;font-weight:500;animation:fadeIn .3s ease}.flash--notice{background:var(--color-light-green);color:var(--color-primary-dark);border:1px solid var(--color-accent-light)}.flash--alert{background:var(--color-danger-light);color:#991b1b;border:1px solid #fecaca}.btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 20px;border-radius:var(--radius);font-size:.9rem;font-weight:600;border:none;cursor:pointer;transition:all .2s ease;text-decoration:none;line-height:1.4}.btn:hover{text-decoration:none}.btn--primary{background:linear-gradient(135deg, var(--color-accent), var(--color-primary));color:#fff;box-shadow:0 4px 12px rgba(45,106,79,.3)}.btn--primary:hover{background:linear-gradient(135deg, var(--color-primary-light), var(--color-primary-dark));transform:translateY(-1px);box-shadow:0 6px 16px rgba(45,106,79,.4)}.btn--outline{background:#fff;color:var(--color-gray-700);border:1px solid var(--color-gray-300)}.btn--outline:hover{background:var(--color-gray-100);border-color:var(--color-gray-500)}.btn--correct{background:var(--color-success);color:#fff}.btn--correct:hover{opacity:.9}.btn--wrong{background:var(--color-danger);color:#fff}.btn--wrong:hover{opacity:.9}.btn--sm{padding:4px 12px;font-size:.8rem}.btn--ghost{background:rgba(0,0,0,0);color:var(--color-primary);border:1px solid var(--color-primary)}.btn--ghost:hover{background:var(--color-very-light-green)}.progress-bar{height:8px;border-radius:999px;background:var(--color-gray-200);overflow:hidden}.progress-bar__fill{height:100%;border-radius:999px;background:linear-gradient(90deg, var(--color-accent), var(--color-primary));transition:width .4s ease}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.04em}.badge--primary{background:var(--color-very-light-green);color:var(--color-primary)}.badge--danger{background:var(--color-danger-light);color:var(--color-danger)}.badge--warning{background:var(--color-warning-light);color:#92400e}.empty-state{text-align:center;padding:48px 24px;color:var(--color-gray-500)}.empty-state__icon{font-size:2.5rem;margin-bottom:12px;opacity:.5}.empty-state__title{font-size:1.1rem;font-weight:700;color:var(--color-gray-700);margin-bottom:6px}.empty-state__text{font-size:.9rem;line-height:1.6}.home-exam{background:rgba(0,0,0,0);min-height:100vh}.home-exam__container{max-width:960px;margin:0 auto;padding:0 16px}.home-exam__hero{padding:122px 0 84px}.home-exam__hero--intro{position:relative;overflow:hidden;background:#fff;color:var(--color-gray-900)}.home-exam__hero--intro::before,.home-exam__hero--intro::after{content:"";position:absolute;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle, rgba(82, 183, 136, 0.18), rgba(255, 255, 255, 0));z-index:0}.home-exam__hero--intro::before{top:-180px;right:-140px}.home-exam__hero--intro::after{bottom:-220px;left:-120px;background:radial-gradient(circle, rgba(45, 106, 79, 0.16), rgba(255, 255, 255, 0))}.home-exam__hero-inner{position:relative;z-index:1;max-width:860px;margin:0 auto;text-align:center;display:flex;flex-direction:column;gap:18px}.home-exam__hero-title{font-size:clamp(2.2rem,3.4vw,3.6rem);font-weight:800;line-height:1.2;margin-bottom:20px;letter-spacing:.02em}.home-exam__hero-emphasis{display:inline-block;padding:0 6px;color:var(--color-primary);font-weight:800;position:relative}.home-exam__hero-emphasis::after{content:"";position:absolute;left:0;right:0;bottom:.1em;height:.35em;background:rgba(82,183,136,.25);border-radius:6px;z-index:-1}.home-exam__hero-lead{color:#1f2937;font-size:1.2rem;line-height:1.9;font-weight:600;display:grid;gap:6px;margin-top:2px;max-width:720px;margin-left:auto;margin-right:auto}.home-exam__hero-actions{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:8px;flex-wrap:wrap}.home-exam__hero-cta{padding:14px 48px;border-radius:999px;text-decoration:none;font-weight:700;font-size:1rem;border:none;transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease}.home-exam__hero-cta--primary{background:linear-gradient(90deg, #52b788, #2d6a4f);color:#fff;box-shadow:0 8px 20px -4px rgba(45,106,79,.4)}.home-exam__hero-cta--primary:hover{transform:translateY(-2px);box-shadow:0 12px 24px -4px rgba(45,106,79,.5);text-decoration:none}.home-exam__hero-cta--ghost{background:hsla(0,0%,100%,.9);color:#1e293b;box-shadow:0 4px 12px -2px rgba(0,0,0,.1)}.home-exam__hero-cta--ghost:hover{background:#fff;box-shadow:0 6px 16px -2px rgba(0,0,0,.15);text-decoration:none}.home-exam__hero-art{position:absolute;right:-40px;top:50%;transform:translateY(-50%) rotate(-3deg);width:min(520px,45vw);aspect-ratio:4/3;background:radial-gradient(120px 120px at 20% 30%, rgba(82, 183, 136, 0.12), transparent),radial-gradient(180px 180px at 80% 60%, rgba(45, 106, 79, 0.08), transparent),radial-gradient(100px 100px at 50% 80%, rgba(149, 213, 178, 0.1), transparent);border-radius:32px;border:1px solid rgba(149,213,178,.15);z-index:0;pointer-events:none;opacity:.6}.home-exam__definition{margin:6px 0 44px;text-align:center;max-width:900px;margin-left:auto;margin-right:auto}.home-exam__definition-title{font-size:clamp(1.7rem,2.2vw,2.3rem);font-weight:800;color:var(--color-gray-900);margin-bottom:14px;letter-spacing:.02em;position:relative;display:inline-block;padding-bottom:6px}.home-exam__definition-title::after{content:"";position:absolute;left:50%;bottom:-4px;width:72px;height:3px;background:var(--color-primary);transform:translateX(-50%)}.home-exam__definition-lead{color:#1f2937;font-size:clamp(1.1rem,1.6vw,1.35rem);line-height:1.9;font-weight:700;max-width:760px;margin:0 auto}.home-exam__learning{margin-top:8px;margin-bottom:36px;text-align:center;max-width:900px;margin-left:auto;margin-right:auto}.home-exam__title{font-size:2.2rem;font-weight:800;color:var(--color-gray-900);margin-bottom:12px;letter-spacing:.02em}.home-exam__lead{font-size:1.05rem;color:#475569;max-width:720px;line-height:1.9;margin-left:auto;margin-right:auto}.home-exam__eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:.75rem;font-weight:700;color:var(--color-primary);margin-bottom:10px}.home-exam__card--flow{position:relative;overflow:hidden;background:linear-gradient(140deg, rgba(216, 243, 220, 0.55), rgba(255, 255, 255, 0.98));border-radius:18px;padding:22px;border:1px solid var(--color-gray-200);box-shadow:var(--shadow-lg);margin-top:20px}.home-exam__card--flow::after{content:"";position:absolute;right:-80px;top:-60px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle, rgba(82, 183, 136, 0.18), rgba(255, 255, 255, 0));pointer-events:none}.home-exam__flow{list-style:none;padding:0;margin:0;position:relative;display:flex;flex-direction:column;gap:16px}.home-exam__flow::before{content:"";position:absolute;left:6px;top:0;bottom:0;width:90px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 720' preserveAspectRatio='none'%3E%3Cpath d='M60 0 C10 80 110 160 60 240 C10 320 110 400 60 480 C10 560 110 640 60 720' stroke='%232d6a4f' stroke-width='10' opacity='0.2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M60 0 C14 80 106 160 60 240 C14 320 106 400 60 480 C14 560 106 640 60 720' stroke='%2352b788' stroke-width='3' opacity='0.35' fill='none' stroke-dasharray='2 14' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:repeat-y;background-size:90px 100%;opacity:.85;pointer-events:none;z-index:0}.home-exam__flow-step{display:grid;grid-template-columns:1fr;gap:14px;align-items:flex-start;padding:32px 26px;border-radius:var(--radius-lg);background:linear-gradient(150deg, rgba(255, 255, 255, 0.98), rgba(245, 240, 232, 0.9));border:1px solid rgba(148,163,184,.4);box-shadow:0 14px 24px rgba(27,67,50,.08);position:relative;z-index:1;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.home-exam__flow-step:hover{transform:translateY(-2px);box-shadow:0 18px 32px rgba(27,67,50,.12);border-color:rgba(82,183,136,.4)}.home-exam__flow-step::before{content:"";position:absolute;inset:0;border-radius:var(--radius-lg);background:linear-gradient(120deg, rgba(82, 183, 136, 0.08), rgba(45, 106, 79, 0.06));opacity:0;transition:opacity .2s ease;pointer-events:none}.home-exam__flow-step:hover::before{opacity:1}.home-exam__flow-step--modal{cursor:pointer}.home-exam__flow-step:nth-child(even) .home-exam__flow-body{grid-template-columns:minmax(200px, 260px) minmax(0, 1fr)}.home-exam__flow-step:nth-child(even) .home-exam__flow-media{order:-1}.home-exam__flow-step:nth-child(even) .home-exam__flow-index{left:auto;right:20px}.home-exam__flow-step:nth-child(even) .home-exam__flow-copy{padding-left:0;padding-right:64px}.home-exam__flow-step--no-media .home-exam__flow-body{grid-template-columns:1fr}.home-exam__flow-step--no-media .home-exam__flow-index{left:auto;right:20px;color:rgba(45,106,79,.08);font-size:clamp(2.8rem,8vw,5.4rem)}.home-exam__flow-index{position:absolute;top:16px;left:20px;font-weight:800;font-size:clamp(3rem,9vw,5.6rem);letter-spacing:.08em;color:rgba(45,106,79,.12);z-index:0;line-height:1;pointer-events:none}.home-exam__flow-body{--flow-media-width: min(260px, 36vw);display:grid;grid-template-columns:minmax(0, 1fr) var(--flow-media-width);gap:14px;align-items:center;text-align:left;position:relative;z-index:1}.home-exam__flow-body--no-media{display:block;width:100%}.home-exam__flow-copy{display:grid;gap:6px;padding-left:120px;position:relative;z-index:1}.home-exam__flow-copy--no-media{padding-left:0;padding-right:0;max-width:none}.home-exam__flow-title{font-size:clamp(1.6rem,2.4vw,2.2rem);font-weight:800;color:var(--color-gray-900);margin-bottom:4px}.home-exam__flow-text{color:#475569;line-height:1.6}.home-exam__flow-media{margin:0;background:linear-gradient(135deg, rgba(248, 250, 252, 0.95), rgba(232, 221, 208, 0.7));border-radius:var(--radius-lg);border:1px solid rgba(148,163,184,.35);overflow:hidden;box-shadow:0 16px 26px rgba(27,67,50,.12);position:relative;z-index:2;height:120px}.home-exam__flow-media::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg, transparent 20%, rgba(255, 255, 255, 0.7) 45%, transparent 60%);transform:translateX(-120%);animation:home-exam-skeleton 2s ease-in-out infinite;opacity:.35;pointer-events:none}.home-exam__flow-media::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 20%, rgba(82, 183, 136, 0.1), transparent 55%);opacity:.6;pointer-events:none}.home-exam__flow-media.is-loaded::before,.home-exam__flow-media.is-loaded::after,.home-exam__flow-media.is-error::before,.home-exam__flow-media.is-error::after{animation:none;opacity:0}.home-exam__flow-image{display:block;width:100%;height:100%;object-fit:cover;opacity:0;filter:blur(8px);transform:scale(1.02);transition:opacity .55s ease,filter .6s ease,transform .6s ease;will-change:opacity,filter,transform}.home-exam__flow-media.is-loaded .home-exam__flow-image{opacity:1;filter:blur(0);transform:scale(1)}.home-exam__flow-media.is-error .home-exam__flow-image{opacity:0}.home-exam__flow-caption{padding:8px 12px;font-size:.75rem;font-weight:700;color:#1e293b;background:rgba(248,250,252,.95);border-top:1px solid rgba(226,232,240,.8)}@keyframes home-exam-skeleton{0%{transform:translateX(-120%)}100%{transform:translateX(120%)}}.home-exam__cta{margin:28px auto 0;max-width:880px}.home-exam__cta-card{background:linear-gradient(135deg, rgba(82, 183, 136, 0.12), rgba(45, 106, 79, 0.08));border:1px solid rgba(82,183,136,.25);border-radius:22px;padding:28px 32px;text-align:center;box-shadow:0 18px 32px rgba(27,67,50,.12)}.home-exam__cta-title{font-size:1.6rem;font-weight:800;color:var(--color-gray-900);margin-bottom:10px;letter-spacing:.02em}.home-exam__cta-lead{color:#475569;line-height:1.8;font-weight:600;margin-bottom:16px}.home-exam__cta-actions{display:flex;justify-content:center;margin-bottom:8px}.home-exam__cta-note{display:grid;gap:6px;margin:12px auto 0;color:#475569;font-weight:600;font-size:.98rem;line-height:1.7;text-align:center;max-width:720px}.home-exam__cta-note-accent{display:inline;color:var(--color-gray-900);font-weight:700;letter-spacing:.02em;text-decoration-line:underline;text-decoration-color:rgba(82,183,136,.7);text-decoration-thickness:3px;text-underline-offset:.28em}.home-exam__overview{margin-top:12px;padding:8px 0}.home-exam__overview-details{background:hsla(0,0%,100%,.7);border-radius:0;border:0;padding:18px 20px;box-shadow:none}.home-exam__overview-summary{position:relative;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0 18px;border-bottom:2px solid var(--color-gray-900);background:rgba(0,0,0,0)}.home-exam__overview-summary::before{content:"";position:absolute;left:0;bottom:0;width:72px;height:3px;background:var(--color-accent)}.home-exam__overview-body{margin-top:20px}.home-exam__overview-split{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:18px}.home-exam__overview-right{border-left:2px solid var(--color-gray-900);padding-left:32px}.home-exam__overview-section+.home-exam__overview-section{margin-top:22px;padding-top:22px;border-top:1px solid rgba(15,23,42,.2)}.home-exam__overview-title{font-size:1rem;font-weight:800;color:var(--color-gray-900);margin-bottom:10px}.home-exam__overview-grid{display:grid;grid-template-columns:1fr;gap:14px;padding:0;border:0}.home-exam__overview-item{padding:0}.home-exam__overview-label{font-size:.8rem;color:var(--color-gray-500);font-weight:700}.home-exam__overview-value{display:block;margin-top:8px;font-size:1.05rem;color:var(--color-gray-900)}.home-exam__overview-chip{display:inline-flex;align-items:center;padding:4px 0;border-radius:0;background:rgba(0,0,0,0);color:var(--color-gray-900);font-weight:700;font-size:.95rem;letter-spacing:.08em;text-transform:uppercase}.home-exam__section-title{font-size:1.6rem;font-weight:800;color:var(--color-gray-900);margin-bottom:6px;margin-top:4px;letter-spacing:.02em}.home-exam__columns{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:16px}.home-exam__label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-primary);margin-bottom:8px}.home-exam__list{padding-left:18px;color:#334155;line-height:1.7}.home-exam__text{color:#334155;line-height:1.7}.home-exam__link{color:var(--color-primary);font-weight:700;text-decoration:none}.home-exam__link:hover{text-decoration:underline}.home-exam__trust-title{font-size:1.3rem;font-weight:800;color:var(--color-gray-900);margin-bottom:16px}.home-exam__trust-grid{display:grid;grid-template-columns:1fr;gap:18px}.home-exam__trust-item{display:grid;gap:6px}.home-exam__trust-label{font-weight:700;color:#1e293b}.home-exam__features{margin:8px 0 48px;text-align:center;max-width:960px;margin-left:auto;margin-right:auto}.home-exam__features-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:20px;margin-top:28px}.home-exam__feature-card{background:#fff;border:1px solid var(--color-gray-200);border-radius:18px;padding:28px 22px;text-align:left;box-shadow:0 14px 24px rgba(27,67,50,.06);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;position:relative;overflow:hidden}.home-exam__feature-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg, var(--color-accent), var(--color-primary));opacity:0;transition:opacity .25s ease}.home-exam__feature-card:hover{transform:translateY(-4px);box-shadow:0 20px 36px rgba(27,67,50,.12);border-color:var(--color-accent-light)}.home-exam__feature-card:hover::before{opacity:1}.home-exam__feature-icon{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg, var(--color-very-light-green), var(--color-light-green));display:flex;align-items:center;justify-content:center;margin-bottom:16px;border:1px solid rgba(82,183,136,.2)}.home-exam__feature-icon-text{font-size:1.1rem;font-weight:800;color:var(--color-primary);letter-spacing:.04em}.home-exam__feature-title{font-size:1.2rem;font-weight:800;color:var(--color-gray-900);margin-bottom:8px}.home-exam__feature-desc{color:#475569;font-size:.92rem;line-height:1.7;margin-bottom:14px}.home-exam__feature-tags{list-style:none;display:flex;flex-wrap:wrap;gap:6px;padding:0;margin:0}.home-exam__feature-tags li{background:var(--color-beige);color:var(--color-primary-dark);font-size:.72rem;font-weight:700;padding:4px 10px;border-radius:999px;letter-spacing:.02em}.home-exam__subjects{margin:36px 0 48px;text-align:center;max-width:960px;margin-left:auto;margin-right:auto}.home-exam__subjects-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:16px;margin-top:28px}.home-exam__subject-card{background:#fff;border:1px solid var(--color-gray-200);border-radius:16px;padding:24px 20px;text-align:left;box-shadow:0 8px 18px rgba(27,67,50,.05);transition:transform .2s ease,box-shadow .2s ease;position:relative}.home-exam__subject-card:hover{transform:translateY(-2px);box-shadow:0 14px 26px rgba(27,67,50,.1)}.home-exam__subject-chip{display:inline-block;background:var(--color-very-light-green);color:var(--color-primary);font-size:.68rem;font-weight:800;padding:3px 10px;border-radius:999px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px}.home-exam__subject-title{font-size:1.15rem;font-weight:800;color:var(--color-gray-900);margin-bottom:6px}.home-exam__subject-desc{color:#475569;font-size:.88rem;line-height:1.7}@media(max-width: 767px){.home-exam__hero{padding:44px 0 32px}.home-exam__title{font-size:1.7rem}.home-exam__hero-title{font-size:2rem}.home-exam__lead{font-size:.95rem}.home-exam__hero-actions{gap:12px}.home-exam__overview-split{grid-template-columns:1fr}.home-exam__overview-right{border-left:0;border-top:2px solid var(--color-gray-900);padding-left:0;padding-top:20px}.home-exam__cta{margin-top:22px}.home-exam__cta-card{padding:22px 18px}.home-exam__cta-title{font-size:1.4rem}.home-exam__definition-title{font-size:1.5rem}.home-exam__flow-body{display:flex;flex-direction:column;grid-template-columns:1fr;gap:12px}.home-exam__flow-index{left:16px;font-size:clamp(2.4rem,12vw,3.4rem)}.home-exam__flow-step:nth-child(even) .home-exam__flow-index{left:16px;right:auto}.home-exam__flow-step:nth-child(even) .home-exam__flow-copy{padding-right:0;padding-left:64px;order:1}.home-exam__flow-copy{padding-left:64px}.home-exam__flow-step:nth-child(even) .home-exam__flow-body{display:flex;flex-direction:column}.home-exam__flow-step:nth-child(even) .home-exam__flow-media{order:2;width:100%}.home-exam__flow-media{height:auto;aspect-ratio:16/9;margin-top:6px;width:100%}.home-exam__flow-image{height:100%}.home-exam__flow-step--no-media .home-exam__flow-index{right:16px;left:auto}.home-exam__flow-copy--no-media{padding-right:0;padding-left:0}.home-exam__features-grid{grid-template-columns:1fr;gap:16px}.home-exam__subjects-grid{grid-template-columns:1fr}.home-exam__hero-art{width:min(420px,90vw);opacity:.22;right:50%;transform:translateX(50%) rotate(-1deg)}}.plan-page{min-height:100vh;background:linear-gradient(180deg, var(--color-beige) 0%, #ffffff 55%, var(--color-very-light-green) 100%)}.plan-hero{padding:40px 0 20px;background:radial-gradient(1200px 420px at 10% -20%, rgba(82, 183, 136, 0.2), rgba(255, 255, 255, 0) 60%);border-bottom:1px solid rgba(149,213,178,.2)}.plan-hero__inner{max-width:960px;margin:0 auto;padding:0 16px;display:flex;align-items:center;justify-content:space-between;gap:24px}.plan-hero__eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.75rem;font-weight:700;color:var(--color-primary);margin-bottom:6px}.plan-hero__title{font-size:2.2rem;font-weight:800;color:var(--color-primary-dark);margin:0 0 8px 0}.plan-hero__subtitle{color:#475569;margin:0}.plan-main{max-width:960px;margin:0 auto;padding:0 16px;padding:36px 16px 60px}.plan-grid{display:grid;grid-template-columns:repeat(3, minmax(0, 1fr));gap:20px}.plan-grid--pricing{grid-template-columns:repeat(2, minmax(0, 1fr))}.plan-grid--compact{gap:16px}.plan-card{background:#fff;border:1px solid var(--color-gray-200);border-radius:18px;padding:22px 20px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:16px;position:relative}.plan-card--starter{background:linear-gradient(180deg, #ffffff 0%, var(--color-beige-light) 100%)}.plan-card--accent{border-color:var(--color-accent-light);box-shadow:0 18px 32px rgba(45,106,79,.2)}.plan-card--recommended{border-width:2px}.plan-card--current{border-color:var(--color-primary);box-shadow:0 18px 32px rgba(45,106,79,.25)}.plan-card__badge{position:absolute;top:18px;right:18px;background:var(--color-primary);color:#fff;font-size:.7rem;letter-spacing:.12em;font-weight:800;text-transform:uppercase;padding:6px 10px;border-radius:999px}.plan-card__label{text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;font-weight:700;color:var(--color-gray-500);margin:0 0 6px 0}.plan-card__title{font-size:1.35rem;font-weight:800;margin:0 0 6px 0;color:var(--color-gray-900)}.plan-card__price{font-size:1.1rem;font-weight:700;color:var(--color-primary);margin:0}.plan-card__desc{color:var(--color-gray-500);margin:6px 0 0;font-size:.95rem}.plan-card__interval-toggle{display:inline-flex;gap:0;background:var(--color-gray-100);border-radius:6px;padding:3px;margin:10px 0 6px}.plan-card__interval-btn{appearance:none;border:none;background:rgba(0,0,0,0);font-size:.82rem;font-weight:700;color:var(--color-gray-500);padding:6px 18px;border-radius:4px;cursor:pointer;transition:background .2s,color .2s,box-shadow .2s}.plan-card__interval-btn:hover{color:var(--color-primary-dark)}.plan-card__interval-btn--active{background:#fff;color:var(--color-primary);box-shadow:0 2px 8px rgba(27,67,50,.1)}.plan-card__price-original{text-decoration:line-through;color:#94a3b8;font-weight:500;font-size:.88em;margin-right:6px}.plan-card__price-sub{font-size:.95rem;font-weight:700;color:var(--color-primary-dark);margin:6px 0 0;display:flex;align-items:center;gap:8px}.plan-card__monthly-equivalent{font-size:1.25rem;font-weight:800;color:var(--color-danger);letter-spacing:.02em}.plan-card__discount-badge{display:inline-block;background:var(--color-danger);color:#fff;font-size:.72rem;font-weight:800;padding:3px 10px;border-radius:999px;margin-left:2px;vertical-align:middle;letter-spacing:.04em;animation:badge-pulse 2s ease-in-out infinite}.plan-card__list{list-style:none;padding:0;margin:0;display:grid;gap:8px;color:#475569}.plan-card__list li{position:relative;padding-left:16px;line-height:1.5}.plan-card__list li::before{content:"";position:absolute;left:0;top:.6em;width:6px;height:6px;border-radius:999px;background:#94a3b8}.plan-card--accent .plan-card__list li::before,.plan-card--current .plan-card__list li::before{background:var(--color-primary)}.plan-card__cta{text-decoration:none;background:linear-gradient(90deg, var(--color-accent), var(--color-primary));color:#fff;font-weight:700;text-align:center;padding:14px 48px;border-radius:999px;border:none;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 8px 20px -4px rgba(45,106,79,.4);transition:transform .2s ease,box-shadow .2s ease}.plan-card__cta:hover{transform:translateY(-2px);box-shadow:0 12px 24px -4px rgba(45,106,79,.5);text-decoration:none}.plan-card__cta--ghost{background:hsla(0,0%,100%,.9);color:#1e293b;box-shadow:0 4px 12px -2px rgba(0,0,0,.1)}.plan-card__cta--ghost:hover{box-shadow:0 6px 16px -2px rgba(0,0,0,.15)}.plan-card__cta--muted{background:var(--color-gray-200);color:#475569;box-shadow:none}.plan-card__cta--muted:hover{transform:none;box-shadow:none}.plan-section{padding:26px 0}.plan-section__header{text-align:center;margin-bottom:32px}.plan-section__title{font-size:1.8rem;font-weight:800;color:var(--color-gray-900);margin:0 0 10px}.plan-section__subtitle{color:var(--color-gray-500);margin:0 auto;max-width:680px}.plan-section__subtitle-accent{font-size:1.1rem;display:inline;color:var(--color-gray-900);font-weight:700;letter-spacing:.02em;padding:0 4px;background:linear-gradient(transparent 60%, rgba(82, 183, 136, 0.2) 60%);box-decoration-break:clone;-webkit-box-decoration-break:clone}.plan-table{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-gray-200);background:#fff}.plan-table__row{display:grid;grid-template-columns:1.2fr .8fr .8fr;border-bottom:1px solid var(--color-gray-200)}.plan-table__row:last-child{border-bottom:none}.plan-table__row--head{background:var(--color-beige-light);font-weight:800;color:var(--color-gray-900)}.plan-table__cell{padding:14px 16px;color:#475569}.plan-table__cell--center{text-align:center}.plan-table__cell--accent{background:rgba(45,106,79,.08);color:var(--color-primary-dark);font-weight:700}.plan-preview{background:var(--color-beige);border-radius:28px;padding:48px 32px;box-shadow:inset 0 1px 0 rgba(148,163,184,.2)}.plan-preview__carousel{position:relative}.plan-preview__track{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:6px 2px 12px}.plan-preview__track::-webkit-scrollbar{display:none}.plan-preview__nav{position:absolute;top:50%;transform:translateY(-50%);border:0;width:36px;height:36px;border-radius:999px;background:#fff;color:#1e293b;box-shadow:0 12px 20px rgba(27,67,50,.18);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:1.2rem;z-index:2}.plan-preview__nav--prev{left:-10px}.plan-preview__nav--next{right:-10px}.plan-preview__card{background:#fff;border-radius:18px;border:1px solid var(--color-gray-200);overflow:hidden;box-shadow:0 14px 24px rgba(27,67,50,.08);flex:0 0 clamp(260px,78vw,420px);scroll-snap-align:start}.plan-preview__media{background:var(--color-gray-200);height:clamp(120px,22vw,160px);overflow:hidden;padding:0;border:0;cursor:zoom-in;width:100%;display:block;appearance:none}.plan-preview__media img{width:100%;height:100%;object-fit:cover}.plan-preview__body{padding:18px 20px 22px;color:#475569}.plan-preview__title{font-size:1.1rem;font-weight:800;color:var(--color-gray-900);margin:0 0 6px}.plan-preview__features{display:grid;grid-template-columns:repeat(2, 1fr);gap:18px}.plan-preview__feature{display:flex;gap:16px;align-items:flex-start;background:#fff;border-radius:14px;border:1px solid var(--color-gray-200);padding:20px;box-shadow:0 8px 18px rgba(27,67,50,.05);transition:transform .2s ease,box-shadow .2s ease}.plan-preview__feature:hover{transform:translateY(-2px);box-shadow:0 14px 26px rgba(27,67,50,.1)}.plan-preview__feature-icon{flex-shrink:0;width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg, var(--color-very-light-green), var(--color-light-green));display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:800;color:var(--color-primary);border:1px solid rgba(82,183,136,.15)}.plan-preview__feature-body{flex:1}.plan-preview__feature-body p{color:#475569;font-size:.88rem;line-height:1.6;margin:0}.plan-preview__feature-title{font-size:1rem;font-weight:800;color:var(--color-gray-900);margin:0 0 4px}.plan-lightbox{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:1200}.plan-lightbox[hidden]{display:none}.plan-lightbox__backdrop{position:absolute;inset:0;background:rgba(27,67,50,.2)}.plan-lightbox__panel{position:relative;background:#fff;border-radius:var(--radius-xl);padding:18px;max-width:min(960px,92vw);max-height:86vh;box-shadow:0 24px 48px rgba(27,67,50,.3);z-index:1;display:flex;flex-direction:column;gap:10px}.plan-lightbox__close{position:absolute;top:10px;right:12px;border:0;background:#fff;color:#1e293b;width:32px;height:32px;border-radius:999px;font-size:1.2rem;cursor:pointer;appearance:none;box-shadow:0 10px 18px rgba(27,67,50,.18);display:inline-flex;align-items:center;justify-content:center}.plan-lightbox__close:hover{background:var(--color-gray-100)}.plan-lightbox__image{max-width:100%;max-height:70vh;object-fit:contain;border-radius:12px;background:var(--color-beige-light)}.plan-lightbox__caption{margin:0;color:#475569;text-align:center;font-size:.9rem}.plan-faq{background:#fff;border-radius:var(--radius-xl);padding:32px 28px;box-shadow:0 16px 28px rgba(27,67,50,.06)}.plan-faq__list{display:flex;flex-direction:column;gap:14px}.plan-faq__row{padding:14px 0;border-bottom:1px solid rgba(148,163,184,.25)}.plan-faq__row:last-child{border-bottom:none}.plan-faq__question{font-weight:700;color:var(--color-gray-900);margin-bottom:6px}.plan-faq__answer{color:var(--color-gray-500)}.plan-cta{background:#fff;color:var(--color-gray-900);border-radius:24px;padding:52px 24px;text-align:center;margin-top:40px;box-shadow:0 18px 32px rgba(27,67,50,.06)}.plan-cta__inner{max-width:720px;margin:0 auto}.plan-cta h2{font-size:2rem;font-weight:800;margin:0 0 14px}.plan-cta p{margin:0 0 22px;color:var(--color-gray-500)}.plan-cta__button{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(90deg, var(--color-accent), var(--color-primary));color:#fff;font-weight:800;padding:14px 48px;border-radius:999px;border:none;text-decoration:none;box-shadow:0 8px 20px -4px rgba(45,106,79,.4);transition:transform .2s ease,box-shadow .2s ease}.plan-cta__button:hover{transform:translateY(-2px);box-shadow:0 12px 24px -4px rgba(45,106,79,.5);text-decoration:none}.plan-cta__note{display:block;margin-top:14px;color:var(--color-gray-500);font-size:.85rem}@media(max-width: 767px){.plan-hero__inner{flex-direction:column;align-items:flex-start}.plan-hero__title{font-size:1.6rem}.plan-grid{grid-template-columns:1fr}.plan-grid--pricing{grid-template-columns:1fr}.plan-table__row{grid-template-columns:1fr .7fr .7fr}.plan-preview{padding:32px 18px}.plan-preview__nav{display:none}.plan-preview__features{grid-template-columns:1fr}.plan-faq{padding:24px 20px}}.learnings-dashboard{min-height:100vh;--dash-ink: #1b4332;--dash-muted: #56657a;--dash-soft: #94a3b8;--dash-accent: #2d6a4f;--dash-accent-strong: #1b4332;--dash-surface: rgba(255, 255, 255, 0.92);--dash-surface-strong: #ffffff;--dash-border: rgba(27, 67, 50, 0.12);--dash-shadow: 0 18px 34px rgba(27, 67, 50, 0.08);background:radial-gradient(1200px 420px at 10% -10%, rgba(82, 183, 136, 0.18), rgba(255, 255, 255, 0) 60%),radial-gradient(900px 480px at 90% 0%, rgba(45, 106, 79, 0.14), rgba(255, 255, 255, 0) 65%),linear-gradient(180deg, #edf7f0 0%, #f8faf9 55%, #ffffff 100%);color:var(--dash-ink);position:relative;overflow:hidden}.learnings-hero{background:linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(237, 247, 240, 0.92));border-bottom:1px solid rgba(45,106,79,.15);padding:36px 0 28px;position:relative;overflow:hidden}.learnings-hero::before{content:"";position:absolute;top:-36px;right:-120px;width:340px;height:210px;background:linear-gradient(130deg, rgba(45, 106, 79, 0.18), rgba(82, 183, 136, 0.06));transform:skewX(-10deg);border-radius:32px}.learnings-hero::after{content:"";position:absolute;bottom:-110px;left:-70px;width:260px;height:260px;border-radius:999px;background:radial-gradient(circle at 30% 30%, rgba(82, 183, 136, 0.18), rgba(45, 106, 79, 0.02) 65%)}.learnings-hero__inner{max-width:960px;margin:0 auto;padding:0 16px;display:flex;align-items:center;justify-content:space-between;gap:28px;position:relative;z-index:1}@media(max-width: 767px){.learnings-hero__inner{flex-direction:column;align-items:flex-start}}.learnings-hero__text{max-width:560px}.learnings-hero__title{font-size:2.1rem;font-weight:800;color:var(--dash-ink);margin:0}.learnings-hero__panel{background:hsla(0,0%,100%,.92);border:1px solid rgba(45,106,79,.18);border-radius:20px;padding:18px 22px;min-width:240px;box-shadow:var(--dash-shadow);display:flex;flex-direction:column;gap:8px}@media(max-width: 767px){.learnings-hero__panel{width:100%}}.learnings-hero__panel-title{font-size:1.1rem;font-weight:800;color:var(--dash-accent-strong)}.learnings-hero__panel-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}.learnings-hero__panel-cta{align-self:flex-start;padding:8px 14px;font-size:.95rem}.dashboard-main{max-width:960px;margin:0 auto;padding:0 16px;padding:36px 0 80px}@media(max-width: 767px){.dashboard-main{padding:16px 0 32px}}.dashboard-split{display:grid;grid-template-columns:minmax(220px, 280px) minmax(0, 1fr);gap:24px;align-items:start}@media(max-width: 767px){.dashboard-split{grid-template-columns:1fr;gap:16px;padding:0 12px}}.dashboard-menu{position:sticky;top:120px;max-height:none;overflow:visible;background:hsla(0,0%,100%,.92);border:1px solid rgba(45,106,79,.15);border-radius:18px;padding:16px;box-shadow:0 16px 28px rgba(27,67,50,.08)}@media(max-width: 767px){.dashboard-menu{position:sticky;top:10px;max-height:none;padding:0;border-radius:0;box-shadow:none;background:rgba(0,0,0,0);border:none;z-index:2}}.dashboard-menu__title{font-size:1.05rem;font-weight:800;color:var(--dash-ink);margin-bottom:12px}.dashboard-menu__group{display:flex;flex-direction:column;gap:8px}.dashboard-menu__group:not(:last-child){padding-bottom:12px;margin-bottom:12px;border-bottom:1px dashed rgba(45,106,79,.15)}.dashboard-menu__label{font-size:.8rem;font-weight:700;color:var(--dash-muted);text-transform:uppercase;letter-spacing:.08em}.dashboard-menu__item{position:relative;text-align:left;display:block;width:100%;padding:10px 12px;border-radius:10px;border:1px solid rgba(0,0,0,0);background:rgba(248,250,252,.95);color:var(--dash-ink);text-decoration:none;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s ease;appearance:none}.dashboard-menu__item:hover{border-color:rgba(45,106,79,.35);background:rgba(237,247,240,.95);color:#1b4332}.dashboard-menu__item.is-active{background:#2d6a4f;color:#fff;border-color:#2d6a4f;box-shadow:0 10px 18px rgba(45,106,79,.2)}.dashboard-menu__label-full{display:inline}.dashboard-menu__label-short{display:none}.dashboard-menu__desktop{display:block}.dashboard-menu__mobile{border:none;padding:0;margin:0;display:none}.dashboard-menu__mobile-trigger{display:none;list-style:none;align-items:center;justify-content:space-between;gap:12px;width:100%;border:1px solid rgba(45,106,79,.25);border-radius:12px;padding:10px 12px;background:hsla(0,0%,100%,.95);color:var(--dash-ink);font-weight:700;font-size:.9rem;cursor:pointer;box-shadow:0 10px 18px rgba(27,67,50,.06)}.dashboard-menu__mobile-trigger::-webkit-details-marker{display:none}.dashboard-menu__mobile-trigger::marker{content:""}.dashboard-menu__mobile-caret{width:8px;height:8px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);flex-shrink:0;transition:transform .2s ease}.dashboard-menu__content{display:block}.dashboard-menu__modal{display:block}@media(max-width: 767px){.dashboard-menu__title{display:none}.dashboard-menu__group{display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:6px}.dashboard-menu__group:not(:last-child){padding-bottom:8px;margin-bottom:8px;border-bottom:1px dashed rgba(45,106,79,.15)}.dashboard-menu__label{grid-column:1/-1;margin-bottom:2px;font-size:.7rem;letter-spacing:.12em}.dashboard-menu__item{padding:6px 8px;border-radius:8px;font-size:.78rem;line-height:1.15;min-height:32px;text-align:center;white-space:normal}.dashboard-menu__label-full{display:inline}.dashboard-menu__label-short{display:none}.dashboard-menu__mobile-trigger{display:flex;position:sticky;top:10px;z-index:3}.dashboard-menu__desktop{display:none}.dashboard-menu__mobile{display:block}.dashboard-menu__content{display:none}.dashboard-menu__mobile[open] .dashboard-menu__mobile-caret{transform:rotate(-135deg)}.dashboard-menu__mobile[open] .dashboard-menu__mobile-trigger{position:fixed;top:12px;left:16px;right:16px;z-index:1201;box-shadow:0 14px 28px rgba(27,67,50,.2)}.dashboard-menu__mobile[open] .dashboard-menu__content{display:flex;position:fixed;inset:0;padding:72px 16px 24px;background:rgba(27,67,50,.35);z-index:1200;align-items:center;justify-content:center}.dashboard-menu__modal{background:#fff;border-radius:16px;padding:12px;max-height:calc(100vh - 120px);width:min(520px,100%);overflow-y:auto;box-shadow:0 16px 30px rgba(27,67,50,.2)}}.dashboard-detail{min-width:0;display:flex;flex-direction:column;gap:18px;padding:6px 0 36px}.dashboard-panel{display:none;background:#fff;border-radius:14px;border:1px solid rgba(45,106,79,.12);padding:24px 28px;box-shadow:0 10px 24px rgba(27,67,50,.06);position:relative;animation:dashPanelIn .3s ease}.dashboard-panel.is-active{display:block}.dashboard-panel__header{margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid rgba(45,106,79,.12)}.dashboard-panel__eyebrow{font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--dash-soft);margin-bottom:6px}.dashboard-panel__title{font-size:1.8rem;font-weight:800;color:var(--dash-ink);margin-bottom:6px}.dashboard-panel__subtitle{color:var(--dash-muted);font-size:1rem}.dashboard-panel__body{display:flex;flex-direction:column;gap:0}@media(max-width: 767px){.dashboard-panel{padding:16px 14px;border-radius:12px}.dashboard-panel__title{font-size:1.4rem}}@keyframes dashPanelIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes dashRise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.dashboard-panel.is-active .dashboard-section,.dashboard-panel.is-active .dashboard-card,.dashboard-panel.is-active .resume-item,.dashboard-panel.is-active .summary-card{animation:dashRise .5s ease both}.dashboard-panel.is-active .summary-card:nth-child(2){animation-delay:.04s}.dashboard-panel.is-active .summary-card:nth-child(3){animation-delay:.08s}.dashboard-panel.is-active .summary-card:nth-child(4){animation-delay:.12s}.dashboard-panel.is-active .dashboard-card:nth-child(2){animation-delay:.05s}.dashboard-panel.is-active .dashboard-card:nth-child(3){animation-delay:.1s}.dashboard-panel.is-active .dashboard-card:nth-child(4){animation-delay:.15s}@media(prefers-reduced-motion: reduce){.dashboard-panel.is-active,.dashboard-panel.is-active .dashboard-section,.dashboard-panel.is-active .dashboard-card,.dashboard-panel.is-active .resume-item,.dashboard-panel.is-active .summary-card{animation:none}}.dashboard-section{display:flex;flex-direction:column;gap:12px;padding:20px 0;border-top:1px solid rgba(45,106,79,.1);position:relative}.dashboard-section:first-child{border-top:none;padding-top:0}.dashboard-section__header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.dashboard-section__title{font-size:1.1rem;font-weight:800;color:var(--dash-ink);margin:0}.dashboard-section__meta{font-size:.85rem;font-weight:700;color:var(--dash-muted)}.dashboard-section__desc{color:var(--dash-muted);font-size:.95rem;line-height:1.6}.dashboard-section__empty{color:var(--dash-soft);font-size:.9rem;padding:12px 0}.dashboard-section--summary{border-top:none;padding:14px 0 18px;border-bottom:1px solid rgba(45,106,79,.1)}.dashboard-section--chart{padding:18px 0 18px;border-top:none;border-bottom:1px solid rgba(45,106,79,.1)}.dashboard-section--resume{padding:14px 0 18px;border-top:none;border-bottom:1px solid rgba(45,106,79,.1)}.dashboard-section--goals{padding:14px 0 18px}@media(max-width: 767px){.dashboard-section{gap:8px;padding:14px 0}.dashboard-section__title{font-size:.95rem}.dashboard-section__meta{font-size:.78rem}}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));gap:14px}.summary-card{background:rgba(0,0,0,0);border-radius:0;padding:10px 0 10px 14px;border:none;box-shadow:none;display:flex;flex-direction:column;gap:6px;position:relative;border-left:1px solid rgba(45,106,79,.15)}.summary-card:first-child{border-left:none;padding-left:0}.summary-card__label{font-size:.95rem;font-weight:800;color:#1b4332}.summary-card__value{font-size:1.9rem;font-weight:800;color:#1b4332;display:flex;align-items:baseline;gap:6px}.summary-card__unit{font-size:1.05rem;font-weight:700;color:#1b4332}@media(max-width: 767px){.summary-grid{grid-template-columns:repeat(2, minmax(0, 1fr));gap:10px}.summary-card{padding:8px 0 8px 10px;gap:4px}.summary-card__label{font-size:.85rem}.summary-card__value{font-size:1.4rem}.summary-card__unit{font-size:.9rem}}.resume-list{display:flex;flex-direction:column;gap:12px;margin-top:0}.resume-item{display:grid;grid-template-columns:150px 1fr auto;align-items:center;gap:16px;padding:16px 0;border-radius:0;border:none;background:rgba(0,0,0,0);box-shadow:none;border-top:1px solid rgba(45,106,79,.12);transition:background .2s ease}.resume-item:first-child{border-top:none;padding-top:6px}.resume-item:hover{background:rgba(45,106,79,.02)}.resume-item__subject{font-weight:800;color:#1b4332;font-size:1.1rem}.resume-item__content{display:flex;flex-direction:column;gap:8px}.resume-item__detail{color:var(--dash-ink);font-size:1.12rem}.resume-item__progress{display:flex;align-items:center;gap:12px}.resume-item__progress-bar{flex:1;height:10px;background:#e2e8f0;border-radius:999px;overflow:hidden}.resume-item__progress-bar span{display:block;height:100%;background:linear-gradient(90deg, #2d6a4f, #52b788);border-radius:999px}.resume-item__progress-label{font-size:.92rem;color:var(--dash-muted);min-width:72px;text-align:right}.resume-item__action{color:#fff;font-weight:800;text-decoration:none;padding:10px 18px;border:1px solid rgba(45,106,79,.35);border-radius:999px;background:#2d6a4f;font-size:1.02rem;box-shadow:none;transition:all .2s ease}.resume-item__action:hover{background:#1b4332;border-color:rgba(82,183,136,.6);transform:translateY(-1px)}.resume-item.is-disabled{opacity:.6}.resume-item.is-disabled .resume-item__action{border-color:#e2e8f0;background:#f8fafc;color:#94a3b8}@media(max-width: 767px){.resume-item{display:grid;grid-template-columns:1fr auto;grid-template-areas:"subject subject" "detail action" "progress progress";gap:6px 10px;padding:8px 0}.resume-item__content{display:contents}.resume-item__subject{grid-area:subject;font-size:.95rem}.resume-item__detail{grid-area:detail;font-size:.9rem;align-self:center;padding-right:6px}.resume-item__progress{grid-area:progress;flex-direction:column;align-items:stretch;gap:4px}.resume-item__progress-bar{height:6px}.resume-item__progress-label{min-width:0;text-align:center}.resume-item__action{grid-area:action;justify-self:end;width:auto;text-align:center;padding:8px 12px;font-size:.92rem}}.goal-period{margin-top:16px}.goal-period:first-child{margin-top:0}.goal-period__title{font-size:.95rem;font-weight:800;color:var(--dash-ink);margin:0 0 12px 0}.goal-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:14px}.goal-card{background:hsla(0,0%,100%,.8);border:1px solid rgba(45,106,79,.12);border-radius:14px;padding:14px 16px;display:flex;flex-direction:column;gap:10px}.goal-card__head{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.goal-card__label{font-size:.9rem;font-weight:800;color:#1b4332}.goal-card__value{font-size:.85rem;font-weight:700;color:var(--dash-muted)}.goal-card__bar{background:#e2e8f0;border-radius:999px;height:8px;overflow:hidden}.goal-card__bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg, #2d6a4f, #52b788);transition:width .4s ease}.goal-card__bar span.is-complete{background:linear-gradient(90deg, #2d6a4f, #40916c)}@media(max-width: 767px){.goal-grid{grid-template-columns:1fr;gap:10px}.goal-card{padding:10px 12px;border-radius:10px}.goal-card__label{font-size:.85rem}.goal-card__value{font-size:.8rem}}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));gap:18px}.dashboard-card{background:rgba(0,0,0,0);border:none;border-top:1px solid rgba(45,106,79,.18);border-radius:0;padding:18px 0 0;box-shadow:none;display:flex;flex-direction:column;gap:14px}.dashboard-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.dashboard-card__eyebrow{font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--dash-soft)}.dashboard-card__title{font-size:1.2rem;font-weight:800;color:var(--dash-ink);margin:6px 0 0 0}.dashboard-card__badge{font-size:.75rem;font-weight:700;padding:6px 10px;border-radius:999px;background:rgba(45,106,79,.12);color:#1b4332;border:1px solid rgba(45,106,79,.2)}.dashboard-card__body{display:flex;flex-direction:column;gap:12px}.dashboard-card__desc{color:var(--dash-muted);font-size:.92rem}.dashboard-card__actions{display:flex;gap:10px;flex-wrap:wrap}.learnings-dashboard .action-btn{display:inline-flex;align-items:center;justify-content:center;background:#2d6a4f;color:#fff;font-weight:800;border:1px solid rgba(45,106,79,.35);border-radius:999px;padding:10px 18px;font-size:1rem;text-decoration:none;cursor:pointer;box-shadow:0 10px 18px rgba(45,106,79,.15);transition:all .2s ease}.learnings-dashboard .action-btn:hover{background:#1b4332;border-color:rgba(82,183,136,.6);transform:translateY(-1px)}.learnings-dashboard .action-btn:disabled{background:#e2e8f0;border-color:#e2e8f0;color:#94a3b8;box-shadow:none;cursor:not-allowed}.learnings-dashboard .action-btn--ghost{background:hsla(0,0%,100%,.95);color:#1b4332;box-shadow:none}.learnings-dashboard .action-btn--ghost:hover{background:rgba(237,247,240,.95)}.learnings-dashboard .action-btn--sm{padding:6px 14px;font-size:.9rem}.subject-progress{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.subject-progress__bar-wrap{flex:1;min-width:200px;display:flex;flex-direction:column;gap:6px}.subject-progress__bar{height:10px;background:#e2e8f0;border-radius:999px;overflow:hidden}.subject-progress__bar span{display:block;height:100%;background:linear-gradient(90deg, #2d6a4f, #52b788);border-radius:999px;transition:width .4s ease}.subject-progress__label{font-size:.92rem;font-weight:700;color:var(--dash-muted)}@media(max-width: 767px){.subject-progress{flex-direction:column;align-items:stretch}.subject-progress__bar-wrap{min-width:0}}.year-grid{display:flex;flex-wrap:wrap;gap:8px}.year-btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;border-radius:10px;border:1px solid rgba(45,106,79,.2);background:hsla(0,0%,100%,.95);color:var(--dash-ink);font-size:.9rem;font-weight:700;text-decoration:none;transition:all .2s ease}.year-btn:hover{border-color:rgba(45,106,79,.45);background:rgba(237,247,240,.95);color:#1b4332;transform:translateY(-1px);box-shadow:0 8px 16px rgba(45,106,79,.12)}@media(max-width: 767px){.year-grid{gap:6px}.year-btn{padding:6px 12px;font-size:.82rem;border-radius:8px}}.weekly-chart__controls{display:flex;align-items:center;gap:12px}.weekly-chart__ranges{display:flex;gap:4px;background:rgba(45,106,79,.06);border-radius:8px;padding:3px}.weekly-chart__range-btn{appearance:none;border:none;background:rgba(0,0,0,0);color:var(--dash-muted);font-size:.82rem;font-weight:700;padding:5px 12px;border-radius:6px;cursor:pointer;transition:all .2s ease}.weekly-chart__range-btn:hover{color:var(--dash-ink);background:rgba(45,106,79,.08)}.weekly-chart__range-btn.is-active{background:#2d6a4f;color:#fff;box-shadow:0 2px 8px rgba(45,106,79,.2)}.weekly-chart__range-label{font-size:.82rem;font-weight:700;color:var(--dash-muted)}.weekly-chart__section-label{font-size:.82rem;font-weight:700;color:var(--dash-soft);text-transform:uppercase;letter-spacing:.06em;margin:12px 0 6px}.weekly-chart__container{position:relative;height:220px;width:100%}.weekly-chart__container canvas{width:100% !important;height:100% !important;transition:opacity .3s ease}.weekly-chart__container--secondary{height:180px;margin-top:8px}.weekly-chart__empty{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--dash-soft);font-size:.9rem;font-weight:700;background:hsla(0,0%,100%,.7);border-radius:10px}.weekly-chart__skeleton{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:center;padding:20px 16px}.weekly-chart__skeleton-bars{display:flex;align-items:flex-end;gap:12px;width:100%;height:100%}.weekly-chart__skeleton-bar{flex:1;height:var(--h, 50%);background:linear-gradient(180deg, rgba(82, 183, 136, 0.12), rgba(45, 106, 79, 0.06));border-radius:4px 4px 0 0;animation:skeletonPulse 1.5s ease-in-out infinite}.weekly-chart__skeleton-lines{width:100%;height:100%;display:flex;align-items:center}.weekly-chart__skeleton-svg{width:100%;height:80%;color:rgba(82,183,136,.2);animation:skeletonPulse 1.5s ease-in-out infinite}@keyframes skeletonPulse{0%,100%{opacity:.4}50%{opacity:1}}.weekly-chart__footer{display:flex;align-items:center;gap:18px;padding:10px 0 0;margin-top:4px;border-top:1px dashed rgba(45,106,79,.12)}.weekly-chart__footer-item{font-size:.85rem;font-weight:700;color:var(--dash-muted)}.weekly-chart__footer-item span{font-weight:800;color:var(--dash-ink)}@media(max-width: 767px){.weekly-chart__controls{flex-direction:column;align-items:flex-start;gap:6px}.weekly-chart__range-btn{padding:4px 10px;font-size:.78rem}.weekly-chart__container{height:180px}.weekly-chart__container--secondary{height:150px}.weekly-chart__footer{flex-wrap:wrap;gap:10px}.weekly-chart__footer-item{font-size:.8rem}}.training__header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:16px}.training__header h1{font-size:1.25rem;color:var(--color-primary-dark)}.training__progress{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}.training__dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;background:var(--color-gray-200);color:var(--color-gray-700);transition:all .2s ease}.training__dot--correct{background:var(--color-light-green);color:var(--color-primary-dark)}.training__dot--wrong{background:var(--color-danger-light);color:#991b1b}.training__dot--current{outline:2px solid var(--color-primary);outline-offset:2px}.problem{background:var(--color-paper);border:1px solid var(--color-gray-200);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}.problem__number{font-size:.85rem;color:var(--color-gray-500);margin-bottom:8px}.problem__text{font-size:1rem;line-height:1.8;margin-bottom:20px}.problem__choices{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.problem__choice-btn{width:48px;height:48px;border-radius:50%;font-size:1.1rem;font-weight:600;background:#fff;border:2px solid var(--color-gray-300);cursor:pointer;transition:all .2s ease}.problem__choice-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.problem__history{margin-top:16px;padding-top:12px;border-top:1px solid var(--color-gray-200)}.problem__history h4{font-size:.85rem;color:var(--color-gray-500);margin-bottom:6px}.problem__history ul{list-style:none;font-size:.85rem}.choices__header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:16px}.choices__header h1{font-size:1.25rem;color:var(--color-primary-dark)}.choices__filters{background:var(--color-paper);border:1px solid var(--color-gray-200);border-radius:var(--radius);padding:12px 16px;margin-bottom:16px}.choices__filter-form{display:flex;flex-wrap:wrap;align-items:center;gap:12px}.choices__filter-group{display:flex;align-items:center;gap:4px;font-size:.85rem}.choices__filter-group select{padding:4px 8px;border-radius:4px;border:1px solid var(--color-gray-300);font-size:.85rem}.choices__info{font-size:.85rem;color:var(--color-gray-500);margin-bottom:12px}.choice-card{background:var(--color-paper);border:1px solid var(--color-gray-200);border-radius:var(--radius);padding:16px;margin-bottom:12px;box-shadow:var(--shadow);transition:border-color .2s ease}.choice-card:hover{border-color:var(--color-accent-light)}.choice-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.choice-card__label{font-size:.8rem;color:var(--color-gray-500);font-weight:500}.choice-card__bookmark{cursor:pointer;font-size:1.2rem;color:var(--color-gray-300);transition:color .2s ease}.choice-card__bookmark--active{color:var(--color-warning)}.choice-card__text{font-size:.95rem;line-height:1.7;margin-bottom:12px}.choice-card__actions{display:flex;gap:8px}.choice-card__history{margin-top:8px;display:flex;gap:4px}.choice-card__history-dot{font-size:.75rem;padding:2px 6px;border-radius:4px}.choice-card__history-dot.correct{background:var(--color-light-green);color:var(--color-primary-dark)}.choice-card__history-dot.wrong{background:var(--color-danger-light);color:#991b1b}.choices__pagination{display:flex;justify-content:center;gap:12px;margin-top:16px}.finished{text-align:center;padding:48px 16px;background:var(--color-paper);border-radius:var(--radius-lg);border:1px solid var(--color-gray-200);box-shadow:var(--shadow-md)}.finished h2{margin-bottom:8px;color:var(--color-primary-dark)}.finished p{color:var(--color-gray-500);margin-bottom:20px}.finished__actions{display:flex;justify-content:center;gap:12px}.drill-start{max-width:720px;margin:0 auto;padding:32px 16px}.drill-start__header{text-align:center;margin-bottom:32px}.drill-start__header h1{font-size:1.8rem;font-weight:800;color:var(--color-primary-dark);margin-bottom:8px}.drill-start__header p{color:var(--color-gray-500)}.drill-start__form{background:var(--color-paper);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-md)}.drill-start__law-list{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.drill-start__law-item{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius);border:1px solid var(--color-gray-200);background:#fff;cursor:pointer;transition:all .2s ease;font-weight:600}.drill-start__law-item:hover{border-color:var(--color-accent);background:var(--color-very-light-green)}.drill-start__law-item input[type=checkbox]{accent-color:var(--color-primary);width:18px;height:18px}.drill-start__options{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:16px;margin-bottom:24px;padding-top:20px;border-top:1px solid var(--color-gray-200)}.drill-start__options label{font-size:.85rem;font-weight:600;color:var(--color-gray-700);margin-bottom:6px;display:block}.drill-start__options select,.drill-start__options input[type=number]{width:100%;padding:8px 12px;border:1px solid var(--color-gray-300);border-radius:var(--radius);font-size:.9rem;transition:border-color .2s ease,box-shadow .2s ease}.drill-start__options select:focus,.drill-start__options input[type=number]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(45,106,79,.12)}.drill-step{max-width:800px;margin:0 auto;padding:24px 16px}.drill-step__header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid var(--color-gray-200)}.drill-step__header-progress{font-size:.9rem;font-weight:700;color:var(--color-primary)}.drill-step__header-actions{display:flex;gap:8px}.drill-step__question{background:var(--color-paper);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow);margin-bottom:20px}.drill-step__question-number{font-size:.8rem;font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}.drill-step__question-text{font-size:1.05rem;line-height:1.8;color:var(--color-gray-900)}.drill-step__blank{background:var(--color-very-light-green);border:2px dashed var(--color-accent-light);border-radius:var(--radius);padding:16px;margin:16px 0;text-align:center}.drill-step__blank input{padding:10px 20px;border:2px solid var(--color-accent-light);border-radius:var(--radius);font-size:1rem;font-weight:600;text-align:center;min-width:200px;transition:border-color .2s ease,box-shadow .2s ease}.drill-step__blank input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(45,106,79,.15)}.drill-step__answer{background:var(--color-light-green);border:1px solid var(--color-accent-light);border-radius:var(--radius);padding:16px 20px;margin-bottom:20px}.drill-step__answer--correct{background:var(--color-light-green);border-color:var(--color-accent)}.drill-step__answer--wrong{background:var(--color-danger-light);border-color:#fca5a5}.drill-step__actions{display:flex;justify-content:center;gap:12px;margin-top:24px}.drill-view{max-width:800px;margin:0 auto;padding:24px 16px}.drill-view__header{margin-bottom:24px}.drill-view__header h1{font-size:1.5rem;font-weight:800;color:var(--color-primary-dark)}.drill-view__list{display:flex;flex-direction:column;gap:16px}.drill-view__item{background:var(--color-paper);border:1px solid var(--color-gray-200);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);transition:border-color .2s ease}.drill-view__item:hover{border-color:var(--color-accent-light)}.drill-view__item-number{font-size:.8rem;font-weight:700;color:var(--color-primary);margin-bottom:8px}.drill-view__item-text{font-size:.95rem;line-height:1.7;margin-bottom:12px}.drill-finish{max-width:600px;margin:0 auto;padding:48px 16px;text-align:center}.drill-finish__icon{font-size:3rem;margin-bottom:16px}.drill-finish__title{font-size:1.8rem;font-weight:800;color:var(--color-primary-dark);margin-bottom:8px}.drill-finish__subtitle{color:var(--color-gray-500);margin-bottom:32px}.drill-finish__stats{display:grid;grid-template-columns:repeat(auto-fit, minmax(140px, 1fr));gap:16px;margin-bottom:32px}.drill-finish__stat-card{background:var(--color-paper);border:1px solid var(--color-gray-200);border-radius:var(--radius);padding:20px 16px;box-shadow:var(--shadow)}.drill-finish__stat-card-label{font-size:.8rem;color:var(--color-gray-500);font-weight:600;margin-bottom:4px}.drill-finish__stat-card-value{font-size:1.8rem;font-weight:800;color:var(--color-primary)}.drill-finish__stat-card--success .drill-finish__stat-card-value{color:var(--color-success)}.drill-finish__stat-card--danger .drill-finish__stat-card-value{color:var(--color-danger)}.drill-finish__actions{display:flex;justify-content:center;gap:12px}.devise-page{min-height:calc(100vh - 200px);display:flex;align-items:center;justify-content:center;padding:40px 16px;background:radial-gradient(600px 400px at 30% 20%, rgba(82, 183, 136, 0.06), transparent),radial-gradient(500px 300px at 70% 80%, rgba(45, 106, 79, 0.04), transparent)}.devise-form{max-width:440px;width:100%;margin:0 auto;background:var(--color-paper);border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);padding:36px 32px;box-shadow:0 20px 40px rgba(27,67,50,.08)}.devise-form h2{font-size:1.4rem;font-weight:800;color:var(--color-primary-dark);margin-bottom:24px;text-align:center}.devise-form .btn--primary{width:100%;padding:12px;font-size:1rem}.devise-form__header{text-align:center;margin-bottom:24px}.devise-form__title{font-size:1.5rem;font-weight:800;color:var(--color-primary-dark);margin:0 0 6px}.devise-form__subtitle{color:var(--color-gray-500);font-size:.92rem;margin:0}.devise-form__body{display:flex;flex-direction:column;gap:0}.devise-form__submit{width:100%;padding:12px;font-size:1rem;margin-top:8px}.devise-form__social{display:flex;flex-direction:column;gap:10px}.devise-form__social-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px 16px;border-radius:var(--radius);font-size:.92rem;font-weight:700;cursor:pointer;transition:all .2s ease;text-decoration:none;border:1px solid var(--color-gray-300)}.devise-form__social-btn--google{background:#fff;color:var(--color-gray-700)}.devise-form__social-btn--google:hover{background:var(--color-gray-50);border-color:var(--color-gray-500);box-shadow:0 4px 12px rgba(0,0,0,.08);text-decoration:none}.devise-form__social-btn--apple{background:#000;color:#fff;border-color:#000}.devise-form__social-btn--apple:hover{background:#1a1a1a;box-shadow:0 4px 12px rgba(0,0,0,.2);text-decoration:none}.devise-form__social-icon{flex-shrink:0}.devise-form__divider{display:flex;align-items:center;gap:14px;margin:20px 0;color:var(--color-gray-500);font-size:.8rem;font-weight:600}.devise-form__divider::before,.devise-form__divider::after{content:"";flex:1;height:1px;background:var(--color-gray-200)}.devise-form__remember{display:flex;align-items:center;gap:8px;margin:8px 0 12px;font-size:.85rem;color:var(--color-gray-700)}.devise-form__remember input[type=checkbox]{accent-color:var(--color-primary);width:16px;height:16px}.devise-form__remember label{cursor:pointer}.devise-form__links{margin-top:20px;text-align:center;font-size:.85rem;display:flex;flex-direction:column;gap:8px}.devise-form__links a{color:var(--color-primary)}.devise-form__link{color:var(--color-gray-500);text-decoration:none;transition:color .2s ease}.devise-form__link:hover{color:var(--color-primary);text-decoration:underline}.devise-form__link--accent{color:var(--color-primary);font-weight:600}.devise-form__link--accent:hover{color:var(--color-primary-dark)}.devise-form__links-separator{display:block;height:1px;background:var(--color-gray-200);margin:4px 0}.devise-form__terms{margin-top:16px;text-align:center;font-size:.78rem;color:var(--color-gray-500);line-height:1.6}.devise-form__terms a{color:var(--color-primary);text-decoration:underline;text-decoration-color:rgba(82,183,136,.4)}.devise-form__flash{border-radius:var(--radius);padding:12px 14px;margin-bottom:20px;font-weight:700;font-size:.9rem;line-height:1.55}.devise-form__flash--alert{background:rgba(254,242,242,.96);border:1px solid rgba(248,113,113,.45);color:#b91c1c}.devise-form__flash--notice{background:rgba(236,253,245,.96);border:1px solid rgba(82,183,136,.35);color:#065f46}.devise-form__field-error{margin:6px 0 0;color:#b91c1c;font-size:.82rem;font-weight:700;line-height:1.45}.devise-form__input--invalid{border-color:rgba(248,113,113,.85) !important;background:rgba(254,242,242,.55) !important}.devise-form__errors{background:var(--color-danger-light);border:1px solid #fecaca;border-radius:var(--radius);padding:14px 16px;margin-bottom:16px}.devise-form__errors-title{font-weight:700;color:#991b1b;font-size:.85rem;margin-bottom:8px}.devise-form__errors-list{list-style:none;padding:0;margin:0;font-size:.85rem;color:#991b1b;display:flex;flex-direction:column;gap:4px}.devise-form__errors-list li::before{content:"- "}@media(max-width: 767px){.devise-form{padding:28px 20px}}.static-page{padding:0}.static-page__hero{padding:40px 0 24px;background:linear-gradient(135deg, rgba(82, 183, 136, 0.08), rgba(45, 106, 79, 0.04));border-bottom:1px solid var(--color-gray-200)}.static-page__hero-inner{max-width:960px;margin:0 auto;padding:0 16px}.static-page__hero-eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.75rem;font-weight:700;color:var(--color-primary);margin-bottom:6px}.static-page__hero-title{font-size:2rem;font-weight:800;color:var(--color-primary-dark);margin:0}.static-page__content{max-width:960px;margin:0 auto;padding:0 16px;padding:32px 16px 48px}.static-page__card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-gray-200);box-shadow:0 16px 28px rgba(27,67,50,.06);padding:36px 32px}.static-page__section{margin-bottom:32px}.static-page__section+.static-page__section{padding-top:24px;border-top:1px solid var(--color-gray-200)}.static-page__section-title{font-size:1.15rem;font-weight:700;color:var(--color-primary-dark);margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--color-gray-200)}.static-page__text{color:#374151;line-height:1.8;margin-bottom:12px}.static-page__list{color:#374151;line-height:1.8;padding-left:1.5em;display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.static-page__contact-form{display:flex;flex-direction:column;gap:16px;max-width:600px}.static-page__contact-form .form-group input:focus,.static-page__contact-form .form-group textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(45,106,79,.12)}.static-page__faq-list{display:flex;flex-direction:column;gap:14px}.static-page__faq-row{padding:14px 0;border-bottom:1px solid rgba(148,163,184,.25)}.static-page__faq-row:last-child{border-bottom:none}.static-page__faq-question{font-weight:700;color:var(--color-primary-dark);margin-bottom:6px}.static-page__faq-answer{color:#475569;line-height:1.7}.static-page__table{width:100%;border-collapse:collapse;margin-bottom:16px}.static-page__table th,.static-page__table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--color-gray-200);font-size:.95rem}.static-page__table th{background:var(--color-beige-light);font-weight:700;color:var(--color-primary-dark)}.static-page__table td{color:#374151}.static-tokushoho__list{display:flex;flex-direction:column;gap:0}.static-tokushoho__item{display:grid;grid-template-columns:200px 1fr;gap:16px;padding:16px 0;border-bottom:1px solid var(--color-gray-200)}.static-tokushoho__item:last-child{border-bottom:none}.static-tokushoho__term{font-weight:600;color:var(--color-primary-dark);font-size:.95rem}.static-tokushoho__desc{color:#374151;line-height:1.7}.static-tokushoho__desc a{color:var(--color-primary);text-decoration:underline}.static-tokushoho__desc a:hover{color:var(--color-primary-dark)}.static-policy{display:flex;flex-direction:column;gap:32px;margin-top:24px}.static-policy__section{display:flex;flex-direction:column;gap:12px}.static-policy__heading{font-size:1.15rem;font-weight:700;color:var(--color-primary-dark);padding-bottom:8px;border-bottom:2px solid var(--color-gray-200)}.static-policy__text{color:#374151;line-height:1.8}.static-policy__list{color:#374151;line-height:1.8;padding-left:1.5em;display:flex;flex-direction:column;gap:8px}.static-policy__footer{margin-top:16px;padding-top:24px;border-top:1px solid var(--color-gray-200)}.static-policy__dates{display:flex;justify-content:flex-end;gap:16px}.static-policy__date{color:var(--color-gray-500);font-size:.9rem}.static-faq{display:flex;flex-direction:column}.static-faq__category{font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:var(--color-primary);padding:14px 0 8px;margin-top:28px;border-bottom:2px solid var(--color-light-green)}.static-faq__category:first-child{margin-top:0}.static-faq__item{padding:16px 0;border-bottom:1px solid rgba(148,163,184,.2)}.static-faq__item:last-child{border-bottom:none}.static-faq__question{font-size:1rem;font-weight:700;color:var(--color-gray-900);margin-bottom:6px;line-height:1.5}.static-faq__answer{color:#475569;line-height:1.7;font-size:.95rem}.static-faq__answer a{color:var(--color-primary);font-weight:600;text-decoration:underline;text-decoration-color:rgba(82,183,136,.4);text-underline-offset:.15em}.static-faq__answer a:hover{text-decoration-color:var(--color-primary)}@media(max-width: 640px){.static-tokushoho__item{grid-template-columns:1fr;gap:8px}.static-page__card{padding:24px 18px}}.learning-history{min-height:100vh;background:radial-gradient(circle at top, var(--color-very-light-green) 0%, #f8faf9 50%, #ffffff 100%)}.learning-history__hero{background:linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 100%);color:#fff;padding:36px 0 28px;position:relative;overflow:hidden}.learning-history__hero::before{content:"";position:absolute;top:-40px;right:-120px;width:280px;height:180px;background:linear-gradient(135deg, rgba(82, 183, 136, 0.3), rgba(149, 213, 178, 0.05));transform:skewX(-12deg);border-radius:28px}.learning-history__hero::after{content:"";position:absolute;bottom:-60px;left:-80px;width:200px;height:200px;border-radius:999px;background:radial-gradient(circle at 30% 30%, rgba(149, 213, 178, 0.25), rgba(82, 183, 136, 0.03) 65%)}.learning-history__hero-inner{max-width:960px;margin:0 auto;padding:0 16px;display:flex;align-items:center;justify-content:space-between;gap:24px;position:relative;z-index:1}@media(max-width: 767px){.learning-history__hero-inner{flex-direction:column;align-items:flex-start}}.learning-history__hero-text{animation:lh-rise .5s ease both;animation-delay:.05s}.learning-history__title{font-size:2rem;font-weight:800;margin-bottom:6px;color:#fff}.learning-history__subtitle{font-size:.95rem;color:hsla(0,0%,100%,.8)}.learning-history__hero-chip{background:hsla(0,0%,100%,.15);backdrop-filter:blur(8px);border:1px solid hsla(0,0%,100%,.25);padding:10px 18px;border-radius:999px;font-weight:700;font-size:.88rem;color:#fff;box-shadow:0 8px 16px rgba(27,67,50,.15);animation:lh-rise .5s ease both;animation-delay:.1s}.learning-history__content{max-width:960px;margin:0 auto;padding:0 16px;padding:36px 0 60px;display:flex;flex-direction:column;gap:36px}@media(max-width: 767px){.learning-history__content{padding:24px 16px 48px}}.learning-history__section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:20px;animation:lh-rise .5s ease both;animation-delay:.12s}@media(max-width: 767px){.learning-history__section-head{flex-direction:column;align-items:flex-start}}.learning-history__section-title{font-size:1.35rem;font-weight:800;color:var(--color-primary-dark);margin-bottom:4px}.learning-history__section-subtitle{font-size:.9rem;color:var(--color-gray-500);max-width:520px}.learning-history__overview{background:var(--color-paper);border-radius:var(--radius-xl);padding:28px;border:1px solid var(--color-gray-200);box-shadow:0 16px 28px rgba(27,67,50,.08)}.learning-history__kpi-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));gap:14px}.learning-history__kpi-card{background:var(--color-very-light-green);border:1px solid var(--color-light-green);border-radius:var(--radius-lg);padding:18px 20px;transition:transform .2s ease,box-shadow .2s ease;animation:lh-rise .5s ease both}.learning-history__kpi-card:nth-child(1){animation-delay:.06s}.learning-history__kpi-card:nth-child(2){animation-delay:.1s}.learning-history__kpi-card:nth-child(3){animation-delay:.14s}.learning-history__kpi-card:nth-child(4){animation-delay:.18s}.learning-history__kpi-card:nth-child(5){animation-delay:.22s}.learning-history__kpi-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(45,106,79,.12)}.learning-history__kpi-label{font-size:.85rem;color:var(--color-gray-500);font-weight:700;margin-bottom:8px}.learning-history__kpi-value{font-size:1.8rem;font-weight:800;color:var(--color-primary-dark);margin-bottom:4px;line-height:1.2}.learning-history__kpi-unit{font-size:.85rem;color:var(--color-gray-500);margin-left:4px;font-weight:400}.learning-history__kpi-note{font-size:.82rem;color:var(--color-gray-500)}.learning-history__trend-section{animation:lh-rise .5s ease both;animation-delay:.13s}.learning-history__trend-kpi-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.learning-history__trend-kpi{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border-radius:999px;background:var(--color-very-light-green);border:1px solid var(--color-light-green);font-size:.85rem;font-weight:700;color:var(--color-gray-700)}.learning-history__trend-kpi strong{font-size:1.1rem;font-weight:800;color:var(--color-primary-dark)}.learning-history__trend-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:16px}.learning-history__trend-card{background:var(--color-paper);border-radius:var(--radius-lg);border:1px solid var(--color-gray-200);padding:18px;box-shadow:var(--shadow);min-height:240px}.learning-history__trend-card canvas{width:100% !important;height:180px !important}.learning-history__trend-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:14px}.learning-history__trend-header h3{font-size:1rem;font-weight:800;color:var(--color-primary-dark)}.learning-history__trend-header span{font-size:.8rem;color:var(--color-gray-500);font-weight:700}.learning-history__chart-skeleton{background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius);min-height:180px;display:flex;align-items:center;justify-content:center;overflow:hidden}.learning-history__chart-skeleton[hidden]{display:none}.learning-history__chart-skeleton-inner{width:80%;height:100px;background:linear-gradient(90deg, var(--color-gray-200) 25%, var(--color-gray-100) 50%, var(--color-gray-200) 75%);background-size:200% 100%;animation:lh-skeleton-shimmer 1.5s ease-in-out infinite;border-radius:var(--radius)}.learning-history__subjects-section{animation:lh-rise .5s ease both;animation-delay:.14s}.learning-history__progress-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));gap:14px}.learning-history__progress-card{background:var(--color-paper);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:18px 20px;box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease}.learning-history__progress-card:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(45,106,79,.1)}.learning-history__progress-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.learning-history__progress-head h3{font-size:.95rem;font-weight:700;color:var(--color-gray-700)}.learning-history__progress-rate{font-size:1.1rem;font-weight:800;color:var(--color-primary)}.learning-history__progress-bar{height:8px;background:var(--color-gray-200);border-radius:999px;overflow:hidden;margin-bottom:8px}.learning-history__progress-bar span{display:block;height:100%;background:linear-gradient(90deg, var(--color-accent), var(--color-primary));border-radius:999px;transition:width .6s ease}.learning-history__progress-count{font-size:.82rem;color:var(--color-gray-500)}.learning-history__subject-detail{animation:lh-rise .5s ease both;animation-delay:.16s}.learning-history__summary-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));gap:14px}.learning-history__summary-card{background:var(--color-paper);border-radius:var(--radius-lg);padding:18px 20px;border:1px solid var(--color-gray-200);box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease;animation:lh-rise .5s ease both}.learning-history__summary-card:nth-child(1){animation-delay:.06s}.learning-history__summary-card:nth-child(2){animation-delay:.1s}.learning-history__summary-card:nth-child(3){animation-delay:.14s}.learning-history__summary-card:nth-child(4){animation-delay:.18s}.learning-history__summary-card:nth-child(5){animation-delay:.22s}.learning-history__summary-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(45,106,79,.1)}.learning-history__summary-label{font-size:.85rem;color:var(--color-gray-500);font-weight:700;margin-bottom:8px}.learning-history__summary-value{font-size:1.8rem;font-weight:800;color:var(--color-primary);margin-bottom:4px}.learning-history__summary-unit{font-size:.85rem;color:var(--color-gray-500);margin-left:4px}.learning-history__summary-note{font-size:.82rem;color:var(--color-gray-500)}.learning-history__goals-section{animation:lh-rise .5s ease both;animation-delay:.18s}.learning-history__goals-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));gap:14px}.learning-history__goal-card{background:var(--color-paper);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease}.learning-history__goal-card:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(45,106,79,.1)}.learning-history__goal-label{font-size:.85rem;color:var(--color-gray-500);font-weight:700;margin-bottom:6px}.learning-history__goal-value{font-size:1.15rem;font-weight:700;color:var(--color-gray-700);margin-bottom:10px}.learning-history__goal-percent{font-size:.82rem;font-weight:700;color:var(--color-primary);margin-top:6px}.learning-history__drills-section{animation:lh-rise .5s ease both;animation-delay:.2s}.learning-history__table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-lg);border:1px solid var(--color-gray-200);box-shadow:0 12px 24px rgba(27,67,50,.08)}.learning-history__table{width:100%;border-collapse:collapse;background:var(--color-paper)}.learning-history__table th{background:var(--color-primary-dark);color:#fff;font-size:.85rem;font-weight:700;padding:14px 16px;text-align:left;white-space:nowrap}.learning-history__table th:first-child{border-top-left-radius:var(--radius-lg)}.learning-history__table th:last-child{border-top-right-radius:var(--radius-lg)}.learning-history__table td{padding:12px 16px;font-size:.88rem;color:var(--color-gray-700);border-bottom:1px solid var(--color-gray-200)}.learning-history__table tbody tr:last-child td{border-bottom:none}.learning-history__table tbody tr{transition:background .15s ease}.learning-history__table tbody tr:hover{background:var(--color-very-light-green)}.learning-history__drill-type{display:inline-block;padding:2px 8px;border-radius:999px;background:var(--color-light-green);color:var(--color-primary-dark);font-size:.8rem;font-weight:700}.learning-history__accuracy-badge{display:inline-block;padding:2px 10px;border-radius:999px;font-size:.85rem;font-weight:700}.learning-history__accuracy-badge.is-high{background:var(--color-light-green);color:var(--color-primary-dark)}.learning-history__accuracy-badge.is-mid{background:var(--color-warning-light);color:#92400e}.learning-history__accuracy-badge.is-low{background:var(--color-danger-light);color:var(--color-danger)}.learning-history__hero{animation:lh-panel-in .45s ease}@keyframes lh-panel-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes lh-skeleton-shimmer{0%{background-position:-200% 0;opacity:.6}50%{opacity:1}100%{background-position:200% 0;opacity:.6}}@keyframes lh-rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@media(max-width: 640px){.learning-history__title{font-size:1.5rem}.learning-history__overview{padding:20px 16px}.learning-history__kpi-grid,.learning-history__progress-grid,.learning-history__summary-grid,.learning-history__goals-grid,.learning-history__trend-grid{grid-template-columns:1fr}.learning-history__kpi-value,.learning-history__summary-value{font-size:1.4rem}.learning-history__table th,.learning-history__table td{padding:8px 10px;font-size:.82rem}}@media(max-width: 400px){.learning-history__kpi-grid,.learning-history__progress-grid,.learning-history__summary-grid,.learning-history__goals-grid{grid-template-columns:1fr}}@media(prefers-reduced-motion: reduce){.learning-history__hero,.learning-history__hero-text,.learning-history__hero-chip,.learning-history__section-head,.learning-history__overview,.learning-history__kpi-card,.learning-history__summary-card,.learning-history__subjects-section,.learning-history__subject-detail,.learning-history__goals-section,.learning-history__drills-section,.learning-history__trend-section{animation:none}.learning-history__chart-skeleton-inner{animation:none}}.admin-layout{background:var(--color-gray-100)}.admin-nav{background:var(--color-primary-dark);color:#fff;padding:12px 24px;display:flex;align-items:center;gap:24px;flex-wrap:wrap}.admin-nav__brand a{color:#fff;font-weight:700;font-size:1rem;text-decoration:none}.admin-nav__links{list-style:none;display:flex;gap:16px;flex-wrap:wrap}.admin-nav__links a{color:var(--color-accent-light);font-size:.85rem;text-decoration:none;transition:color .2s ease}.admin-nav__links a:hover{color:#fff}.admin-nav__user{margin-left:auto;font-size:.8rem;color:var(--color-accent-light)}.admin-nav__user a{color:var(--color-accent-light);margin-left:8px}.admin-content{max-width:1100px;margin:24px auto;padding:0 24px}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:16px;margin-bottom:24px}.admin-stats__card{background:#fff;border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);border-top:3px solid var(--color-primary)}.admin-stats__card h3{font-size:.85rem;color:var(--color-gray-500);margin-bottom:4px}.admin-stats__number{font-size:1.5rem;font-weight:700;color:var(--color-primary-dark)}.admin-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin-bottom:16px}.admin-table th,.admin-table td{padding:10px 14px;text-align:left;font-size:.85rem;border-bottom:1px solid var(--color-gray-200)}.admin-table th{background:var(--color-beige-light);font-weight:600;color:var(--color-gray-700)}.admin-table td a{font-weight:500;color:var(--color-primary)}.admin-filters{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;background:#fff;padding:12px 16px;border-radius:var(--radius);box-shadow:var(--shadow)}.admin-filters select,.admin-filters input{padding:6px 10px;border:1px solid var(--color-gray-300);border-radius:4px;font-size:.85rem}.admin-detail dl{display:grid;grid-template-columns:120px 1fr;gap:8px 16px;margin-bottom:20px}.admin-detail dt{font-size:.85rem;color:var(--color-gray-500);font-weight:500}.admin-detail dd{font-size:.9rem}.articles-index{min-height:80vh}.articles-index__inner{max-width:960px;margin:0 auto;padding:0 16px;max-width:1080px;padding-top:8px;padding-bottom:48px}.articles-index__hero{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:stretch;margin-bottom:40px;padding:36px 0 32px;border-bottom:1px solid var(--color-gray-200)}.articles-index__hero-content{display:flex;flex-direction:column;justify-content:center;gap:8px}.articles-index__eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.7rem;font-weight:700;color:var(--color-primary)}.articles-index__title{font-size:clamp(1.8rem,3vw,2.4rem);font-weight:800;color:var(--color-gray-900);line-height:1.2;letter-spacing:.02em}.articles-index__subtitle{font-size:.95rem;color:var(--color-gray-500);line-height:1.7;margin-top:4px}.articles-index__filter{display:inline-flex;align-items:center;background:var(--color-very-light-green);color:var(--color-primary-dark);font-size:.85rem;font-weight:600;padding:6px 14px;border-radius:999px;margin-top:4px;width:fit-content}.articles-index__hero-actions{display:flex;gap:8px;margin-top:8px}.articles-index__chip{display:inline-flex;align-items:center;padding:4px 12px;background:var(--color-gray-100);color:var(--color-gray-700);font-size:.78rem;font-weight:600;border-radius:999px}.articles-index__hero-panel{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-gray-200);padding:28px 28px 24px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:10px;transition:box-shadow .2s ease}.articles-index__hero-panel:hover{box-shadow:var(--shadow-md)}.articles-index__featured-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--color-primary)}.articles-index__featured-title{font-size:1.25rem;font-weight:800;line-height:1.4;margin:0}.articles-index__featured-title a{color:var(--color-gray-900);text-decoration:none}.articles-index__featured-title a:hover{color:var(--color-primary);text-decoration:none}.articles-index__featured-summary{font-size:.88rem;color:var(--color-gray-500);line-height:1.7;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.articles-index__featured-meta{font-size:.78rem;color:var(--color-gray-500);display:flex;align-items:center;gap:6px;margin-top:auto}.articles-index__featured-cta{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;font-weight:700;color:var(--color-primary);text-decoration:none;margin-top:4px}.articles-index__featured-cta::after{content:"→"}.articles-index__featured-cta:hover{text-decoration:underline}.articles-index__list{display:grid;grid-template-columns:repeat(auto-fill, minmax(300px, 1fr));gap:20px}.articles-index__card{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--radius);padding:22px 24px 18px;display:flex;flex-direction:column;gap:8px;transition:box-shadow .2s ease,border-color .2s ease,transform .2s ease}.articles-index__card:hover{box-shadow:var(--shadow-md);border-color:var(--color-accent-light);transform:translateY(-2px)}.articles-index__meta{font-size:.78rem;color:var(--color-gray-500);display:flex;align-items:center;gap:6px}.articles-index__meta-sep{color:var(--color-gray-300)}.articles-index__meta-link{color:var(--color-primary);font-weight:600;text-decoration:none}.articles-index__meta-link:hover{text-decoration:underline}.articles-index__card-title{font-size:1.05rem;font-weight:700;line-height:1.5;margin:0}.articles-index__card-title a{color:var(--color-gray-900);text-decoration:none}.articles-index__card-title a:hover{color:var(--color-primary);text-decoration:none}.articles-index__card-summary{font-size:.85rem;color:var(--color-gray-500);line-height:1.7;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.articles-index__card-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:auto;padding-top:10px;border-top:1px solid var(--color-gray-100)}.articles-index__card-tags{display:flex;flex-wrap:wrap;gap:4px}.articles-index__card-tag{font-size:.72rem;font-weight:600;color:var(--color-primary);background:var(--color-very-light-green);padding:2px 8px;border-radius:999px;text-decoration:none}.articles-index__card-tag:hover{background:var(--color-light-green);text-decoration:none}.articles-index__card-link{font-size:.82rem;font-weight:700;color:var(--color-primary);text-decoration:none;white-space:nowrap;flex-shrink:0}.articles-index__card-link::after{content:" →"}.articles-index__card-link:hover{text-decoration:underline}.articles-index__empty{grid-column:1/-1;text-align:center;padding:48px 16px;color:var(--color-gray-500);font-size:.95rem}.articles-index__pagination{margin-top:36px;display:flex;justify-content:center}.articles-index__pagination nav{display:flex;gap:4px}.articles-index__pagination a,.articles-index__pagination span,.articles-index__pagination em{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;border-radius:var(--radius);font-size:.85rem;font-weight:600;text-decoration:none;transition:background-color .15s ease,color .15s ease}.articles-index__pagination a{color:var(--color-gray-700);background:#fff;border:1px solid var(--color-gray-200)}.articles-index__pagination a:hover{background:var(--color-very-light-green);color:var(--color-primary);border-color:var(--color-accent-light);text-decoration:none}.articles-index__pagination em,.articles-index__pagination .current{background:var(--color-primary);color:#fff;font-style:normal;border:1px solid rgba(0,0,0,0)}.articles-index__pagination .gap{border:none;background:rgba(0,0,0,0);color:var(--color-gray-500)}@media(max-width: 767px){.articles-index__hero{grid-template-columns:1fr;gap:20px;padding:24px 0 24px;margin-bottom:28px}.articles-index__title{font-size:1.7rem}.articles-index__hero-panel{padding:20px}.articles-index__list{grid-template-columns:1fr;gap:14px}.articles-index__card{padding:18px 18px 14px}}.article-show{max-width:960px;margin:0 auto;padding:0 16px;max-width:1080px;padding-top:16px;padding-bottom:56px}.article-show__breadcrumb{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--color-gray-500);margin-bottom:20px;flex-wrap:wrap}.article-show__breadcrumb a{color:var(--color-gray-500);text-decoration:none}.article-show__breadcrumb a:hover{color:var(--color-primary);text-decoration:underline}.article-show__breadcrumb span:last-child{color:var(--color-gray-700);font-weight:600}.article-show__breadcrumb-sep{color:var(--color-gray-300);font-size:.75rem}.article-show__layout{display:grid;grid-template-columns:minmax(0, 1fr) 280px;gap:40px;align-items:start}.article-show__main{min-width:0}.article-show__article{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:36px 40px 40px;box-shadow:var(--shadow)}.article-show__header{margin-bottom:28px}.article-show__meta{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--color-gray-500);margin-bottom:12px}.article-show__meta time{color:var(--color-gray-500)}.article-show__meta-sep{color:var(--color-gray-300)}.article-show__meta-link{color:var(--color-primary);font-weight:600;text-decoration:none}.article-show__meta-link:hover{text-decoration:underline}.article-show__title{font-size:clamp(1.5rem,3vw,2rem);font-weight:800;line-height:1.4;color:var(--color-gray-900);letter-spacing:.01em}.article-show__lead{margin-top:14px;font-size:.95rem;color:var(--color-gray-500);line-height:1.8;padding-bottom:20px;border-bottom:1px solid var(--color-gray-200)}.article-show__cover{margin:0 0 28px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--color-gray-200)}.article-show__cover img{display:block;width:100%;height:auto}.article-toc{background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius);padding:20px 24px;margin-bottom:32px}.article-toc__title{font-size:.85rem;font-weight:700;color:var(--color-gray-700);margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--color-primary);display:inline-block}.article-toc__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px;counter-reset:toc}.article-toc__list li{counter-increment:toc}.article-toc__list li a{display:flex;align-items:baseline;gap:8px;font-size:.88rem;color:var(--color-gray-700);text-decoration:none;padding:4px 8px;border-radius:4px;line-height:1.5;transition:background-color .15s ease,color .15s ease}.article-toc__list li a::before{content:counter(toc) ".";color:var(--color-primary);font-weight:700;font-size:.82rem;flex-shrink:0}.article-toc__list li a:hover{background:var(--color-very-light-green);color:var(--color-primary);text-decoration:none}.article-toc__list ol{list-style:none;padding-left:20px;margin:2px 0 0;display:flex;flex-direction:column;gap:2px}.article-toc__list ol li a{font-size:.82rem;color:var(--color-gray-500);padding:2px 8px}.article-toc__list ol li a::before{content:"-";color:var(--color-gray-300)}.article-show__body{line-height:1.9;font-size:1rem;color:var(--color-gray-900)}.article-show__body h2{font-size:1.4rem;font-weight:800;margin:40px 0 16px;padding-bottom:10px;border-bottom:2px solid var(--color-primary);color:var(--color-gray-900);line-height:1.4}.article-show__body h3{font-size:1.15rem;font-weight:700;margin:32px 0 12px;color:var(--color-gray-900);padding-left:14px;border-left:3px solid var(--color-accent);line-height:1.4}.article-show__body h4{font-size:1.05rem;font-weight:700;margin:24px 0 8px;color:var(--color-gray-900);line-height:1.5}.article-show__body h5,.article-show__body h6{font-size:.95rem;font-weight:700;margin:20px 0 8px;color:var(--color-gray-700)}.article-show__body p{margin:0 0 18px;line-height:1.9}.article-show__body a{color:var(--color-primary);text-decoration:underline;text-decoration-color:rgba(45,106,79,.3);text-underline-offset:3px;transition:text-decoration-color .2s ease}.article-show__body a:hover{text-decoration-color:var(--color-primary)}.article-show__body strong{font-weight:700;background:linear-gradient(transparent 60%, rgba(82, 183, 136, 0.18) 60%)}.article-show__body ul,.article-show__body ol{margin:0 0 18px;padding-left:24px;line-height:1.9}.article-show__body ul li,.article-show__body ol li{margin-bottom:4px}.article-show__body ul li+li,.article-show__body ol li+li{margin-top:2px}.article-show__body ul{list-style:disc}.article-show__body ul ul{list-style:circle;margin-bottom:0}.article-show__body ol{list-style:decimal}.article-show__body ol ol{list-style:lower-alpha;margin-bottom:0}.article-show__body blockquote{margin:20px 0;padding:16px 20px;border-left:4px solid var(--color-accent);background:var(--color-gray-50);border-radius:0 var(--radius) var(--radius) 0;color:var(--color-gray-700);font-size:.95rem}.article-show__body blockquote p{margin-bottom:8px}.article-show__body blockquote p:last-child{margin-bottom:0}.article-show__body pre{margin:20px 0;padding:18px 20px;background:var(--color-gray-900);color:#e5e7eb;border-radius:var(--radius);overflow-x:auto;font-size:.85rem;line-height:1.7}.article-show__body pre code{background:rgba(0,0,0,0);padding:0;font-size:inherit;color:inherit;border-radius:0}.article-show__body code{background:var(--color-gray-100);color:var(--color-primary-dark);padding:2px 6px;border-radius:4px;font-size:.88em}.article-show__body table{width:100%;border-collapse:collapse;margin:20px 0;font-size:.9rem}.article-show__body table th,.article-show__body table td{padding:10px 14px;border:1px solid var(--color-gray-200);text-align:left}.article-show__body table th{background:var(--color-gray-50);font-weight:700;color:var(--color-gray-700)}.article-show__body table tr:hover td{background:var(--color-very-light-green)}.article-show__body hr{border:none;height:1px;background:var(--color-gray-200);margin:32px 0}.article-show__body img{max-width:100%;height:auto;border-radius:var(--radius);margin:8px 0}.article-show__body figure{margin:24px 0}.article-show__body figure img{display:block;width:100%}.article-show__body figure figcaption{font-size:.82rem;color:var(--color-gray-500);text-align:center;margin-top:8px}.article-show__body>*:first-child{margin-top:0}.article-show__tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:32px;padding-top:20px;border-top:1px solid var(--color-gray-200)}.article-show__tag{font-size:.78rem;font-weight:600;color:var(--color-primary);background:var(--color-very-light-green);padding:4px 12px;border-radius:999px;text-decoration:none;transition:background-color .15s ease}.article-show__tag:hover{background:var(--color-light-green);text-decoration:none}.article-show__share{margin-top:28px;padding-top:20px;border-top:1px solid var(--color-gray-200)}.article-show__share-title{font-size:.82rem;font-weight:700;color:var(--color-gray-700);margin-bottom:10px}.article-show__share-actions{display:flex;gap:10px}.article-show__share-button{display:inline-flex;align-items:center;justify-content:center;padding:8px 20px;border-radius:var(--radius);font-size:.82rem;font-weight:700;text-decoration:none;transition:opacity .15s ease,transform .15s ease}.article-show__share-button:hover{opacity:.85;transform:translateY(-1px);text-decoration:none}.article-show__share-button--x{background:#0f1419;color:#fff}.article-show__share-button--line{background:#06c755;color:#fff}.article-show__cta-rich{margin-top:32px;background:linear-gradient(135deg, rgba(216, 243, 220, 0.5), rgba(237, 247, 240, 0.8));border:1px solid rgba(82,183,136,.25);border-radius:var(--radius-lg);overflow:hidden}.article-show__cta-rich-content{padding:28px 32px;text-align:center}.article-show__cta-rich-eyebrow{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--color-primary);margin-bottom:6px}.article-show__cta-rich-title{font-size:1.3rem;font-weight:800;color:var(--color-gray-900);margin-bottom:10px;line-height:1.4}.article-show__cta-rich-text{font-size:.9rem;color:var(--color-gray-700);line-height:1.8;margin-bottom:18px;max-width:520px;margin-left:auto;margin-right:auto}.article-show__cta-rich-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}.article-show__cta-rich-button{display:inline-flex;align-items:center;justify-content:center;padding:10px 28px;border-radius:999px;font-size:.88rem;font-weight:700;text-decoration:none;background:linear-gradient(90deg, #52b788, #2d6a4f);color:#fff;box-shadow:0 4px 12px rgba(45,106,79,.3);transition:transform .2s ease,box-shadow .2s ease}.article-show__cta-rich-button:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(45,106,79,.4);text-decoration:none;color:#fff}.article-show__cta-rich-button--ghost{background:hsla(0,0%,100%,.9);color:var(--color-primary-dark);box-shadow:0 2px 8px rgba(0,0,0,.06);border:1px solid var(--color-gray-200)}.article-show__cta-rich-button--ghost:hover{background:#fff;box-shadow:0 4px 12px rgba(0,0,0,.1);color:var(--color-primary-dark)}.article-show__footer-nav{margin-top:28px;padding-top:20px;border-top:1px solid var(--color-gray-200);text-align:center}.article-show__footer-link{display:inline-flex;align-items:center;gap:6px;font-size:.9rem;font-weight:700;color:var(--color-primary);text-decoration:none}.article-show__footer-link::before{content:"←"}.article-show__footer-link:hover{text-decoration:underline}.article-show__sidebar{position:sticky;top:80px;display:flex;flex-direction:column;gap:16px}.article-sidebar-card{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow)}.article-sidebar-card__title{font-size:.8rem;font-weight:700;color:var(--color-gray-700);margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--color-primary);display:inline-block}.article-sidebar-card__categories{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}.article-sidebar-card__category-link{display:block;padding:6px 10px;font-size:.85rem;font-weight:600;color:var(--color-gray-700);text-decoration:none;border-radius:4px;transition:background-color .15s ease,color .15s ease}.article-sidebar-card__category-link:hover{background:var(--color-very-light-green);color:var(--color-primary);text-decoration:none}.article-sidebar-card__tags{display:flex;flex-wrap:wrap;gap:6px}.article-sidebar-card__tag{font-size:.75rem;font-weight:600;color:var(--color-primary);background:var(--color-very-light-green);padding:3px 10px;border-radius:999px;text-decoration:none;transition:background-color .15s ease}.article-sidebar-card__tag:hover{background:var(--color-light-green);text-decoration:none}.article-sidebar-card__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.article-sidebar-card__list li{display:flex;flex-direction:column;gap:2px;padding-bottom:10px;border-bottom:1px solid var(--color-gray-100)}.article-sidebar-card__list li:last-child{border-bottom:none;padding-bottom:0}.article-sidebar-card__list li a{font-size:.85rem;font-weight:600;color:var(--color-gray-900);text-decoration:none;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.article-sidebar-card__list li a:hover{color:var(--color-primary);text-decoration:none}.article-sidebar-card__list li span{font-size:.72rem;color:var(--color-gray-500)}.article-sidebar-card__text{font-size:.85rem;color:var(--color-gray-500)}.article-sidebar-search{display:flex;gap:0}.article-sidebar-search__input{flex:1;padding:8px 12px;border:1px solid var(--color-gray-300);border-right:none;border-radius:var(--radius) 0 0 var(--radius);font-size:.85rem;background:#fff;transition:border-color .2s ease}.article-sidebar-search__input:focus{outline:none;border-color:var(--color-primary)}.article-sidebar-search__button{padding:8px 16px;background:var(--color-primary);color:#fff;border:1px solid var(--color-primary);border-radius:0 var(--radius) var(--radius) 0;font-size:.82rem;font-weight:700;cursor:pointer;transition:background-color .15s ease}.article-sidebar-search__button:hover{background:var(--color-primary-dark)}.article-sidebar-cta{background:linear-gradient(145deg, var(--color-primary-dark), var(--color-primary));border-radius:var(--radius);padding:22px 20px;color:#fff;text-align:center}.article-sidebar-cta__title{font-size:1rem;font-weight:800;line-height:1.5;margin-bottom:12px}.article-sidebar-cta__features{list-style:none;padding:0;margin:0 0 16px;display:flex;flex-wrap:wrap;justify-content:center;gap:6px}.article-sidebar-cta__features li{background:hsla(0,0%,100%,.15);padding:3px 10px;border-radius:999px;font-size:.75rem;font-weight:600}.article-sidebar-cta__button{display:block;width:100%;padding:10px 16px;background:#fff;color:var(--color-primary-dark);font-weight:700;font-size:.88rem;border-radius:999px;text-decoration:none;text-align:center;transition:transform .15s ease,box-shadow .15s ease}.article-sidebar-cta__button:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.2);text-decoration:none;color:var(--color-primary-dark)}.article-sidebar-cta__link{display:inline-block;margin-top:10px;font-size:.78rem;font-weight:600;color:hsla(0,0%,100%,.8);text-decoration:none}.article-sidebar-cta__link:hover{color:#fff;text-decoration:underline}@media(max-width: 767px){.article-show{padding-top:8px;padding-bottom:36px}.article-show__breadcrumb{margin-bottom:14px;font-size:.75rem}.article-show__layout{grid-template-columns:1fr;gap:28px}.article-show__article{padding:24px 20px 28px;border-radius:var(--radius)}.article-show__title{font-size:1.4rem}.article-show__sidebar{position:static}.article-show__share-actions{flex-direction:column;gap:8px}.article-show__share-button{width:100%}.article-show__cta-rich-content{padding:22px 18px}.article-show__cta-rich-title{font-size:1.1rem}.article-show__cta-rich-actions{flex-direction:column;align-items:stretch}.article-show__body{font-size:.95rem}.article-show__body h2{font-size:1.2rem;margin:32px 0 12px}.article-show__body h3{font-size:1.05rem;margin:24px 0 10px}.article-show__body pre{font-size:.8rem;padding:14px 16px}.article-show__body table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.article-show__body table th,.article-show__body table td{padding:8px 10px;white-space:nowrap}.article-toc{padding:16px 18px}}.mypage{min-height:100vh;background:linear-gradient(180deg, var(--color-very-light-green) 0%, #f8fafc 55%, #ffffff 100%)}.mypage .container{max-width:960px;margin:0 auto;padding:0 16px;max-width:1060px;padding-top:30px;padding-bottom:60px}.mypage__layout{display:grid;grid-template-columns:200px minmax(0, 1fr);gap:24px;align-items:start}@media(max-width: 767px){.mypage__layout{grid-template-columns:1fr}}.mypage__main{display:flex;flex-direction:column;gap:24px}.mypage__card{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);box-shadow:0 16px 30px rgba(27,67,50,.08);padding:28px 32px}@media(max-width: 767px){.mypage__card{padding:24px 20px}}.mypage__card--accent{background:linear-gradient(140deg, #ffffff 0%, var(--color-very-light-green) 100%)}.mypage__card-title{font-size:1.4rem;font-weight:800;color:var(--color-primary);margin:0 0 20px}.mypage__form{display:flex;flex-direction:column;gap:20px}.mypage__form--inline{flex-direction:row;align-items:flex-end;gap:12px}@media(max-width: 767px){.mypage__form--inline{flex-direction:column;align-items:stretch}}.mypage__text{color:var(--color-gray-500);margin:0 0 12px}.mypage__providers{display:flex;flex-direction:column;gap:12px}.mypage__provider{display:flex;align-items:center;gap:16px;padding:12px 14px;border-radius:12px;background:var(--color-gray-50);border:1px solid var(--color-gray-200)}@media(max-width: 767px){.mypage__provider{flex-direction:column;align-items:flex-start;gap:8px}}.mypage__provider-name{font-weight:800;color:var(--color-gray-900)}.mypage__provider-badge{font-weight:700;font-size:.9rem;padding:6px 12px;border-radius:999px;text-align:center;background:var(--color-gray-200);color:var(--color-gray-700)}.mypage__provider-badge--connected{background:var(--color-light-green);color:var(--color-primary-dark)}.mypage__plan-current{display:flex;align-items:center;gap:16px;flex-wrap:wrap}@media(max-width: 767px){.mypage__plan-current{flex-direction:column;align-items:flex-start}}.mypage__plan-badge{background:var(--color-primary);color:#fff;font-weight:700;padding:8px 14px;border-radius:999px}.mypage__plan-detail{color:var(--color-gray-500);font-weight:600;margin:0}.mypage__usage-grid{display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:16px}@media(max-width: 767px){.mypage__usage-grid{grid-template-columns:1fr}}.mypage__usage-item{background:#fff;border:1px solid var(--color-light-green);border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:6px}.mypage__usage-label{font-size:.85rem;color:var(--color-gray-500);font-weight:700}.mypage__usage-value{font-size:1.2rem;font-weight:800;color:var(--color-gray-900)}.mypage__promo-active{display:flex;flex-direction:column;gap:6px}.mypage__promo-code{font-size:1.2rem;font-weight:800;color:var(--color-primary-dark);margin:0}.mypage__promo-expires{color:var(--color-gray-500);font-size:.9rem;margin:0}.mypage__card-lead{color:var(--color-gray-500);margin:0 0 4px;font-size:.95rem}.mypage__section{padding-top:4px;display:flex;flex-direction:column;gap:12px}.mypage__section-title{font-size:1.1rem;font-weight:800;color:var(--color-gray-900)}.mypage__section-lead{color:var(--color-gray-500);font-size:.95rem}.mypage__field-error{margin:4px 0 0;font-size:.85rem;font-weight:700;color:#b91c1c;line-height:1.45}.mypage__input--invalid{border-color:rgba(248,113,113,.8) !important;background:rgba(254,242,242,.55) !important}.mypage__notice{padding:10px 14px;border-radius:10px;background:var(--color-very-light-green);border:1px solid var(--color-accent-light);color:var(--color-primary-dark);font-size:.9rem}.mypage__actions{display:flex;gap:12px;flex-wrap:wrap}.mypage__plan-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-top:16px}.mypage__plan-actions-note{color:var(--color-gray-500);font-size:.85rem;margin-top:8px}.mypage__plan-status{display:inline-flex;align-items:center;padding:6px 12px;border-radius:999px;background:var(--color-gray-200);color:var(--color-gray-700);font-weight:700;font-size:.85rem}.mypage__plan-cancel{background:rgba(0,0,0,0);border:none;padding:0;color:#b91c1c;font-weight:700;text-decoration:underline;cursor:pointer}.mypage__plan-cancel:hover{color:#991b1b}.mypage__code-input{border:1px solid var(--color-gray-300);border-radius:10px;padding:12px 14px;font-size:1rem;color:var(--color-gray-900);background:var(--color-gray-50);transition:border-color .2s ease,box-shadow .2s ease}.mypage__code-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(45,106,79,.15);background:#fff}.mypage-header{background:var(--color-gray-50);border-bottom:1px solid var(--color-gray-200);box-shadow:0 12px 24px rgba(27,67,50,.08);padding:30px 0;margin-bottom:30px;position:relative;overflow:hidden}.mypage-header::before{content:"";position:absolute;top:-36px;right:-120px;width:260px;height:170px;background:linear-gradient(135deg, rgba(82, 183, 136, 0.2), rgba(45, 106, 79, 0.04));transform:skewX(-12deg);border-radius:28px;z-index:0}.mypage-header::after{content:"";position:absolute;bottom:-70px;left:-80px;width:200px;height:200px;border-radius:999px;background:radial-gradient(circle at 30% 30%, rgba(45, 106, 79, 0.16), rgba(82, 183, 136, 0.02) 65%);z-index:0}.mypage-header__inner{position:relative;z-index:1;display:flex;align-items:flex-end;justify-content:space-between;gap:20px}@media(max-width: 767px){.mypage-header__inner{flex-direction:column;align-items:flex-start}}.mypage-header__text{display:flex;flex-direction:column;gap:4px}.mypage-header__actions{flex-shrink:0}.mypage-header__back{font-size:.9rem;color:var(--color-primary);text-decoration:none;font-weight:700;border:1px solid var(--color-accent-light);background:#fff;padding:10px 16px;border-radius:999px;transition:all .2s ease}.mypage-header__back:hover{background:var(--color-very-light-green);border-color:var(--color-primary);color:var(--color-primary-dark)}.mypage-header__title{font-size:2rem;font-weight:800;color:var(--color-gray-900);margin:0}.mypage-header__subtitle{color:var(--color-gray-500);font-size:1.05rem;margin:0}.mypage-sidebar{position:sticky;top:120px;align-self:start}@media(max-width: 767px){.mypage-sidebar{position:static;top:auto}}.mypage-sidebar__nav{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);box-shadow:0 16px 24px rgba(27,67,50,.08);padding:16px;display:flex;flex-direction:column;gap:12px}@media(max-width: 767px){.mypage-sidebar__nav{flex-direction:row;gap:10px;padding:12px}}.mypage-sidebar__link{padding:10px 12px;border-radius:10px;text-decoration:none;font-weight:700;color:var(--color-gray-900);background:var(--color-gray-50);border:1px solid rgba(0,0,0,0);transition:all .2s ease;text-align:center;font-size:.92rem}.mypage-sidebar__link:hover{background:var(--color-very-light-green);border-color:var(--color-accent-light);color:var(--color-primary)}.mypage-sidebar__link--active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:0 10px 18px rgba(45,106,79,.3)}.glossary-index{--article-ink: #0b1320;--article-ink-soft: #475569;--article-green: var(--color-primary);--article-green-bg: var(--color-light-green);position:relative;background:radial-gradient(circle at top left, var(--color-very-light-green) 0%, #ffffff 45%, #f8fafc 100%);overflow:hidden;min-height:100vh}.glossary-index::before,.glossary-index::after{content:"";position:absolute;border-radius:999px;filter:blur(0.5px);opacity:.6;z-index:0}.glossary-index::before{width:380px;height:380px;top:-120px;right:-120px;background:radial-gradient(circle, rgba(45, 106, 79, 0.35), transparent 70%);animation:float-slow 10s ease-in-out infinite}.glossary-index::after{width:420px;height:420px;bottom:-180px;left:-140px;background:radial-gradient(circle, rgba(45, 106, 79, 0.22), transparent 70%);animation:float-slow 12s ease-in-out infinite reverse}.glossary-index__inner{position:relative;z-index:1;max-width:1100px;margin:0 auto;padding:56px 20px 80px}.glossary-index__hero{display:grid;grid-template-columns:minmax(0, 1.1fr) minmax(0, 0.9fr);gap:28px;align-items:center;margin-bottom:32px}.glossary-index__hero-content{display:flex;flex-direction:column;gap:12px}.glossary-index__eyebrow{font-size:.8rem;text-transform:uppercase;letter-spacing:.2em;color:var(--color-primary);font-weight:700}.glossary-index__title{font-size:2.6rem;font-weight:800;margin:0;color:var(--article-ink);line-height:1.2}.glossary-index__subtitle{color:var(--article-ink-soft);font-size:1rem;line-height:1.7;margin:0}.glossary-index__hero-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.glossary-index__chip{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:#fff;border:1px solid var(--color-accent-light);font-size:.85rem;font-weight:700;color:var(--color-primary-dark)}.glossary-index__hero-panel{background:#fff;border-radius:22px;padding:22px 24px;border:1px solid var(--color-gray-200);box-shadow:0 18px 32px rgba(15,23,42,.1);display:flex;flex-direction:column;gap:12px}.glossary-index__hero-panel-label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:#94a3b8;margin:0}.glossary-index__hero-panel-hint{color:var(--article-ink-soft);font-size:.85rem;margin:0;line-height:1.6}.glossary-index__search-status{display:flex;align-items:center;gap:12px;font-size:.88rem;color:var(--article-ink);font-weight:600}.glossary-search{display:flex;gap:8px}.glossary-search__input{flex:1;padding:12px 16px;border:1.5px solid var(--color-gray-200);border-radius:10px;font-size:.95rem;background:var(--color-gray-50);transition:border-color .15s,box-shadow .15s,background .15s}.glossary-search__input:focus{outline:none;border-color:var(--color-primary);background:#fff;box-shadow:0 4px 16px rgba(45,106,79,.12)}.glossary-search__button{padding:12px 20px;background:#0f172a;color:#fff;border:none;border-radius:10px;font-size:.88rem;font-weight:700;cursor:pointer;transition:opacity .15s;white-space:nowrap}.glossary-search__button:hover{opacity:.88}.glossary-search__clear{color:var(--color-primary);font-size:.85rem;text-decoration:none;font-weight:600}.glossary-search__clear:hover{text-decoration:underline}.glossary-index__nav{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:36px;padding:20px 24px;background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-gray-200);box-shadow:0 8px 20px rgba(15,23,42,.05)}.glossary-index__nav-link{display:inline-block;padding:8px 16px;border-radius:999px;font-size:.88rem;font-weight:700;text-decoration:none;color:var(--color-primary);background:var(--color-light-green);transition:all .2s ease;border:1.5px solid rgba(0,0,0,0)}.glossary-index__nav-link:hover{background:var(--color-primary);color:#fff;box-shadow:0 4px 12px rgba(45,106,79,.25);transform:translateY(-1px)}.glossary-index__nav-link--disabled{color:#cbd5e1;background:var(--color-gray-50);cursor:default;pointer-events:none;border-color:#f1f5f9}.glossary-index__empty{text-align:center;padding:64px 20px;color:var(--article-ink-soft);font-size:1.05rem;background:#fff;border-radius:18px;border:1px solid var(--color-gray-200);box-shadow:0 8px 20px rgba(15,23,42,.05)}.glossary-index__list{display:flex;flex-direction:column;gap:36px}.glossary-index__group{animation:fade-rise .5s ease both}.glossary-index__group:nth-child(2){animation-delay:.05s}.glossary-index__group:nth-child(3){animation-delay:.1s}.glossary-index__group:nth-child(4){animation-delay:.15s}.glossary-index__group:nth-child(5){animation-delay:.2s}.glossary-index__group-title{font-size:1.4rem;font-weight:800;color:var(--article-ink);margin:0 0 16px;padding-bottom:10px;border-bottom:3px solid var(--color-primary);display:inline-block;letter-spacing:.04em}.glossary-index__terms{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0;background:#fff;border-radius:18px;border:1px solid var(--color-gray-200);box-shadow:0 16px 28px rgba(15,23,42,.08);overflow:hidden}.glossary-index__term{padding:16px 24px;border-bottom:1px solid #f1f5f9;transition:background .15s}.glossary-index__term:last-child{border-bottom:none}.glossary-index__term:hover{background:var(--color-very-light-green)}.glossary-index__term-main{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.glossary-index__term-link{font-size:1.02rem;font-weight:700;color:var(--article-ink);text-decoration:none;transition:color .15s;line-height:1.5}.glossary-index__term-link:hover{color:var(--color-primary)}.glossary-index__term-category{font-size:.72rem;font-weight:700;color:var(--color-primary);background:var(--color-light-green);padding:3px 12px;border-radius:999px;letter-spacing:.02em;white-space:nowrap}.glossary-index__term-summary{margin:6px 0 0;font-size:.88rem;color:var(--article-ink-soft);line-height:1.7}@media(max-width: 720px){.glossary-index__hero{grid-template-columns:1fr;gap:20px}.glossary-index__title{font-size:1.8rem}.glossary-index__inner{padding:32px 16px 60px}.glossary-index__nav{gap:5px;padding:14px 16px;border-radius:12px}.glossary-index__nav-link{padding:6px 12px;font-size:.8rem}.glossary-index__hero-panel{border-radius:16px;padding:18px 16px}.glossary-index__term{padding:14px 16px}.glossary-index__terms{border-radius:12px}.glossary-index__group-title{font-size:1.2rem}}.error-page{padding:80px 16px;min-height:calc(100vh - 160px);display:grid;place-items:center;background:radial-gradient(circle at top, #f8fafc 0%, var(--color-gray-200) 60%, var(--color-gray-300) 100%)}.error-card{width:min(720px,100%);background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:48px;display:grid;gap:20px}.error-card__code{font-size:3.5rem;font-weight:800;color:var(--color-danger);letter-spacing:.08em}.error-card__title{font-size:1.8rem;font-weight:800;color:var(--color-gray-900)}.error-card__message{color:var(--color-gray-500);line-height:1.7}.error-card__actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}.error-card__button{border:1px solid var(--color-gray-300);border-radius:999px;padding:10px 18px;text-decoration:none;color:var(--color-gray-900);font-weight:600;transition:transform .15s ease,box-shadow .15s ease}.error-card__button:hover{transform:translateY(-1px);box-shadow:0 8px 16px rgba(15,23,42,.15)}.error-card__button--primary{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);color:#fff;border-color:rgba(0,0,0,0)}@media(max-width: 767px){.error-card{padding:32px 24px}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:var(--color-primary)}.text-muted{color:var(--color-gray-500)}.text-danger{color:var(--color-danger)}.text-success{color:var(--color-success)}.mt-0{margin-top:0}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}.mb-0{margin-bottom:0}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0}.hover-lift{transition:transform .2s ease,box-shadow .2s ease}.hover-lift:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(27,67,50,.1)}
