:root{--text:#333;--text-h:#000;--bg:#fff;--border:#e0e0e0;--accent:#000;--sans:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;font:16px/1.6 var(--sans);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{color:#333;background-color:#fff;margin:0;padding:0}#root{width:100%}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.app,html{scroll-behavior:smooth}.app{color:#111;background:radial-gradient(circle at top,#0000000d,#0000 32%),#fff;flex-direction:column;min-height:100vh;display:flex}.header{z-index:10;color:#111;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:linear-gradient(#fff 0%,#f0f0f0 48%,#fafafa 100%);border-bottom:1px solid #b8b8b8;animation:.8s ease-out both headerFadeIn;position:sticky;top:0;box-shadow:inset 0 1px #fffffff2,inset 0 -1px #91919159,0 3px 10px #00000014}@keyframes headerFadeIn{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.header-container{justify-content:space-between;align-items:center;gap:24px;max-width:1280px;margin:0 auto;padding:18px 32px;display:flex}.logo-section{align-items:center;gap:14px;min-width:0;display:flex}.logo-image{object-fit:contain;width:auto;height:46px}.logo-brand{letter-spacing:-.04em;color:#111;text-align:left;white-space:nowrap;width:fit-content;min-height:1.15em;margin:0;padding-bottom:12px;font-size:clamp(19px,2.2vw,30px);font-weight:800;line-height:1;position:relative}.logo-brand.wave-title{flex-wrap:nowrap}.logo-brand:before,.logo-brand:after{content:"";border-radius:999px;height:4px;position:absolute;bottom:2px;left:0;right:0}.logo-brand:before{background:#f0f0f0}.logo-brand:after{transform-origin:0;background:#67b9e6;width:100%;animation:7.2s ease-in-out infinite brandUnderlineSlide;left:0;right:auto}.nav{flex-shrink:0;justify-self:end;align-items:center;gap:24px;display:flex}.nav-button{color:#3a3a3a;cursor:pointer;background:0 0;border:0;border-bottom:2px solid #0000;padding:8px 0;font-size:15px;font-weight:600;transition:color .2s,border-color .2s}.nav-button:hover,.nav-button.active{color:#111;border-bottom-color:#111}.main{flex:1;width:100%}.download-banner{justify-content:center;width:100%;padding:12px 32px 4px;display:flex}.windows-download-button{color:#fff;text-align:center;background:#000;border:2px solid #000;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;min-width:280px;padding:14px 28px;line-height:1.15;text-decoration:none;transition:transform .2s,box-shadow .2s;display:inline-flex;box-shadow:0 12px 24px #0000002e}.windows-download-button:hover{transform:translateY(-2px);box-shadow:0 16px 30px #0000003d}.windows-download-line{letter-spacing:-.02em;font-size:24px;font-weight:800;display:block}.page{width:100%}.page-container{max-width:1280px;margin:0 auto;padding:72px 32px 84px}.hero-copy{text-align:center;max-width:760px;margin:0 auto 48px}.hero-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:30px;display:grid}.hero-action-card{text-align:left;cursor:pointer;background:#fff;border:1px solid #dcdcdc;border-radius:24px;padding:22px 24px;transition:transform .2s,box-shadow .2s,border-color .2s}.hero-action-card--tab{background:linear-gradient(#f6f0e3 0%,#fbf7ef 100%);border-color:#e6d9bd}.hero-action-card--fit{background:linear-gradient(#eaf5ff 0%,#f3f9ff 100%);border-color:#cfe3f6}.hero-action-image-frame{aspect-ratio:1;box-sizing:border-box;background:0 0;border:1px solid #c9c9c9;border-radius:18px;width:min(100%,240px);height:auto;margin:0 auto 16px;padding:10px;display:block;overflow:hidden}.hero-action-image{object-fit:contain;object-position:center;border-radius:12px;width:100%;height:100%;display:block}.hero-action-card--fit .hero-action-image{transform-origin:50%;transform:scale(1.3)}.hero-action-card:hover{border-color:#111;transform:translateY(-2px);box-shadow:0 16px 30px #00000014}.hero-action-label{color:#666;letter-spacing:.04em;margin-bottom:10px;font-size:13px;font-weight:700;display:block}.hero-action-title{color:#111;letter-spacing:-.03em;font-size:24px;line-height:1.35;display:block}.page-title,.contact-title,.product-title{letter-spacing:-.04em;margin:0;font-weight:800}.page-title{min-height:1.2em;font-size:clamp(40px,6vw,72px)}.contact-title{text-align:center;min-height:1.2em;margin-bottom:28px;font-size:clamp(34px,5vw,58px)}.page-subtitle{color:#5f5f5f;margin:18px 0 0;font-size:19px;line-height:1.8}.wave-title{flex-wrap:wrap;align-items:flex-end;gap:.01em;display:flex}.wave-char{will-change:transform, color;animation-timing-function:ease-in-out;animation-iteration-count:infinite;display:inline-block}.wave-title--jump .wave-char{animation-name:waveJump;transform:translateY(0)}.wave-title--color .wave-char{color:#111;animation:none}.wave-char--space{width:.32em}@keyframes waveJump{0%,12%,to{transform:translateY(0)}18%{transform:translateY(-.24em)}26%{transform:translateY(0)}}@keyframes waveColor{0%,12%,to{color:#111}20%{color:#67b9e6}32%{color:#111}}@keyframes brandUnderlineSlide{0%,16%{opacity:0;transform:scaleX(0)}26%{opacity:1;transform:scaleX(.16)}52%{opacity:1;transform:scaleX(1)}62%{opacity:0;transform:scaleX(1)}to{opacity:0;transform:scaleX(0)}}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.products-stack{flex-direction:column;gap:36px;display:flex}.product-card{background:linear-gradient(#fff 0%,#fafafa 100%);border:1px solid #e5e5e5;border-radius:28px;grid-template-columns:minmax(0,1.2fr) minmax(360px,.8fr);align-items:start;gap:36px;padding:36px;display:grid;box-shadow:0 22px 60px #0000000f}.product-card--tab{background:linear-gradient(#f6f0e3 0%,#fbf7ef 100%);border-color:#e8dcc2}.product-card--fit{background:linear-gradient(#eaf5ff 0%,#f3f9ff 100%);border-color:#d3e7f8}.product-copy{min-width:0}.product-badge{color:#4d4d4d;letter-spacing:.02em;margin:0 0 14px;font-size:14px;font-weight:700}.product-title{min-height:1.2em;font-size:clamp(30px,4vw,46px)}.product-summary{color:#444;margin:18px 0 0;font-size:18px;line-height:1.9}.product-sections{flex-direction:column;gap:20px;margin-top:28px;display:flex}.feature-block{background:#fff;border:1px solid #ececec;border-radius:20px;padding:24px 24px 22px}.feature-title{letter-spacing:-.03em;align-items:center;gap:10px;margin:0 0 16px;font-size:24px;font-weight:800;display:flex}.feature-number{flex:none}.feature-items{margin:0;padding-left:0;list-style:none}.feature-items li{color:#2f2f2f;padding-left:0;font-size:18px;line-height:1.95}.feature-items li+li{margin-top:14px}.product-highlights{color:#fff;background:#111;border-radius:20px;margin-top:24px;padding:22px 24px}.highlight-line{gap:10px;margin:0;font-size:17px;line-height:1.85;display:flex}.highlight-line+.highlight-line{margin-top:12px}.highlight-mark{flex:none;font-weight:800}.product-media{align-self:start;position:sticky;top:110px}.video-frame{aspect-ratio:16/9;background:#000;border-radius:22px;position:static;overflow:hidden;box-shadow:0 20px 45px #0003}.video-frame iframe{border:0;width:100%;height:100%;display:block}.google-play-link{width:fit-content;margin-top:14px;display:block}.google-play-image{width:clamp(306px,93.5%,442px);height:auto;display:block}.contact-wrap{max-width:780px}.contact-desc{color:#666;margin:-8px 0 24px;font-size:15px}.upload-guide{color:#6b6b6b;margin:-2px 0 6px;font-size:13px}.logo-preview-wrap{background:#fff;border:1px solid #dfdfdf;border-radius:14px;margin-top:12px;padding:12px}.logo-preview-label{color:#444;margin:0 0 8px;font-size:13px;font-weight:700}.logo-preview-frame{aspect-ratio:3;background:#f8f8f8;border:1px solid #d7d7d7;border-radius:10px;width:100%;max-width:420px;overflow:hidden}.logo-preview-image{object-fit:contain;width:100%;height:100%;display:block}.logo-preview-file{color:#777;word-break:break-all;margin:8px 0 0;font-size:12px}.form-row{grid-template-columns:1fr 1fr;gap:20px;display:grid}.form-row+.form-group,.form-group+.form-row{margin-top:20px}.form-select{color:#111;appearance:none;cursor:pointer;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23999' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") right 16px center no-repeat;border:1px solid #d4d4d4;border-radius:14px;width:100%;padding:14px 16px;font-family:inherit;font-size:16px;transition:border-color .2s,box-shadow .2s}.form-select:focus{border-color:#111;outline:none;box-shadow:0 0 0 4px #00000014}.submit-button:disabled{opacity:.65;cursor:not-allowed;transform:none}.contact-done{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:50vh;padding:60px 20px;display:flex}.done-icon{margin-bottom:20px;font-size:64px}.done-title{color:#111;margin-bottom:12px;font-size:clamp(28px,4vw,40px);font-weight:800}.done-message{color:#333;margin-bottom:10px;font-size:clamp(16px,2.5vw,20px);font-weight:700}.done-sub{color:#888;font-size:15px}.form{background:#fafafa;border:1px solid #e4e4e4;border-radius:24px;padding:34px;box-shadow:0 14px 36px #0000000d}.form-group{flex-direction:column;gap:10px;display:flex}.form-group+.form-group,.form-row+.form-row{margin-top:20px}.form-group label{color:#111;font-size:14px;font-weight:700}.form-group input,.form-group textarea{color:#111;background:#fff;border:1px solid #d4d4d4;border-radius:14px;width:100%;padding:14px 16px;font-family:inherit;font-size:16px;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group textarea:focus{border-color:#111;outline:none;box-shadow:0 0 0 4px #00000014}.submit-button{color:#fff;cursor:pointer;background:#111;border:0;border-radius:14px;width:100%;margin-top:24px;padding:16px 20px;font-size:16px;font-weight:700;transition:transform .2s,background-color .2s}.submit-button:hover{background:#252525;transform:translateY(-1px)}.footer{color:#d5d5d5;background:#000;border-top:1px solid #1f1f1f}.top-button{color:#111;letter-spacing:.03em;cursor:pointer;opacity:0;pointer-events:none;z-index:20;background:#ffffffdb;border:1px solid #0000003d;border-radius:999px;padding:11px 18px;font-size:13px;font-weight:700;transition:opacity .35s,transform .35s,background-color .2s;position:fixed;bottom:28px;left:50%;transform:translate(-50%)translateY(18px);box-shadow:0 8px 20px #00000026}.top-button.visible{opacity:1;pointer-events:auto;transform:translate(-50%)translateY(0)}.top-button:hover{background:#fff}.footer-content{text-align:center;flex-direction:column;gap:12px;max-width:1280px;margin:0 auto;padding:28px 32px 34px;display:flex}.copyright{color:#fff;margin:0;font-weight:700}.footer-info,.footer-contact{flex-wrap:wrap;justify-content:center;gap:10px 18px;font-size:13px;line-height:1.8;display:flex}@media (width<=1080px){.product-card{grid-template-columns:1fr}.product-media{position:static;top:auto}.video-frame{position:static}}@media (width<=768px){.header-container,.page-container,.footer-content{padding-left:20px;padding-right:20px}.header-container{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px 16px}.logo-section{flex:auto;gap:10px;min-width:0}.logo-brand{letter-spacing:-.03em;font-size:clamp(15px,4.3vw,21px)}.nav{flex:100%;justify-content:flex-end;gap:18px}.hero-actions{grid-template-columns:1fr}.hero-action-image{height:160px}.page-container{padding-top:44px;padding-bottom:52px}.download-banner{padding-left:20px;padding-right:20px}.windows-download-button{width:100%;min-width:0;max-width:340px}.windows-download-line{font-size:21px}.page-subtitle,.product-summary,.feature-items li,.highlight-line{font-size:16px}.product-card,.form,.feature-block,.product-highlights{padding-left:20px;padding-right:20px}.feature-title{font-size:20px}.top-button{padding:10px 15px;font-size:12px;bottom:20px}}.nav-button--login{color:#fff;cursor:pointer;background:linear-gradient(135deg,#111 0%,#333 100%);border:none;border-radius:22px;margin-left:6px;padding:8px 20px;font-size:14px;font-weight:700;transition:background .2s,transform .15s}.nav-button--login:hover{background:linear-gradient(135deg,#222 0%,#555 100%);transform:translateY(-1px)}.nav-button--login.active-user{color:#fff;background:linear-gradient(135deg,#67b9e6 0%,#3a90cc 100%)}.page-login{align-items:flex-start;min-height:70vh;padding-top:60px;display:flex}.login-wrap{width:100%;max-width:440px;margin:0 auto}.login-title{color:#111;text-align:center;margin-bottom:32px;font-size:clamp(26px,4vw,36px);font-weight:800}.login-form{flex-direction:column;gap:18px;display:flex}.login-admin-toggle{padding:14px 0 4px}.admin-check-label{cursor:pointer;color:#444;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;font-size:15px;display:flex}.admin-check-label input[type=checkbox]{accent-color:#67b9e6;cursor:pointer;width:18px;height:18px}.login-error{color:#e05050;margin:-8px 0 0;font-size:13px}.back-button{color:#666;cursor:pointer;background:0 0;border:1.5px solid #ccc;border-radius:10px;padding:12px;font-size:15px;transition:border-color .2s,color .2s}.back-button:hover{color:#333;border-color:#888}.page-admin,.page-member{min-height:70vh;padding-top:50px}.admin-wrap,.member-wrap{width:100%;max-width:860px;margin:0 auto}.welcome-header{text-align:center;margin-bottom:48px}.welcome-badge{letter-spacing:.04em;border-radius:20px;margin-bottom:14px;padding:4px 16px;font-size:13px;font-weight:700;display:inline-block}.admin-badge{color:#fff;background:#111}.member-badge{color:#fff;background:#67b9e6}.welcome-title{color:#111;margin-bottom:8px;font-size:clamp(28px,4vw,42px);font-weight:800}.welcome-sub{color:#777;font-size:16px}.admin-menu-tabs,.member-menu-tabs{gap:12px;margin:-10px 0 18px;display:grid}.admin-menu-tabs{grid-template-columns:repeat(3,minmax(0,1fr))}.member-menu-tabs{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-menu-tab,.member-menu-tab{color:#2f3a45;cursor:pointer;background:#fff;border:1px solid #d6dce3;border-radius:14px;padding:13px 16px;font-size:15px;font-weight:700;transition:border-color .2s,box-shadow .2s,background-color .2s}.admin-menu-tab:hover,.member-menu-tab:hover{border-color:#8abde2}.admin-menu-tab.is-active,.member-menu-tab.is-active{color:#0f3e5e;background:linear-gradient(#eaf6ff 0%,#f6fbff 100%);border-color:#67b9e6;box-shadow:0 8px 20px #67b9e633}.dashboard-grid{grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:40px;display:grid}.dashboard-card{cursor:default;background:#fff;border:1.5px solid #e8e8e8;border-radius:18px;padding:28px 24px;transition:box-shadow .2s,transform .2s}.dashboard-card:hover{transform:translateY(-3px);box-shadow:0 8px 28px #00000017}.dashboard-card-icon{margin-bottom:12px;font-size:32px}.dashboard-card-title{color:#111;margin-bottom:8px;font-size:17px;font-weight:700}.dashboard-card-desc{color:#777;font-size:14px;line-height:1.55}.member-school-panel{background:#fff;border:1px solid #e5e5e5;border-radius:20px;margin:12px 0 34px;padding:24px;box-shadow:0 18px 36px #0000000a}.member-school-panel__header{justify-content:space-between;align-items:end;gap:24px;margin-bottom:18px;display:flex}.member-school-panel__title{color:#111;margin:0;font-size:24px;font-weight:800}.member-school-panel__desc{color:#666;margin:8px 0 0;font-size:14px}.member-school-panel__control{min-width:220px}.member-school-panel__label{color:#333;margin-bottom:8px;font-size:13px;font-weight:700;display:block}.member-school-panel__select{min-width:220px}.member-school-limit-banner{background:linear-gradient(#eef7ff 0%,#f8fbff 100%);border:1px solid #d7e7f5;border-radius:18px;justify-content:space-between;align-items:center;gap:16px;margin:0 0 18px;padding:16px 18px;display:flex}.member-school-limit-banner strong{color:#163950;font-size:16px}.member-school-limit-banner span{color:#476274;font-size:14px}.member-school-search{margin-bottom:20px}.member-school-search__input{color:#111;background:#fff;border:1px solid #d4d4d4;border-radius:14px;width:100%;padding:14px 16px;font-family:inherit;font-size:16px;transition:border-color .2s,box-shadow .2s}.member-school-search__input:focus{border-color:#111;outline:none;box-shadow:0 0 0 4px #00000014}.member-school-search__input:disabled{color:#999;background:#f3f3f3}.member-school-browser{margin-top:20px}.member-school-browser__head{color:#444;justify-content:space-between;align-items:center;margin-bottom:14px;font-size:14px;display:flex}.member-school-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.member-school-card{text-align:left;cursor:pointer;background:#fff;border:1px solid #dcdcdc;border-radius:16px;flex-direction:column;align-items:flex-start;gap:4px;padding:14px 15px;transition:transform .18s,box-shadow .18s,border-color .18s;display:flex}.member-school-card:hover:not(:disabled){border-color:#111;transform:translateY(-1px);box-shadow:0 10px 20px #00000014}.member-school-card:disabled{cursor:default}.member-school-card--saved{background:linear-gradient(#edf7ff 0%,#f7fbff 100%);border-color:#8fc0e5}.member-school-card--pending{background:linear-gradient(#fff6d8 0%,#fffaf0 100%);border-color:#e7c86a}.member-school-card--removed{background:linear-gradient(#fff1f1 0%,#fff9f9 100%);border-color:#e1b6b6}.member-school-card__name{color:#111;font-size:15px;font-weight:700}.member-school-card__meta{color:#5f6d7c;font-size:11px}.member-school-empty{color:#777;text-align:center;border:1px dashed #d7d7d7;border-radius:16px;padding:24px}.member-school-empty--compact{margin-top:14px;padding:18px}.member-school-selection-lists{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:22px;display:grid}.member-school-selection{border:1px solid #ebebeb;border-radius:18px;padding:18px}.member-school-selection--saved{background:linear-gradient(#f7fbff 0%,#fff 100%)}.member-school-selection--pending{background:linear-gradient(#fffaf0 0%,#fff 100%)}.member-school-selection--removed{background:linear-gradient(#fff8f8 0%,#fff 100%)}.member-school-selection__header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.member-school-selection__header h4{color:#111;margin:0;font-size:16px}.member-school-selection__header span{color:#666;font-size:12px}.member-school-selection__list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.member-school-selection__empty{color:#777;margin:0;font-size:14px}.member-school-pill{border-radius:14px;justify-content:space-between;align-items:center;gap:14px;padding:14px;display:flex}.member-school-pill--saved{background:#eaf5ff;border:1px solid #cbe3f4}.member-school-pill--pending{background:#fff4cf;border:1px solid #edd589}.member-school-pill--removed{background:#fff1f1;border:1px solid #efc7c7}.member-school-pill__body{flex-direction:column;gap:2px;display:flex}.member-school-pill__body strong{color:#111;font-size:15px}.member-school-pill__body small{color:#6a6a6a;font-size:12px}.member-school-pill__remove{color:#fff;cursor:pointer;background:#d9534f;border:0;border-radius:10px;flex:none;padding:10px 12px;font-size:13px;font-weight:700}.member-school-pill__remove:disabled{color:#666;cursor:not-allowed;background:#d0d0d0}.member-school-pill__remove--secondary{background:#6b7681}.member-school-pill__remove--secondary:hover{background:#57616b}.member-school-message{border-radius:12px;margin-top:18px;padding:12px 14px;font-size:14px;font-weight:600}.member-school-message--success{color:#2d6b39;background:#edf8ef;border:1px solid #b6dfbf}.member-school-message--error{color:#a33b3b;background:#fff0f0;border:1px solid #efc4c4}.member-school-message--info{color:#34566f;background:#eef7ff;border:1px solid #c7def0}.member-school-save{margin-top:18px}.member-logout-button{margin-top:28px}.page-member--embedded{min-height:0;padding-top:0}.member-wrap--embedded{max-width:100%}.member-wrap--embedded .member-school-panel{margin-top:0}.logout-button{color:#666;cursor:pointer;background:0 0;border:1.5px solid #ccc;border-radius:10px;width:160px;margin:0 auto;padding:12px;font-size:15px;transition:border-color .2s,color .2s;display:block}.logout-button:hover{color:#333;border-color:#888}.dashboard-card--action{text-align:left;cursor:pointer;border:1.5px solid #cfdff0}.dashboard-card--action:hover{border-color:#8bbce0}.admin-member-panel{background:#fff;border:1px solid #e5e5e5;border-radius:20px;margin:12px 0 34px;padding:20px}.admin-member-panel__header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:12px;display:flex}.admin-member-panel__header h3{color:#111;margin:0;font-size:20px}.admin-success{color:#2f8f4e;margin:0 0 10px;font-size:14px;font-weight:600}.admin-member-table-wrap{border:1px solid #ececec;border-radius:14px;margin-bottom:16px;overflow-x:auto}.admin-member-table{border-collapse:collapse;width:100%;min-width:700px}.admin-member-table th,.admin-member-table td{text-align:left;border-bottom:1px solid #efefef;padding:12px 10px;font-size:14px}.admin-member-table th{color:#333;background:#f8fafc;font-weight:700}.admin-member-row{cursor:pointer}.admin-member-row.active{background:#b8ddff}.admin-member-row.active td{color:#083457;font-weight:700}.admin-empty-cell{text-align:center;color:#888}.admin-edit-card{border-top:1px solid #ececec;padding-top:16px}.admin-edit-card h4{margin:0 0 14px;font-size:18px}.admin-edit-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 16px;display:grid}.admin-edit-grid label{color:#222;flex-direction:column;gap:8px;font-size:13px;font-weight:700;display:flex}.admin-edit-grid input,.admin-edit-grid textarea{border:1px solid #d5d5d5;border-radius:10px;padding:11px 12px;font-family:inherit;font-size:14px}.admin-edit-grid textarea{resize:vertical}.admin-edit-checkbox{align-items:center;padding-top:24px;flex-direction:row!important;gap:10px!important}.admin-edit-full{grid-column:1/-1}.admin-edit-actions{gap:12px;margin-top:14px;display:flex}.admin-edit-actions .submit-button{width:auto;min-width:140px;margin-top:0}.admin-delete-button{color:#b93535;cursor:pointer;background:#fff5f5;border:1.5px solid #d86666;border-radius:14px;min-width:140px;padding:12px 16px;font-size:15px;font-weight:700}.admin-delete-button:hover{background:#ffeaea}@media (width<=600px){.dashboard-grid{grid-template-columns:1fr}.admin-member-panel{padding:14px}.admin-member-panel__header{flex-direction:column;align-items:flex-start}.member-school-panel__header,.member-school-selection-lists{grid-template-columns:1fr;display:grid}.member-school-limit-banner{flex-direction:column;align-items:flex-start}.member-school-panel__header{align-items:stretch}.member-school-panel__control,.member-school-panel__select{width:100%;min-width:0}.member-school-grid,.admin-edit-grid{grid-template-columns:1fr}.admin-edit-actions{flex-direction:column}.login-wrap,.admin-wrap,.member-wrap,.student-preset-wrap{padding:0 16px}.form-row{grid-template-columns:1fr}}.preset-badge{color:#fff;background:#9c27b0}.student-preset-panel{background:#fff;border:1px solid #e5e5e5;border-radius:20px;margin:12px 0 34px;padding:24px;box-shadow:0 18px 36px #0000000a}.student-preset-panel__header{margin-bottom:24px}.student-preset-panel__header p{color:#666;margin:0;font-size:14px;line-height:1.6}.student-preset-message{border:1px solid #0000;border-radius:12px;margin-bottom:18px;padding:12px 14px;font-size:14px;font-weight:600}.student-preset-message--success{color:#2d6b39;background:#edf8ef;border-color:#b6dfbf}.student-preset-message--error{color:#a33b3b;background:#fff0f0;border-color:#efc4c4}.student-preset-message--info{color:#34566f;background:#eef7ff;border-color:#c7def0}.student-preset-form{background:linear-gradient(#f9fbff 0%,#fff 100%);border:1px solid #e0ebf7;border-radius:16px;margin-bottom:24px;padding:20px}.student-preset-form__row{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.student-preset-form__row:last-of-type{margin-bottom:0}.student-preset-form label{color:#111;font-size:14px;font-weight:700}.student-preset-form .form-input,.student-preset-form .form-select{color:#111;background:#fff;border:1px solid #d4d4d4;border-radius:12px;width:100%;padding:12px 14px;font-family:inherit;font-size:15px;transition:border-color .2s,box-shadow .2s}.student-preset-form .form-input:focus,.student-preset-form .form-select:focus{border-color:#9c27b0;outline:none;box-shadow:0 0 0 3px #9c27b014}.student-preset-form .form-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23999' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.student-preset-form__actions{gap:10px;margin-top:20px;display:flex}.submit-button.student-preset-add,.student-preset-form .submit-button{background:#9c27b0;flex:1;margin-top:0;padding:12px 16px;font-size:14px}.submit-button.student-preset-add:hover,.student-preset-form .submit-button:hover{background:#7b1fa2}.cancel-button:hover{color:#333;background:#efefef;border-color:#888}.student-preset-list{background:linear-gradient(#fafbff 0%,#fff 100%);border:1px solid #ebebeb;border-radius:16px;padding:18px}.student-preset-list__header span{color:#999;font-size:13px;font-weight:600}.student-preset-list__empty{text-align:center;color:#999;padding:20px;font-size:14px}.student-preset-item{background:#fff;border:1px solid #e8e8e8;border-radius:12px;justify-content:space-between;align-items:center;gap:12px;padding:14px;transition:border-color .2s,box-shadow .2s;display:flex}.student-preset-item:hover{border-color:#9c27b0}.student-preset-item__body{flex-direction:column;flex:1;gap:2px;display:flex}.student-preset-item__name{color:#111;font-size:15px;font-weight:700}.student-preset-item__school{color:#666;font-size:13px}.student-preset-item__meta{color:#999;font-size:12px}.student-preset-item__actions{flex-wrap:nowrap;gap:8px;display:flex}.preset-edit-button,.preset-delete-button{color:#666;cursor:pointer;background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:8px 12px;font-size:13px;font-weight:600;transition:border-color .2s,color .2s,background-color .2s}.preset-edit-button:hover:not(:disabled){color:#9c27b0;background:#f9f9ff;border-color:#9c27b0}.preset-delete-button{color:#c2185b;border-color:#e8b6d0}.preset-delete-button:hover:not(:disabled){background:#fff3f5;border-color:#c2185b}.workbook-badge{color:#fff;background:#ff9800}.page-workbook,.page-workbook--embedded{min-height:70vh;padding-top:50px}.page-workbook--embedded{min-height:0;padding-top:0}.workbook-wrap,.workbook-wrap--embedded{width:100%;max-width:860px;margin:0 auto}.workbook-wrap--embedded{max-width:100%}.workbook-message{border-radius:12px;margin-bottom:18px;padding:12px 14px;font-size:14px;font-weight:600}.workbook-message--success{color:#2d6b39;background:#edf8ef;border:1px solid #b6dfbf}.workbook-message--error{color:#a33b3b;background:#fff0f0;border:1px solid #efc4c4}.workbook-message--info{color:#34566f;background:#eef7ff;border:1px solid #c7def0}.workbook-section{background:#fff;border:1px solid #e5e5e5;border-radius:20px;margin-bottom:28px;padding:20px;box-shadow:0 18px 36px #0000000a}.workbook-section__header{border-bottom:2px solid #f0f0f0;margin-bottom:16px;padding-bottom:12px}.workbook-section__header h3{color:#111;margin:0;font-size:20px;font-weight:800}.workbook-tabs{gap:8px;margin-bottom:14px;display:flex}.workbook-tab{color:#666;cursor:pointer;background:#fff;border:1px solid #d6dce3;border-radius:12px;flex:1;padding:10px 12px;font-size:13px;font-weight:700;transition:border-color .2s,background-color .2s,color .2s}.workbook-tab:hover{color:#ff9800;background:#fffbf5;border-color:#ff9800}.workbook-items{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.workbook-items--two-column{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.workbook-checkbox{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;display:flex}.workbook-checkbox input[type=checkbox]{cursor:pointer;accent-color:#ff9800;width:18px;height:18px}.workbook-checkbox span{color:#333;font-size:14px;font-weight:500}.workbook-create-button{background:#ff9800;width:100%;margin-top:14px;padding:12px 16px;font-size:14px}.workbook-create-button:hover:not(:disabled){background:#f57c00}.workbook-create-button:disabled{opacity:.65;cursor:not-allowed}.workbook-section--exam{background:linear-gradient(#fef5e7 0%,#fff9f0 100%);border-color:#ffe0cc}.exam-total-display{background:#fff8f0;border:1px solid #ffd699;border-radius:12px;align-items:center;gap:12px;margin-bottom:16px;padding:14px 16px;font-size:14px;font-weight:600;display:flex}.exam-total-display strong{color:#ff9800;font-size:18px}.exam-total-valid{color:#4caf50;font-weight:700}.exam-total-invalid{color:#d32f2f;font-weight:700}.exam-items{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:16px;display:grid}.exam-item{align-items:center;gap:10px;display:flex}.exam-item label{color:#333;flex:1;font-size:13px;font-weight:600}.exam-input{color:#111;text-align:center;background:#fff;border:1px solid #d4d4d4;border-radius:8px;width:60px;padding:8px 10px;font-size:14px;font-weight:600;transition:border-color .2s,box-shadow .2s}.exam-input:focus{border-color:#ff9800;outline:none;box-shadow:0 0 0 3px #ff98001a}.workbook-logout-button{margin-top:28px}@media (width<=768px){.admin-menu-tabs,.member-menu-tabs{grid-template-columns:repeat(2,minmax(0,1fr))}.workbook-items--two-column,.exam-items{grid-template-columns:1fr}.workbook-tabs{flex-direction:column}}.page-student-preset,.page-student-preset--embedded{min-height:70vh;padding-top:50px}.page-student-preset--embedded{min-height:0;padding-top:0}.student-preset-wrap,.student-preset-wrap--embedded{width:100%;max-width:860px;margin:0 auto}.student-preset-wrap--embedded{max-width:100%}.student-preset-message{border-radius:12px;margin-bottom:18px;padding:12px 14px;font-size:14px;font-weight:600}.student-preset-message--success{color:#2d6b39;background:#edf8ef;border:1px solid #b6dfbf}.student-preset-message--error{color:#a33b3b;background:#fff0f0;border:1px solid #efc4c4}.student-preset-message--info{color:#34566f;background:#eef7ff;border:1px solid #c7def0}.student-preset-panel{background:#fff;border:1px solid #e5e5e5;border-radius:20px;margin-bottom:28px;padding:20px;box-shadow:0 18px 36px #0000000a}.student-preset-panel__header{border-bottom:2px solid #f0f0f0;margin-bottom:20px;padding-bottom:16px}.student-preset-panel__header h3{color:#111;margin:0 0 8px;font-size:22px;font-weight:800}.student-preset-panel__header p{color:#666;margin:0;font-size:14px}.student-preset-form{margin-bottom:28px}.student-preset-form__row{margin-bottom:16px}.student-preset-form__row label{color:#333;margin-bottom:8px;font-size:14px;font-weight:600;display:block}.student-preset-form__row input,.student-preset-form__row select{border:1px solid #d6dce3;border-radius:8px;width:100%;padding:10px 12px;font-family:inherit;font-size:14px}.student-preset-form__row input:focus,.student-preset-form__row select:focus{border-color:#4caf50;outline:none;box-shadow:0 0 0 3px #4caf501a}.student-preset-form__row input:disabled,.student-preset-form__row select:disabled{cursor:not-allowed;background:#f5f5f5}.student-preset-workbook{background:#fafafa;border:1px solid #e5e5e5;border-radius:12px;margin-bottom:28px;padding:20px}.student-preset-workbook h4{color:#111;margin:0 0 12px;font-size:18px;font-weight:700}.student-preset-workbook-tabs{gap:8px;margin-bottom:16px;display:flex}.student-preset-workbook-tab{color:#666;cursor:pointer;background:#fff;border:1px solid #d6dce3;border-radius:8px;flex:1;padding:10px 12px;font-size:13px;font-weight:600;transition:all .2s}.student-preset-workbook-tab:hover{color:#4caf50;background:#f1f8f4;border-color:#4caf50}.student-preset-workbook-section{margin-bottom:20px}.student-preset-workbook-section h5{color:#333;margin:0 0 12px;font-size:15px;font-weight:600}.student-preset-workbook-items{flex-direction:column;gap:8px;display:flex}.student-preset-workbook-items--two-column{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.student-preset-workbook-checkbox{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:6px;align-items:center;gap:8px;padding:8px;transition:background .2s;display:flex}.student-preset-workbook-checkbox:hover{background:#f0f0f0}.student-preset-workbook-checkbox input[type=checkbox]{cursor:pointer;accent-color:#4caf50;width:18px;height:18px}.student-preset-workbook-checkbox span{color:#333;font-size:14px;font-weight:500}.student-preset-exam{background:#fff8f0;border:1px solid #ffe0cc;border-radius:12px;margin-bottom:28px;padding:20px}.student-preset-exam h4{color:#111;margin:0 0 12px;font-size:18px;font-weight:700}.student-preset-exam-total{background:#fff;border:1px solid #ffd699;border-radius:8px;align-items:center;gap:8px;margin-bottom:16px;padding:12px 16px;font-size:14px;font-weight:600;display:flex}.exam-valid{color:#4caf50;font-weight:700}.exam-invalid{color:#d32f2f;font-weight:700}.student-preset-exam-items{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.student-preset-exam-item{flex-direction:column;gap:6px;display:flex}.student-preset-exam-item label{color:#333;font-size:13px;font-weight:600}.student-preset-exam-input{text-align:center;border:1px solid #ffd699;border-radius:6px;padding:8px 10px;font-size:14px;font-weight:600}.student-preset-exam-input:focus{border-color:orange;outline:none;box-shadow:0 0 0 3px #ffa5001a}.student-preset-form__actions{gap:12px;margin-bottom:20px;display:flex}.submit-button{color:#fff;cursor:pointer;background:#4caf50;border:none;border-radius:8px;flex:1;padding:12px 16px;font-size:14px;font-weight:600;transition:background .2s}.submit-button:hover:not(:disabled){background:#45a049}.submit-button:disabled{opacity:.6;cursor:not-allowed}.cancel-button{color:#333;cursor:pointer;background:#f0f0f0;border:1px solid #d6dce3;border-radius:8px;flex:1;padding:12px 16px;font-size:14px;font-weight:600;transition:all .2s}.cancel-button:hover:not(:disabled){background:#e0e0e0;border-color:#bbb}.cancel-button:disabled{opacity:.6;cursor:not-allowed}.student-preset-list{margin-bottom:28px}.student-preset-list__header{border-bottom:2px solid #f0f0f0;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;display:flex}.student-preset-list__header h4{color:#111;margin:0;font-size:18px;font-weight:700}.student-preset-list__header span{color:#666;background:#f0f0f0;border-radius:6px;padding:4px 8px;font-size:14px;font-weight:600}.student-preset-list__empty{text-align:center;color:#999;background:#fafafa;border:1px dashed #ddd;border-radius:12px;padding:40px 20px;font-size:14px}.student-preset-items{flex-direction:column;gap:10px;display:flex}.student-preset-item{background:#fff;border:1px solid #e5e5e5;border-radius:12px;justify-content:space-between;align-items:center;gap:16px;padding:16px 20px;transition:all .2s;display:flex;box-shadow:0 2px 8px #0000000a}.student-preset-item:hover{border-color:#d6dce3;box-shadow:0 4px 12px #00000014}.student-preset-item.is-editing{background:#f9fff9;border-color:#4caf50}.student-preset-item__body{flex:1;min-width:0}.student-preset-item__name{color:#111;margin-bottom:4px;font-size:16px;font-weight:700;display:block}.student-preset-item__school{color:#666;margin-bottom:6px;font-size:14px;display:block}.student-preset-item__meta{color:#999;font-size:12px;display:block}.student-preset-item__actions{flex-shrink:0;gap:8px;display:flex}.preset-edit-button,.preset-delete-button{cursor:pointer;border:1px solid #d6dce3;border-radius:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s}.preset-edit-button{color:#4caf50;background:#fff;border-color:#4caf50}.preset-edit-button:hover:not(:disabled){background:#f1f8f4}.preset-delete-button{color:#d32f2f;background:#fff;border-color:#d32f2f}.preset-delete-button:hover:not(:disabled){background:#fff0f0}.preset-edit-button:disabled,.preset-delete-button:disabled{opacity:.5;cursor:not-allowed}.student-preset-logout-button{margin-top:28px}.student-preset-panel__header--with-actions{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.student-preset-toolbar{flex-shrink:0;gap:8px;display:flex}.student-preset-view-button{color:#555;cursor:pointer;background:#fff;border:1px solid #d6dce3;border-radius:999px;padding:10px 14px;font-size:13px;font-weight:700;transition:all .2s}.student-preset-view-button:hover:not(:disabled){color:#2e7d32;border-color:#4caf50}.student-preset-view-button.is-active{color:#2e7d32;background:#eef8ef;border-color:#4caf50}.student-preset-view-button:disabled{opacity:.5;cursor:not-allowed}.student-preset-list-view,.student-preset-editor{flex-direction:column;gap:20px;display:flex}.student-preset-school-groups{flex-direction:column;gap:16px;display:flex}.student-preset-school-group{background:linear-gradient(#fff 0%,#fbfcff 100%);border:1px solid #e3e8ef;border-radius:16px;padding:18px}.student-preset-school-group__header{border-bottom:1px solid #eef1f5;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;padding-bottom:12px;display:flex}.student-preset-school-group__header strong{color:#111;font-size:16px;display:block}.student-preset-school-group__header span{color:#75808f;margin-top:4px;font-size:12px;display:block}.student-preset-school-group__header em{color:#4f5b67;background:#f0f4f8;border-radius:999px;padding:6px 10px;font-size:12px;font-style:normal;font-weight:700}.student-preset-item__content-button{text-align:left;cursor:pointer;background:0 0;border:0;flex:1;min-width:0;margin:0;padding:0}.student-preset-item__content-button:focus-visible{outline-offset:6px;border-radius:8px;outline:2px solid #4caf50}.student-preset-editor__topbar{justify-content:space-between;align-items:center;gap:12px;display:flex}.student-preset-editor__editing-badge{color:#2e7d32;background:#eef8ef;border-radius:999px;align-items:center;padding:6px 10px;font-size:12px;font-weight:700;display:inline-flex}@media (width<=768px){.student-preset-panel__header--with-actions,.student-preset-school-group__header,.student-preset-editor__topbar{flex-direction:column;align-items:stretch}.student-preset-toolbar{width:100%}.student-preset-view-button{flex:1}.student-preset-exam-items{grid-template-columns:repeat(3,minmax(0,1fr))}.student-preset-workbook-items--two-column{grid-template-columns:1fr}.student-preset-item{flex-direction:column;align-items:stretch}.student-preset-item__actions{width:100%}.preset-edit-button,.preset-delete-button{flex:1}}.page-report{padding:0}.report-page-wrap{flex-direction:column;gap:12px;padding:16px;display:flex}.report-action-bar{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.report-action-title{color:#1a237e;flex:1;margin:0;font-size:18px;font-weight:700}.report-action-buttons{gap:8px;display:flex}.report-share-btn{background:#1565c0}.report-share-msg{color:#555;width:100%;margin:0;font-size:13px}.report-scroll-viewport{-webkit-overflow-scrolling:touch;background:#e8e8e8;border:1px solid #e0e0e0;border-radius:4px;padding:24px;overflow:auto}.report-a4{box-sizing:border-box;color:#212121;background:#fff;padding:48px 56px;font-family:Malgun Gothic,Apple SD Gothic Neo,sans-serif;box-shadow:0 4px 24px #0000002e}.report-a4__header{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.report-a4__top-divider{background:#1a237e;border-radius:4px;width:100%;height:8px}.report-a4__logo-area{flex-direction:column;display:flex}.report-a4__brand{color:#1a237e;letter-spacing:-1px;font-size:22px;font-weight:800}.report-a4__brand-sub{color:#5c6bc0;letter-spacing:1px;font-size:11px}.report-a4__title-area{text-align:center}.report-a4__main-title{color:#1a237e;margin:0 0 4px;font-size:24px;font-weight:800}.report-a4__sub-title{color:#7986cb;letter-spacing:1px;margin:0;font-size:12px}.report-a4__period-area{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.report-a4__period-label{color:#888;font-size:11px}.report-a4__period-value{color:#1a237e;font-size:14px;font-weight:700}.report-a4__divider{background:linear-gradient(90deg,#1a237e 0%,#7986cb 100%);border-radius:2px;height:2px;margin:14px 0}.report-a4__info-grid{grid-template-columns:repeat(3,1fr);gap:10px 16px;margin-bottom:4px;display:grid}.report-a4__info-item{background:#f5f6ff;border-radius:6px;flex-direction:column;gap:2px;padding:8px 12px;display:flex}.report-a4__info-label{color:#7986cb;text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.report-a4__info-value{color:#212121;font-size:15px;font-weight:700}.report-a4__score{color:#1a237e;font-size:18px}.report-a4__section{margin-bottom:18px}.report-a4__section-title{color:#1a237e;border-left:4px solid #1a237e;margin:0 0 10px;padding-left:8px;font-size:14px;font-weight:700}.report-a4__table{border-collapse:collapse;width:100%;font-size:12px}.report-a4__table th{color:#fff;text-align:center;background:#1a237e;border:1px solid #283593;padding:7px 8px;font-weight:600}.report-a4__table td{text-align:center;color:#333;border:1px solid #e0e0e0;padding:6px 8px}.report-a4__table tbody tr:nth-child(2n) td{background:#f5f6ff}.report-a4__td-score{color:#1a237e;font-weight:700}.report-a4__comment-box{background:#f5f6ff;border-left:4px solid #5c6bc0;border-radius:4px;padding:14px 16px}.report-a4__comment-text{color:#333;margin:0;font-size:13px;line-height:1.8}.report-a4__chart{flex-direction:column;gap:8px;display:flex}.report-a4__bar-row{align-items:center;gap:10px;display:flex}.report-a4__bar-label{color:#555;flex-shrink:0;width:50px;font-size:12px}.report-a4__bar-track{background:#e8eaf6;border-radius:8px;flex:1;height:16px;overflow:hidden}.report-a4__bar-fill{background:linear-gradient(90deg,#1a237e 0%,#5c6bc0 100%);border-radius:8px;height:100%;transition:width .4s}.report-a4__bar-value{color:#1a237e;text-align:right;flex-shrink:0;width:36px;font-size:12px;font-weight:700}.report-a4__footer{color:#aaa;border-top:1px solid #e0e0e0;justify-content:space-between;margin-top:24px;padding-top:12px;font-size:10px;display:flex}@media print{.report-action-bar,.report-scroll-viewport{background:0 0;border:none;padding:0;display:block;overflow:visible}.report-a4{box-shadow:none;width:210mm;min-height:297mm;padding:15mm 20mm}}
