:root{--font-family: "Noto Sans JP", "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--primary: #6366f1;--primary-500: #6366f1;--primary-400: #818cf8;--primary-600: #4f46e5;--primary-700: #4338ca;--secondary-400: #22c55e;--accent-400: #f59e0b;--accent-500: #d97706;--danger: #ef4444;--text-primary: #1a1a2e;--text-secondary: #555570;--text-tertiary: #8888a0;--bg-primary: #f5f5f8;--bg-secondary: #eeeef2;--bg-tertiary: #e4e4ea;--surface-glass: rgba(255, 255, 255, .85);--surface-glass-hover: rgba(255, 255, 255, .95);--surface-glass-active: rgba(255, 255, 255, 1);--surface-1: #ffffff;--border-subtle: rgba(0, 0, 0, .06);--border-medium: rgba(0, 0, 0, .1);--border-strong: rgba(0, 0, 0, .18);--border-default: rgba(0, 0, 0, .1);--border-glow: rgba(99, 102, 241, .3);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 18px;--radius-2xl: 24px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--transition-fast: .15s ease;--transition-smooth: .25s cubic-bezier(.4, 0, .2, 1);--shadow-card: 0 2px 12px rgba(0, 0, 0, .08), 0 0 0 1px rgba(0, 0, 0, .04);--shadow-glow: 0 0 20px rgba(99, 102, 241, .12)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background:#fff;color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased}.juku-portal-page{overflow-x:hidden}.juku-portal-page .wp-site-blocks,.juku-portal-page main,.juku-portal-page .wp-block-group.alignfull{max-width:100vw;overflow-x:clip}.juku-portal-page .wp-block-group.alignfull{width:100%;margin-left:0!important;margin-right:0!important;padding-left:0!important;padding-right:0!important}.student-app{max-width:600px;margin:0 auto;padding:var(--space-4);min-height:100vh}.student-login{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;gap:var(--space-6)}.student-login-card{background:var(--surface-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-medium);border-radius:var(--radius-2xl);padding:var(--space-8) var(--space-6);width:100%;max-width:380px;box-shadow:var(--shadow-card)}.student-login-card h1{text-align:center;font-size:var(--text-xl);margin-bottom:var(--space-6);background:linear-gradient(135deg,var(--primary-600),var(--primary-700));-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:.02em}.login-form{display:flex;flex-direction:column;gap:var(--space-3)}.login-form input{width:100%;padding:12px 16px;background:#f5f5f8;border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-family);font-size:var(--text-sm);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.login-form input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #6366f126}.login-form button{padding:12px;background:linear-gradient(135deg,var(--primary-600),var(--primary-500));border:none;border-radius:var(--radius-md);color:#fff;font-family:var(--font-family);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:opacity var(--transition-fast),transform var(--transition-fast);box-shadow:0 4px 12px #6366f14d}.login-form button:hover{opacity:.9;transform:translateY(-1px)}.login-form button:disabled{opacity:.5;cursor:not-allowed;transform:none}.login-error{font-size:var(--text-xs);color:var(--danger);text-align:center}.student-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-5) var(--space-4);margin:calc(var(--space-4) * -1) calc(var(--space-4) * -1) var(--space-4);background:linear-gradient(135deg,#6366f114,#8b5cf60a,#6366f105);border-bottom:1px solid var(--border-medium);position:relative}.student-header:after{content:"";position:absolute;bottom:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(99,102,241,.4),transparent)}.student-header-info h2{font-size:var(--text-lg);font-weight:700;letter-spacing:.01em;color:var(--text-primary);-webkit-background-clip:unset;-webkit-text-fill-color:unset}.student-header-info span{font-size:var(--text-xs);color:var(--primary-400);font-weight:500}.student-logout{padding:8px 14px;background:var(--surface-glass);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-xs);font-weight:500;cursor:pointer;font-family:var(--font-family);transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),opacity var(--transition-fast)}.student-logout:hover{color:var(--text-primary);border-color:var(--border-strong);background:var(--surface-glass-hover)}.student-tabs{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-bottom:var(--space-5);padding:4px;background:var(--surface-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.student-tab{flex:1;padding:10px 14px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-tertiary);font-size:var(--text-xs);font-weight:600;cursor:pointer;white-space:nowrap;font-family:var(--font-family);transition:background var(--transition-smooth),color var(--transition-smooth),border-color var(--transition-smooth),box-shadow var(--transition-smooth);text-align:center}.student-tab.active{background:linear-gradient(135deg,#6366f11f,#8b5cf614);color:var(--primary-600);box-shadow:0 2px 8px #6366f11f,inset 0 0 0 1px #6366f126}.student-tab:hover:not(.active){color:var(--text-secondary);background:var(--surface-glass-hover)}.student-tabs.student-tabs-sub{margin-top:-12px;margin-bottom:var(--space-4);padding:3px;background:#00000005;border-color:#0000000a}.student-tab.sub{padding:6px 8px;font-size:11px}.student-tab.sub .tab-icon{font-size:12px}.student-tab.sub .tab-label{font-size:10px}.tab-badge{position:absolute;top:2px;right:4px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:#ef4444;color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;animation:badgePulse 2s infinite}@keyframes badgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.student-card{background:var(--surface-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-medium);border-radius:var(--radius-xl);padding:var(--space-5);margin-bottom:var(--space-3);box-shadow:var(--shadow-card);transition:border-color var(--transition-smooth),box-shadow var(--transition-smooth)}.student-card:hover{border-color:var(--border-strong)}.student-card h3{font-size:var(--text-sm);font-weight:700;margin-bottom:var(--space-4);color:var(--text-primary);display:flex;align-items:center;gap:var(--space-2)}.student-card-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;font-size:var(--text-sm);border-bottom:1px solid var(--border-subtle)}.student-card-item:last-child{border-bottom:none;padding-bottom:0}.student-card-label{color:var(--text-secondary);font-weight:500}.student-card-value{color:var(--text-primary);font-weight:600}.study-hours-card{display:flex;align-items:center;gap:var(--space-3)}.study-hours-slider{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:8px;border-radius:4px;background:linear-gradient(90deg,var(--primary-600),var(--primary-400),#c084fc);outline:none;cursor:pointer}.study-hours-slider::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:0 2px 8px #0000004d,0 0 0 2px var(--primary-500);cursor:pointer;transition:transform var(--transition-fast)}.study-hours-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}.study-hours-value{font-weight:800;font-size:var(--text-lg);min-width:52px;text-align:right;color:var(--primary-400);font-variant-numeric:tabular-nums}.study-hours-save{padding:8px 16px;background:linear-gradient(135deg,var(--primary-600),var(--primary-500));border:none;border-radius:var(--radius-md);color:#fff;font-size:var(--text-xs);font-weight:600;cursor:pointer;font-family:var(--font-family);transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),opacity var(--transition-fast);box-shadow:0 2px 8px #6366f14d}.study-hours-save:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.study-hours-save:disabled{opacity:.5;cursor:not-allowed;transform:none}.subject-badge{font-size:11px;padding:2px 8px;border-radius:var(--radius-sm);background:#6366f11f;color:var(--primary-400);font-weight:600;letter-spacing:.02em}.action-buttons-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2);margin-top:var(--space-3)}.action-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;background:var(--surface-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:11px;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:background var(--transition-smooth),color var(--transition-smooth),border-color var(--transition-smooth),box-shadow var(--transition-smooth);text-align:center;line-height:1.3}.action-btn:hover{border-color:var(--border-strong);background:var(--surface-glass-hover);transform:translateY(-1px)}.action-btn.active{border-color:var(--border-glow);background:var(--surface-glass-active);color:var(--text-primary);box-shadow:var(--shadow-glow)}.action-btn-icon{font-size:20px;line-height:1}.action-btn.absence{--btn-accent: #a855f7}.action-btn.absence.active{border-color:#a855f766;background:#a855f71a;box-shadow:0 0 16px #a855f726}.action-btn.makeup{--btn-accent: #22c55e}.action-btn.makeup.active{border-color:#22c55e66;background:#22c55e1a;box-shadow:0 0 16px #22c55e26}.action-btn.cancel{--btn-accent: #ef4444}.action-btn.cancel.active{border-color:#ef44444d;background:#ef444414;box-shadow:0 0 16px #ef44441f}.action-form{margin-top:var(--space-3);padding:var(--space-4);background:var(--surface-glass);border:1px solid var(--border-medium);border-radius:var(--radius-lg);animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.action-form-title{font-size:var(--text-xs);font-weight:700;margin-bottom:var(--space-3);display:flex;align-items:center;gap:var(--space-2)}.action-form-title.absence{color:#c084fc}.action-form-title.makeup{color:#4ade80}.action-form-title.cancel{color:#f87171}.action-form label{display:block;font-size:var(--text-xs);color:var(--text-tertiary);margin-bottom:4px;font-weight:500}.action-form select,.action-form input[type=date],.action-form input[type=text],.action-form input[type=time],.action-form textarea{width:100%;padding:10px 12px;background:#f5f5f8;border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-family);font-size:var(--text-sm);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.action-form select:focus,.action-form input:focus,.action-form textarea:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #6366f11a}.action-form .form-group{margin-bottom:var(--space-3)}.action-form .form-group-row{display:flex;gap:var(--space-2);align-items:flex-end;margin-bottom:var(--space-3)}.action-form .form-group-row>div{flex:1}.reason-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;margin-bottom:6px}.reason-chip{padding:5px 14px;font-size:11px;border-radius:20px;border:1px solid var(--border-medium);background:transparent;color:var(--text-secondary);cursor:pointer;font-family:var(--font-family);font-weight:500;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),opacity var(--transition-fast)}.reason-chip:hover{border-color:var(--border-strong);color:var(--text-primary)}.reason-chip.selected{border-color:#a855f7;background:#a855f726;color:#c084fc;font-weight:600}.action-submit{width:100%;padding:10px;border:none;border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),opacity var(--transition-fast)}.action-submit.absence{background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;box-shadow:0 4px 12px #7c3aed4d}.action-submit.makeup{background:linear-gradient(135deg,#059669,#22c55e);color:#fff;box-shadow:0 4px 12px #0596694d}.action-submit.cancel{background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff;box-shadow:0 4px 12px #dc26264d}.action-submit:hover{transform:translateY(-1px);filter:brightness(1.1)}.action-submit:disabled{opacity:.4;cursor:not-allowed;transform:none;filter:none}.quick-date-btn{padding:8px 14px;font-size:var(--text-xs);font-weight:600;background:linear-gradient(135deg,var(--primary-600),var(--primary-500));color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;font-family:var(--font-family);transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),opacity var(--transition-fast)}.quick-date-btn:hover{transform:translateY(-1px)}.status-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:3px 10px;border-radius:20px;font-weight:600;letter-spacing:.02em}.status-badge.pending{background:#f59e0b1f;color:#b45309}.status-badge.approved{background:#22c55e1f;color:#059669}.status-badge.rejected{background:#ef44441f;color:#dc2626}.student-empty{text-align:center;padding:var(--space-6);color:var(--text-tertiary);font-size:var(--text-sm);font-style:italic}.test-form{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-3)}.test-form input,.test-form select{box-sizing:border-box;min-width:0;padding:10px 12px;background:#f5f5f8;border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-family);font-size:var(--text-sm);outline:none;transition:border-color var(--transition-fast)}.test-form input:focus,.test-form select:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #6366f11a}.test-form .form-row{display:flex;gap:var(--space-2)}.test-form .form-row>*{flex:1}.test-result-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.test-result-header h3{min-width:0}.test-result-toggle{flex:0 0 auto;white-space:nowrap}.test-result-form .test-meta-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(11rem,.65fr);align-items:center;gap:var(--space-2)}.test-result-form .test-score-row{display:grid;grid-template-columns:minmax(4.5rem,6rem) minmax(0,1fr);align-items:center;gap:var(--space-2)}.test-result-form .test-score-row>*,.test-result-form .test-meta-row>*{min-width:0}.test-subject-label{color:var(--text-secondary);font-size:var(--text-xs);font-weight:600;line-height:1.3;overflow-wrap:anywhere}.test-score-input{width:100%;min-height:44px;text-align:right}.test-form-hint{margin:0 0 var(--space-1);color:var(--text-tertiary);font-size:11px;line-height:1.5}.test-form button{padding:10px;background:linear-gradient(135deg,var(--primary-600),var(--primary-500));border:none;border-radius:var(--radius-md);color:#fff;font-family:var(--font-family);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),opacity var(--transition-fast);box-shadow:0 2px 8px #6366f14d}.test-form button:hover{transform:translateY(-1px)}.test-form button:disabled{opacity:.5;cursor:not-allowed;transform:none}.single-add-header{display:flex;justify-content:space-between;align-items:center}.single-add-btn{padding:6px 14px;background:var(--surface-glass);border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--primary-400);font-size:var(--text-xs);font-weight:600;cursor:pointer;font-family:var(--font-family);transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),opacity var(--transition-fast)}.single-add-btn:hover{background:var(--surface-glass-hover);border-color:var(--primary-500)}.chat-container{display:flex;flex-direction:column;height:500px;background:#fff;border-radius:var(--radius-xl);border:1px solid var(--border-subtle);overflow:hidden}.chat-header-bar{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#f8f8fb;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.chat-header-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#4f46e5,#818cf8);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.chat-header-info{flex:1}.chat-header-name{font-size:14px;font-weight:700;color:var(--text-primary)}.chat-header-status{font-size:11px;color:#4ade80;display:flex;align-items:center;gap:4px}.chat-header-status:before{content:"";width:6px;height:6px;background:#4ade80;border-radius:50%}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding:20px 16px;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.15) transparent}.chat-messages::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar-thumb{background:#0000001a;border-radius:4px}.chat-msg-row{display:flex;gap:8px;max-width:75%;align-items:flex-end}.chat-msg-row.user{align-self:flex-end;flex-direction:row-reverse}.chat-msg-row.assistant{align-self:flex-start}.chat-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#4f46e5,#818cf8);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.chat-bubble{padding:12px 16px;font-size:14px;line-height:1.85;word-break:break-word;white-space:pre-wrap}.chat-bubble.user{background:linear-gradient(135deg,#4f46e5,#6366f1);color:#fff;border-radius:18px 18px 4px;box-shadow:0 2px 8px #4f46e54d}.chat-bubble.assistant{background:#f0f0f5;color:var(--text-primary);border-radius:18px 18px 18px 4px;border:1px solid rgba(0,0,0,.06)}.chat-time{font-size:10px;color:#8888a0;margin-top:2px;padding:0 4px}.chat-msg-row.user .chat-time{text-align:right}.chat-typing{display:flex;gap:8px;align-self:flex-start;max-width:85%;align-items:flex-end}.chat-typing-bubble{display:flex;gap:4px;padding:12px 18px;background:#f0f0f5;border-radius:18px 18px 18px 4px;border:1px solid rgba(0,0,0,.06)}.chat-typing-dot{width:6px;height:6px;border-radius:50%;background:#8888a0;animation:typingBounce 1.4s infinite ease-in-out}.chat-typing-dot:nth-child(1){animation-delay:0s}.chat-typing-dot:nth-child(2){animation-delay:.2s}.chat-typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1.1)}}.chat-date-sep{text-align:center;padding:8px 0}.chat-date-sep span{font-size:11px;color:#8888a0;background:#0000000a;padding:4px 14px;border-radius:12px}.chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:100%;color:#8888a0;text-align:center;padding:40px 20px}.chat-empty-icon{font-size:40px;opacity:.6}.chat-empty-text{font-size:14px;line-height:1.5}.chat-input-bar{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#f8f8fb;border-top:1px solid var(--border-subtle);flex-shrink:0}.chat-input-bar input{flex:1;padding:10px 16px;background:#f0f0f5;border:1px solid rgba(0,0,0,.1);border-radius:24px;color:var(--text-primary);font-family:var(--font-family);font-size:14px;outline:none;transition:border-color .15s}.chat-input-bar input:focus{border-color:var(--primary-500);background:#e8e8ee}.chat-input-bar input::placeholder{color:#8888a0}.chat-send-btn{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#4f46e5,#6366f1);border:none;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s,border-color .2s;flex-shrink:0}.chat-send-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #4f46e566}.chat-send-btn:disabled{opacity:.3;cursor:default}.chat-msg-content-wrap{position:relative;max-width:100%}.portal-msg-actions{display:flex;gap:2px;margin-top:2px;opacity:0;transition:opacity .15s ease}.portal-msg-actions.user{justify-content:flex-end}.portal-msg-actions.assistant{justify-content:flex-start}.chat-msg-row:hover .portal-msg-actions{opacity:1}.portal-action-btn{background:none;border:none;cursor:pointer;font-size:13px;padding:2px 6px;border-radius:4px;color:#8888a0;transition:background .15s,color .15s;font-family:var(--font-family);line-height:1}.portal-action-btn:hover{background:#6366f11a;color:#6366f1}.chat-edit-area{display:flex;flex-direction:column;gap:6px;width:100%;max-width:480px}.chat-edit-textarea{width:100%;min-height:120px;max-height:300px;padding:12px 16px;border:1.5px solid rgba(99,102,241,.4);border-radius:14px;font-family:var(--font-family);font-size:15px;line-height:1.7;resize:vertical;outline:none;background:#f8f8fb;color:var(--text-primary);transition:border-color .15s;box-sizing:border-box}.chat-edit-textarea:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.chat-edit-btns{display:flex;gap:6px;justify-content:flex-end}.chat-edit-save{padding:5px 16px;border:none;border-radius:16px;background:linear-gradient(135deg,#4f46e5,#6366f1);color:#fff;font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font-family);transition:transform .15s,box-shadow .15s}.chat-edit-save:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 3px 10px #4f46e54d}.chat-edit-save:disabled{opacity:.4;cursor:default}.chat-edit-cancel{padding:5px 14px;border:1px solid var(--border-medium);border-radius:16px;background:transparent;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;font-family:var(--font-family);transition:background .15s}.chat-edit-cancel:hover{background:#0000000a}.chat-input-row{display:none}.help-section{padding:var(--space-3);background:var(--surface-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-md);margin-bottom:var(--space-2)}.help-section-title{font-size:var(--text-sm);font-weight:600;margin-bottom:var(--space-2);display:flex;align-items:center;gap:var(--space-2)}.help-section p{font-size:var(--text-xs);color:var(--text-secondary);line-height:1.6}.form-hint{font-size:11px;color:var(--text-tertiary);margin-top:var(--space-1);line-height:1.4}.form-warning{font-size:11px;color:#fbbf24;margin-top:var(--space-1)}.student-tab{display:flex;align-items:center;justify-content:center;gap:4px}.tab-icon{font-size:14px;line-height:1}.tab-label{transition:opacity .15s ease,max-width .2s ease}.test-scores-grid{display:grid;grid-template-columns:1fr;gap:0}@media(max-width:480px){.student-app{padding:var(--space-3)}.student-header{padding:var(--space-4) var(--space-3);margin:calc(var(--space-3) * -1) calc(var(--space-3) * -1) var(--space-3)}.student-tabs{gap:1px;padding:3px}.student-tab{padding:10px 6px;font-size:12px;flex-direction:column;gap:3px}.tab-icon{font-size:20px}.tab-label{font-size:11px;opacity:.7}.student-tab.active .tab-label{opacity:1;font-weight:700}.test-form .form-row{flex-direction:column}.test-result-header{align-items:flex-start}.test-result-header h3{font-size:var(--text-lg);line-height:1.35}.test-result-toggle{min-width:auto;padding:8px 10px;font-size:12px}.test-result-form{gap:var(--space-2)}.test-result-form .test-meta-row{grid-template-columns:1fr}.test-result-form .test-score-row{grid-template-columns:minmax(4.25rem,5.25rem) minmax(0,1fr);gap:8px}.test-subject-label{align-self:center;font-size:12px}.chat-container{height:calc(100vh - 180px);min-height:350px}.test-scores-grid{grid-template-columns:repeat(2,1fr);gap:4px}.test-score-item{display:flex;justify-content:space-between;align-items:center;padding:6px 8px;background:var(--surface-glass);border-radius:var(--radius-sm);border:1px solid var(--border-subtle)}.test-score-item .student-card-label{font-size:11px}.test-score-item .student-card-value{font-size:12px}.action-buttons-grid{grid-template-columns:repeat(3,1fr);gap:6px}.action-btn{padding:10px 6px;font-size:10px}.student-card{padding:var(--space-3)}}.preview-modal-body .student-tabs{flex-wrap:wrap!important;overflow-x:visible!important;gap:3px!important}.preview-modal-body .student-tab{display:flex;align-items:center;justify-content:center;gap:2px;flex-direction:column;padding:6px 4px;font-size:10px;flex:0 0 auto;min-width:calc(25% - 3px);white-space:nowrap}.preview-modal-body .tab-icon{font-size:14px;line-height:1}.preview-modal-body .tab-label{font-size:9px;opacity:.5;line-height:1.2}.preview-modal-body .student-tab.active .tab-label{opacity:1;font-weight:700}.preview-modal-body .test-form .form-row{flex-direction:column}.preview-modal-body .test-result-header{align-items:flex-start}.preview-modal-body .test-result-toggle{flex:0 0 auto;min-width:auto;padding:8px 10px;font-size:12px;flex-direction:row}.preview-modal-body .test-result-form .test-meta-row{display:grid;grid-template-columns:1fr}.preview-modal-body .test-result-form .test-score-row{display:grid;grid-template-columns:minmax(4.25rem,5.25rem) minmax(0,1fr)}.preview-modal-body .chat-container{height:350px;max-height:50vh;margin:0 12px 10px;border-radius:16px;border:1px solid rgba(0,0,0,.08)}.preview-modal-body .test-scores-grid{grid-template-columns:repeat(2,1fr);gap:4px}.preview-modal-body .test-score-item{display:flex;justify-content:space-between;align-items:center;padding:6px 8px;background:var(--surface-glass);border-radius:var(--radius-sm);border:1px solid var(--border-subtle)}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.portal-back{padding:8px 16px;background:transparent;border:1px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-sm);font-family:var(--font-family);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.portal-back:hover{border-color:var(--primary-500);color:var(--text-primary)}.absence-shift-item{-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;outline:none}.absence-shift-item:active{transform:scale(.98)}.absence-shift-item:focus-visible{outline:2px solid #7c3aed;outline-offset:2px}
