@import"https://fonts.googleapis.com/css2?family=Noto+Sans+Thai:wght@400;500;600;700&display=swap";:root{--color-primary: #5B4EFF;--color-primary-hover: #4a3ee0;--color-primary-dark: #5B8CFF;--color-primary-light: #EEF2FF;--color-accent-mint: #62E5D2;--color-success: #34D399;--color-danger: #F87171;--color-warning: #F6C453;--color-bg: #F8FAFC;--color-surface: #FFFFFF;--color-border: #E5E7EB;--color-text: #111827;--color-text-secondary: #6B7280;--radius-sm: 8px;--radius-md: 16px;--radius-lg: 22px;--radius: 8px;--gradient-primary: linear-gradient(135deg, #5B4EFF 0%, #5B8CFF 58%, #62E5D2 100%);--shadow-sm: 0 10px 30px rgba(17,24,39,.06);--shadow-md: 0 18px 50px rgba(91,140,255,.14);--shadow: 0 10px 30px rgba(17,24,39,.06)}*{box-sizing:border-box}html{background:var(--color-bg)}body{min-width:320px;min-height:100vh;margin:0;background:var(--color-bg);color:var(--color-text);font-family:Noto Sans Thai,sans-serif;font-size:16px}button,input,select{font:inherit}button:focus-visible,input:focus-visible,select:focus-visible,a:focus-visible{outline:3px solid rgba(91,78,255,.28);outline-offset:2px}.auth-page{display:grid;min-height:100vh;place-items:center;padding:40px 24px;background:linear-gradient(135deg,#5b4eff1a,#62e5d214 48%,#f8fafc00 76%),var(--color-bg)}.auth-card{width:min(100%,440px);border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-md);border:1px solid rgba(229,231,235,.78);padding:40px 34px}.auth-brand{display:grid;justify-items:center;gap:10px;margin-bottom:28px}.auth-kicker{margin:0 0 8px;color:var(--color-primary);font-size:.78rem;font-weight:700;letter-spacing:0;text-align:center;text-transform:uppercase}.auth-tagline,.dashboard-tagline{width:-moz-fit-content;width:fit-content;background:linear-gradient(135deg,#5b4eff,#14b8a6);background-clip:text;color:transparent;font-weight:800;text-transform:none;-webkit-background-clip:text}.auth-tagline{margin-right:auto;margin-left:auto}.auth-connection-status{margin:-10px 0 18px;color:var(--color-text-secondary);font-size:.88rem;font-weight:600;text-align:center}.auth-title{margin:0 0 6px;color:var(--color-text);font-size:1.7rem;font-weight:700;line-height:1.25;text-align:center}.auth-subtitle{margin:0 0 24px;color:var(--color-text-secondary);font-size:.95rem;text-align:center}.auth-form{display:grid;gap:18px}.form-field{display:grid;gap:7px}.form-label{color:var(--color-text);font-size:14px;font-weight:500}.form-input{width:100%;height:50px;border:1px solid var(--color-border);border-radius:14px;background:#fbfcff;color:var(--color-text);font-size:16px;padding:0 16px}.form-input:disabled{cursor:not-allowed;opacity:.68}.form-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 4px #5b4eff1c}.form-input-error{border-color:var(--color-danger)}.form-error{color:var(--color-danger);font-size:.85rem}.button{display:inline-flex;width:100%;height:50px;align-items:center;justify-content:center;gap:10px;border-radius:14px;padding:0 16px;font-size:16px;font-weight:700;cursor:pointer;transition:background-color .15s ease,border-color .15s ease,color .15s ease,box-shadow .15s ease,transform .15s ease}.button-primary{border:1px solid transparent;background:var(--gradient-primary);color:#fff;box-shadow:0 14px 28px #5b8cff3d}.button-primary:not(:disabled):hover{box-shadow:0 18px 34px #5b8cff4d;transform:translateY(-1px)}.button-outline{border:1px solid rgba(91,78,255,.36);background:var(--color-surface);color:var(--color-primary)}.button-outline:not(:disabled):hover{background:var(--color-primary-light)}.button:disabled{cursor:not-allowed;opacity:.7}.button>span{display:inline-flex;min-width:0;align-items:center;justify-content:center;gap:8px}.button-spinner{width:18px;height:18px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-message{border-radius:14px;padding:11px 12px;font-size:.9rem}.auth-message-error{background:#fef2f2;color:#b91c1c}.auth-message-success{background:#f0fdf4;color:#15803d}.auth-message .payment-status-link{display:inline-flex;margin-left:8px;color:inherit;font-weight:700;text-decoration:underline}.auth-footer{display:grid;gap:12px;margin-top:20px;color:var(--color-text-secondary);font-size:.93rem;text-align:center}.text-link{display:inline-flex;align-items:center;gap:6px;color:var(--color-primary);font-weight:600;text-decoration:none}.text-link:hover{color:var(--color-primary-hover)}.brand-logo{display:inline-flex;align-items:center;line-height:1}.brand-logo-image{display:block;width:auto;height:44px;border-radius:10px}.brand-logo-login{display:grid;justify-items:center}.brand-logo-login .brand-logo-image{height:64px;max-width:min(100%,260px);border-radius:0;-o-object-fit:contain;object-fit:contain}.brand-logo-footer .brand-logo-image{height:28px;max-width:120px;-o-object-fit:contain;object-fit:contain}.button-icon,.inline-icon,.status-icon,.icon-action-svg,.success-icon-svg,.admin-action-icon{flex:0 0 auto}.button-icon,.inline-icon,.status-icon{width:16px;height:16px}.icon-action-svg{width:18px;height:18px}.password-box{border:1px solid var(--color-border);border-radius:16px;background:#fbfcff;padding:12px 14px;color:var(--color-text-secondary);font-size:.9rem}.password-box ul{display:grid;gap:4px;margin:0;padding-left:20px}.checkbox-row{display:flex;align-items:center;gap:9px;color:var(--color-text-secondary);font-size:.92rem}.checkbox-row input{width:16px;height:16px;accent-color:var(--color-primary)}.app-page{min-height:100vh;background:linear-gradient(180deg,#5b4eff14,#f8fafc00 300px),var(--color-bg)}.topbar{height:64px;border-bottom:1px solid rgba(229,231,235,.82);background:#ffffffe0}.topbar-inner{display:flex;width:min(1120px,calc(100% - 32px));height:100%;align-items:center;justify-content:space-between;gap:16px;margin:0 auto}.topbar-logo{color:var(--color-text);font-size:1.25rem;font-weight:700}.topbar-user{display:flex;align-items:center;gap:12px;color:var(--color-text-secondary);font-size:.92rem}.logout-button{display:inline-flex;min-height:48px;align-items:center;justify-content:center;border:1px solid rgba(229,231,235,.95);border-radius:999px;background:var(--color-surface);color:var(--color-text);padding:8px 14px;cursor:pointer}.logout-button:hover{border-color:var(--color-primary);color:var(--color-primary)}.dashboard-main{display:grid;width:min(1120px,calc(100% - 32px));gap:22px;margin:0 auto;padding:32px 0 44px}.dashboard-hero,.dashboard-card{border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-sm);border:1px solid rgba(229,231,235,.76)}.dashboard-hero{display:flex;align-items:center;justify-content:space-between;gap:20px;overflow:hidden;padding:28px}.dashboard-hero>div{min-width:0}.dashboard-eyebrow{margin:0 0 8px;color:var(--color-primary);font-size:.78rem;font-weight:700;letter-spacing:0;text-transform:uppercase}.dashboard-title{margin:0 0 8px;font-size:clamp(1.55rem,3vw,2rem);font-weight:700;line-height:1.25;overflow-wrap:anywhere}.dashboard-subtitle{max-width:560px;margin:0 0 16px;color:var(--color-text-secondary);font-size:.98rem;line-height:1.6}.dashboard-tagline{margin:0 0 16px;font-size:1.02rem}.role-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.role-badge{display:inline-flex;align-items:center;border-radius:999px;padding:6px 12px;background:var(--color-primary-light);color:var(--color-primary);font-size:12px;font-weight:600}.role-premium{background:#fff7d6;color:#a16207}.membership-expiry-note{color:var(--color-text-secondary);font-size:.92rem;font-weight:700;line-height:1.45}.upgrade-wrap{width:min(200px,100%);flex-shrink:0}.dashboard-card{padding:24px}.card-title{margin:0 0 14px;font-size:1.05rem;font-weight:700}.muted{color:var(--color-text-secondary)}.progress-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px;color:var(--color-text-secondary);font-size:14px}.progress-track{height:9px;overflow:hidden;border-radius:999px;background:#e9eeff}.progress-bar{width:0;height:100%;border-radius:inherit;background:var(--gradient-primary)}.stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.stat-card{min-width:0;border:1px solid rgba(229,231,235,.74);border-radius:20px;background:var(--color-surface);box-shadow:var(--shadow-sm);padding:20px 16px;text-align:center}.stat-value{margin:0;color:var(--color-primary);font-size:2rem;font-weight:700;line-height:1.1;overflow-wrap:anywhere}.stat-label{margin:4px 0 0;color:var(--color-text-secondary);font-size:12px}.quick-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.action-card{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:12px;min-height:84px;border:1px solid rgba(229,231,235,.78);border-radius:20px;background:var(--color-surface);box-shadow:var(--shadow-sm);padding:18px;color:var(--color-text);text-align:left;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.action-card:hover{border-color:#5b4eff57;box-shadow:var(--shadow-md);transform:translateY(-2px)}.action-icon{display:inline-grid;width:38px;height:38px;flex:0 0 auto;place-items:center;border-radius:14px;background:#eff6ff;color:var(--color-primary-dark);font-size:.76rem;font-weight:800;line-height:1}.action-title{font-size:15px;font-weight:700}.section-title{margin:0 0 12px;font-size:1rem;font-weight:600;color:var(--color-text)}.categories-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.category-card{display:flex;width:100%;min-height:58px;align-items:center;justify-content:space-between;gap:8px;border:1px solid rgba(229,231,235,.76);border-radius:18px;background:var(--color-surface);box-shadow:var(--shadow-sm);padding:16px;color:var(--color-text);text-align:left;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.category-card:hover{border-color:#5b4eff57;box-shadow:var(--shadow-md);transform:translateY(-1px)}.category-card-skeleton{cursor:default;overflow:hidden;position:relative}.category-card-skeleton:before{width:58%;height:14px;border-radius:999px;background:#e5e7eb;content:""}.category-card-skeleton:after{position:absolute;top:0;right:0;bottom:0;left:0;content:"";background:linear-gradient(90deg,transparent,rgba(255,255,255,.72),transparent);animation:shimmer 1.2s infinite}.category-name{font-size:14px;font-weight:500;color:var(--color-text);min-width:0}.badge-soon{flex-shrink:0;border-radius:999px;background:#ecfdf5;color:var(--color-text-secondary);font-size:11px;font-weight:600;padding:3px 8px;white-space:nowrap}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.otp-input{text-align:center;font-size:1.75rem;font-weight:700;letter-spacing:.5rem;color:var(--color-primary)}.resend-btn{background:none;border:none;padding:0;cursor:pointer;font-size:14px}.resend-btn:disabled{opacity:.5;cursor:not-allowed}.toast{position:fixed;right:20px;bottom:20px;max-width:min(360px,calc(100% - 40px));border-radius:var(--radius-md);background:var(--color-text);color:#fff;box-shadow:var(--shadow-md);padding:12px 16px;font-size:14px;font-weight:500;z-index:9999}.toast-error{background:#b91c1c}.site-footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px 18px;border-top:1px solid rgba(229,231,235,.82);background:var(--color-surface);color:var(--color-text-secondary);padding:18px 16px;font-size:.82rem}.site-footer-brand{display:inline-flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px 12px}.site-footer-link{display:inline-flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px;color:var(--color-text-secondary);font-weight:700;text-decoration:none;transition:color .15s ease}.site-footer-link:hover{color:var(--color-primary)}.admin-main{display:grid;width:min(1120px,calc(100% - 32px));gap:22px;margin:0 auto;padding:32px 0 44px}.admin-topbar-subtitle{color:var(--color-text-secondary);font-size:.82rem}.admin-topbar{height:auto}.admin-topbar-inner{min-height:64px}.admin-nav-links{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.admin-nav-links a{display:inline-flex;min-height:40px;align-items:center;border:1px solid transparent;border-radius:999px;color:var(--color-text-secondary);padding:0 12px;font-size:.9rem;font-weight:700;text-decoration:none}.admin-nav-links a:hover,.admin-nav-links a.active{border-color:#5b4eff3d;background:#f4f3ff;color:#5b4eff}.admin-page-heading{display:grid;gap:6px}.admin-step-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;align-items:start}.admin-step-card{border:1px solid rgba(229,231,235,.76);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-sm);padding:22px}.step-heading{display:flex;gap:12px;align-items:flex-start;margin-bottom:18px}.step-heading h2{margin:0;color:var(--color-text);font-size:1.05rem;line-height:1.35}.step-heading p{margin:4px 0 0;color:var(--color-text-secondary);font-size:.9rem;line-height:1.55}.step-number{display:inline-grid;width:34px;height:34px;flex:0 0 auto;place-items:center;border-radius:12px;background:var(--color-primary-light);color:var(--color-primary);font-weight:800}.admin-form-grid,.admin-upload-actions,.validation-result{display:grid;gap:16px}.admin-loading-box,.admin-empty-state{border:1px dashed rgba(91,78,255,.28);border-radius:var(--radius-md);background:#fbfcff;color:var(--color-text-secondary);padding:18px;font-size:.95rem}.file-drop{display:grid;min-height:118px;align-content:center;gap:8px;border:1px dashed rgba(91,78,255,.42);border-radius:var(--radius-md);background:#fbfcff;color:var(--color-text);padding:18px;cursor:pointer;transition:border-color .15s ease,background-color .15s ease}.file-drop:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.file-drop input{width:100%;color:var(--color-text-secondary)}.file-drop-title{font-weight:700;overflow-wrap:anywhere}.file-drop-meta,.selected-category-note,.summary-label{color:var(--color-text-secondary);font-size:.9rem}.admin-result-card{display:grid;gap:4px}.result-stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.result-stat{display:grid;gap:4px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#fbfcff;padding:16px}.result-stat span{color:var(--color-text-secondary);font-size:.85rem}.result-stat strong{color:var(--color-text);font-size:1.65rem}.result-stat-success strong{color:#15803d}.result-stat-danger strong{color:#b91c1c}.error-row-list{display:grid;gap:10px;max-height:320px;overflow:auto;padding-right:4px}.error-row-card{border:1px solid #FECACA;border-radius:14px;background:#fef2f2;padding:12px;color:#991b1b}.error-row-card ul{display:grid;gap:4px;margin:6px 0 0;padding-left:18px}.review-summary-card{display:grid;grid-template-columns:1.2fr 1.2fr .8fr;gap:16px}.review-summary-card>div{display:grid;gap:4px;min-width:0}.review-summary-card strong{overflow-wrap:anywhere}.question-review-list{display:grid;gap:14px}.question-review-card{min-width:0;border:1px solid rgba(229,231,235,.76);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-sm);padding:18px}.question-review-header{display:flex;justify-content:space-between;gap:12px;color:var(--color-text-secondary);font-size:.86rem}.question-review-header strong{color:var(--color-primary)}.question-review-card h2{margin:10px 0 14px;font-size:1rem;line-height:1.6}.csv-preview-table-wrap{width:100%;max-width:100%;margin-top:12px;overflow-x:auto}.csv-preview-reference-table{width:100%;min-width:100%;table-layout:fixed;border-collapse:separate;border-spacing:0;border:1px solid rgba(229,231,235,.86);border-radius:12px;overflow:hidden;font-size:.86rem}.csv-preview-reference-table th,.csv-preview-reference-table td{width:33.333%;border-right:1px solid rgba(229,231,235,.72);padding:10px 12px;text-align:left;vertical-align:top;overflow-wrap:anywhere}.csv-preview-reference-table th:last-child,.csv-preview-reference-table td:last-child{border-right:0}.csv-preview-reference-table th{background:#f8f7ff;color:var(--color-text);font-weight:800}.csv-preview-reference-table td{color:var(--color-text-secondary);line-height:1.5}.choice-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.choice-grid div{border:1px solid var(--color-border);border-radius:12px;background:#fbfcff;padding:12px;line-height:1.45}.question-card-actions{display:flex;justify-content:flex-end;margin-top:14px}.question-card-actions .button{width:min(140px,100%);border-color:#fecaca;color:#b91c1c}.question-card-actions .button:not(:disabled):hover{background:#fef2f2}.admin-pagination,.admin-bottom-actions{display:flex;align-items:center;justify-content:space-between;gap:14px}.admin-pagination .button,.admin-bottom-actions .button{width:min(220px,100%)}.success-panel{display:grid;justify-items:center;gap:10px;text-align:center}.success-panel h2,.success-panel p{margin:0}.success-panel p{color:var(--color-text-secondary);overflow-wrap:anywhere}.success-icon{display:grid;width:54px;height:54px;place-items:center;border-radius:18px;background:#ecfdf5;color:#15803d;font-size:1.7rem;font-weight:800}.success-icon-svg{width:28px;height:28px}.admin-inline-link{display:inline-flex;min-height:48px;align-items:center;gap:6px}.admin-stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.admin-stat-card,.admin-action-card,.batch-group-card{border:1px solid rgba(229,231,235,.76);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-sm)}.admin-stat-card{display:grid;gap:6px;min-height:118px;align-content:center;padding:18px}.admin-stat-card span{color:var(--color-text-secondary);font-size:.84rem}.admin-stat-card strong{color:#5b4eff;font-size:1.8rem;line-height:1.2}.admin-stat-card .admin-stat-small{color:var(--color-text);font-size:1rem;line-height:1.45}.admin-action-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.admin-action-card{display:flex;min-height:92px;align-items:center;justify-content:space-between;gap:14px;padding:22px;color:var(--color-text);cursor:pointer;text-align:left}.admin-action-card span{font-weight:800}.admin-action-icon{width:24px;height:24px;color:#5b4eff}.admin-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.admin-section-header h2{margin:0;font-size:1.05rem}.admin-section-header .button{width:min(160px,100%)}.admin-activity-list,.category-tree,.batch-group-list,.admin-question-row-list,.admin-edit-form{display:grid;gap:14px}.admin-activity-row{display:grid;grid-template-columns:1fr auto 130px;gap:14px;align-items:center;border-bottom:1px solid var(--color-border);padding:12px 0}.admin-activity-row:last-child{border-bottom:0}.admin-activity-row div{display:grid;gap:4px;min-width:0}.admin-activity-row span{color:var(--color-text-secondary);font-size:.9rem;overflow-wrap:anywhere}.form-textarea{width:100%;min-height:108px;resize:vertical;border:1px solid var(--color-border);border-radius:14px;background:#fbfcff;color:var(--color-text);font-size:16px;line-height:1.55;padding:12px 16px}.form-textarea:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 4px #5b4eff1c}.admin-inline-form{display:grid;gap:16px}.admin-inline-actions{display:flex;flex-wrap:wrap;gap:10px}.admin-inline-actions .button{width:min(180px,100%)}.category-tree-row{display:grid;gap:10px}.category-root-action{width:min(220px,100%)}.category-tree>.category-tree-row{border:1px solid rgba(229,231,235,.76);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-sm);padding:16px}.category-tree-row.level-2{margin-left:24px}.category-tree-row.level-3{margin-left:48px}.category-tree-line{display:grid;grid-template-columns:48px 1fr auto;gap:12px;align-items:center;min-width:0;border-radius:14px;background:#fbfcff;padding:12px}.category-tree-line strong,.category-tree-line span{min-width:0;overflow-wrap:anywhere}.category-toggle,.icon-action{display:inline-grid;width:48px;height:48px;place-items:center;border:1px solid var(--color-border);border-radius:999px;background:var(--color-surface);color:var(--color-text);cursor:pointer;font-weight:800}.category-toggle:hover,.icon-action:hover{border-color:#5b4eff4d;color:#5b4eff}.icon-action.confirm{border-color:#22c55e57;color:#15803d}.category-leaf-spacer{width:48px;height:48px}.category-inline-form{display:grid;grid-template-columns:minmax(220px,1fr) auto;gap:12px;align-items:end;margin-left:48px;border:1px dashed rgba(91,78,255,.3);border-radius:14px;background:#f8f7ff;padding:14px}.category-rename-form{display:grid;grid-template-columns:minmax(180px,1fr) 48px 48px;gap:8px;align-items:center}.category-inline-add{justify-self:start;display:inline-flex;min-height:48px;align-items:center;gap:6px;border:1px dashed rgba(91,78,255,.3);border-radius:999px;background:#f8f7ff;color:#5b4eff;padding:0 14px;font-weight:800;cursor:pointer}.category-tree-actions,.batch-actions,.question-row-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.category-tree-actions .button,.batch-actions .button,.question-row-actions .button{width:auto;min-width:116px}.admin-filter-row{display:grid;grid-template-columns:minmax(180px,1fr) minmax(220px,1.4fr) 130px 160px;gap:12px;align-items:end}.batch-group-card{display:grid;gap:16px;padding:18px}.batch-group-header,.admin-question-row{display:grid;grid-template-columns:1fr auto;gap:14px;align-items:center}.batch-group-header h2,.batch-group-header p{margin:0}.batch-group-header h2{font-size:1.02rem;line-height:1.45}.batch-group-header p{color:var(--color-text-secondary);line-height:1.55}.latest-badge{display:inline-flex;align-items:center;border-radius:999px;background:#ecfdf5;color:#15803d;padding:3px 8px;font-size:.72rem;font-weight:900}.batch-conflict-box{display:grid;gap:12px;border:1px solid #FECACA;border-radius:14px;background:#fef2f2;color:#991b1b;padding:14px}.batch-conflict-box p{margin:0;font-weight:700}.admin-question-row{border:1px solid var(--color-border);border-radius:14px;background:#fbfcff;padding:12px}.admin-question-row div:first-child{display:grid;gap:5px;min-width:0}.admin-question-row strong{display:-webkit-box;overflow:hidden;line-height:1.5;-webkit-box-orient:vertical;-webkit-line-clamp:2}.admin-question-row span{color:var(--color-text-secondary);font-size:.85rem}.show-more-button{display:inline-flex;justify-self:start;min-height:48px;align-items:center;gap:6px;border:1px solid rgba(91,78,255,.24);border-radius:999px;background:#f8f7ff;color:#5b4eff;padding:0 14px;font-weight:800;cursor:pointer}.admin-edit-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.admin-payment-filter-row{grid-template-columns:minmax(180px,.7fr) minmax(220px,1.5fr) 130px 140px}.admin-user-filter-row{grid-template-columns:minmax(240px,1fr) 130px 140px}.admin-payment-list,.admin-user-list{display:grid;gap:14px}.admin-payment-card,.admin-user-card{display:grid;gap:18px;border:1px solid rgba(229,231,235,.78);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-sm);padding:18px}.admin-payment-detail-list div{grid-template-columns:150px minmax(0,1fr)}.admin-payment-actions{justify-content:flex-end}.admin-payment-actions .button{min-width:132px}.admin-law-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;align-items:start}.admin-law-wide{grid-column:1 / -1}.admin-checkbox-row{display:flex;min-height:50px;align-items:center;gap:10px;color:var(--color-text);font-weight:700}.admin-checkbox-row input{width:18px;height:18px;accent-color:var(--color-primary)}.admin-law-filter-row{grid-template-columns:minmax(220px,1fr) minmax(220px,.8fr) 130px 140px}.admin-law-list{display:grid;gap:14px}.admin-law-card{display:grid;gap:18px;border:1px solid rgba(229,231,235,.78);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-sm);padding:18px}.admin-law-detail-list div{grid-template-columns:130px minmax(0,1fr)}.admin-law-replace-row{display:grid;grid-template-columns:minmax(0,1fr) 150px;gap:12px;align-items:center}.admin-law-replace-row input{min-width:0;width:100%;border:1px solid var(--color-border);border-radius:14px;background:#fbfcff;padding:12px}.admin-modal-backdrop{position:fixed;z-index:60;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#11182770;padding:18px}.admin-modal-panel{display:grid;width:min(560px,100%);max-height:calc(100vh - 36px);gap:16px;overflow:auto;border:1px solid rgba(229,231,235,.78);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-lg);padding:22px}.admin-modal-panel h2,.admin-modal-panel p{margin:0}.admin-modal-panel p{color:var(--color-text-secondary);line-height:1.55}.admin-slip-preview{width:min(760px,100%)}.admin-slip-expiry{border-radius:14px;background:#fffbeb;color:#92400e;padding:10px 12px;font-size:.9rem;font-weight:800}.admin-slip-preview img{display:block;width:100%;max-height:62vh;-o-object-fit:contain;object-fit:contain;border:1px solid var(--color-border);border-radius:14px;background:#fbfcff}.admin-slip-preview a{color:var(--color-primary);font-weight:800;overflow-wrap:anywhere;text-decoration:none}.cancel-confirm-card{display:grid;gap:16px}.cancel-confirm-card p{margin:0;color:var(--color-text);font-weight:600;line-height:1.55}.cancel-confirm-actions{display:grid;grid-template-columns:repeat(2,minmax(0,180px));gap:12px}.quiz-main{display:grid;width:min(1120px,calc(100% - 32px));gap:22px;margin:0 auto;padding:32px 0 44px}.quiz-page-heading{display:grid;gap:6px}.quiz-state-card,.quiz-card,.quiz-info-card,.quiz-question-card,.score-card,.quiz-stat-card,.history-attempt-card,.answer-review-card{border:1px solid rgba(229,231,235,.76);border-radius:16px;background:var(--color-surface);box-shadow:var(--shadow-sm)}.quiz-state-card{display:grid;gap:12px;padding:20px;color:var(--color-text-secondary)}.quiz-state-card p{margin:0}.quota-banner{border:1px solid rgba(91,78,255,.2);border-radius:16px;background:#f4f3ff;color:#5b4eff;padding:16px;font-weight:700}.quota-banner-blocked{border-color:#ef444447;background:#fef2f2;color:#b91c1c}.quiz-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:18px;align-items:start}.quiz-card{padding:22px}.quiz-card-title{margin:0 0 16px;color:var(--color-text);font-size:1.08rem;font-weight:800}.quiz-info-card{display:grid;gap:16px}.quiz-path{border:1px solid rgba(91,78,255,.18);border-radius:14px;background:#f8f7ff;color:var(--color-text);padding:14px;font-weight:700;line-height:1.55}.quiz-toggle{display:flex;align-items:center;gap:10px;color:var(--color-text);font-weight:600}.quiz-toggle input{width:18px;height:18px;accent-color:#5B4EFF}.quiz-empty{border:1px dashed rgba(91,78,255,.26);border-radius:14px;background:#fbfcff;color:var(--color-text-secondary);padding:16px}.quiz-play-main{gap:18px}.quiz-play-header{display:flex;align-items:center;justify-content:space-between;gap:12px;border-radius:16px;background:var(--color-surface);box-shadow:var(--shadow-sm);padding:16px 18px}.quiz-play-header span{color:var(--color-text-secondary);font-weight:700}.quiz-progress-track{height:10px;overflow:hidden;border-radius:999px;background:#e9eeff}.quiz-progress-bar{height:100%;border-radius:inherit;background:#5b4eff;transition:width .18s ease}.quiz-question-card{display:grid;gap:18px;padding:24px}.quiz-question-card h1{margin:0;color:var(--color-text);font-size:1.25rem;line-height:1.65}.quiz-question-type{color:#5b4eff;font-size:.76rem;font-weight:800;letter-spacing:0}.quiz-choice-blur-panel{display:grid;gap:16px}.quiz-choice-blur-panel .button{width:min(220px,100%)}.quiz-choice-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.quiz-choice-grid.is-blurred{position:relative;-webkit-user-select:none;-moz-user-select:none;user-select:none}.quiz-copy-deterrent-content{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.quiz-choice-grid.is-blurred:after{position:absolute;top:0;right:0;bottom:0;left:0;content:"";border-radius:14px;-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px);background:#ffffff61}.quiz-choice-box{position:relative;display:flex;width:100%;min-height:64px;align-items:flex-start;justify-content:space-between;gap:12px;border:1px solid var(--color-border);border-radius:14px;background:#fbfcff;color:var(--color-text);padding:14px 16px;line-height:1.6;text-align:left}button.quiz-choice-box{cursor:pointer;transition:border-color .15s ease,background-color .15s ease,box-shadow .15s ease}button.quiz-choice-box:hover{border-color:#5b4eff5c;background:#f8f7ff}.quiz-choice-box.selected{border-color:#5b4eff;background:#f0efff;box-shadow:0 0 0 4px #5b4eff1a}.quiz-choice-box.correct{border-color:#22c55e75;background:#ecfdf5;color:#166534;box-shadow:0 0 0 4px #22c55e1a}.quiz-choice-box.wrong{border-color:#ef444475;background:#fef2f2;color:#991b1b;box-shadow:0 0 0 4px #ef44441a}button.quiz-choice-box.correct:hover{border-color:#22c55e94;background:#dcfce7}button.quiz-choice-box.wrong:hover{border-color:#ef444494;background:#fee2e2}.quiz-choice-content{min-width:0}.question-explanation-actions{width:min(220px,100%)}.question-explanation-panel{display:grid;gap:12px;border:1px solid rgba(91,78,255,.18);border-radius:14px;background:#fbfcff;padding:16px}.question-explanation-panel.correct{border-color:#22c55e70;background:#f0fdf4}.question-explanation-panel.wrong{border-color:#ef444461;background:#fef2f2}.question-explanation-status{display:flex;align-items:center;gap:10px}.question-result-status{display:inline-flex;align-items:center;gap:6px;font-weight:800}.question-explanation-panel.correct .question-result-status{color:#15803d}.question-explanation-panel.wrong .question-result-status{color:#b91c1c}.question-explanation-section{display:grid;gap:4px}.question-explanation-panel strong{color:var(--color-text)}.question-explanation-panel p{margin:0;color:var(--color-text-secondary);line-height:1.55}.upgrade-lock-panel{display:grid;gap:4px;border:1px dashed rgba(91,78,255,.28);border-radius:12px;background:#f8f7ff;padding:12px}.upgrade-lock-panel strong{color:var(--color-text);line-height:1.35}.upgrade-lock-panel p{margin:0;color:var(--color-text-secondary);line-height:1.55}.quiz-nav-actions{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.quiz-question-navigator{display:grid;grid-template-columns:repeat(10,minmax(0,48px));gap:10px;align-items:center;justify-content:center;border-radius:16px;background:var(--color-surface);box-shadow:var(--shadow-sm);padding:16px}.quiz-nav-dot{display:inline-grid;width:48px;height:48px;place-items:center;border:1px solid var(--color-border);border-radius:999px;background:var(--color-surface);color:var(--color-text-secondary);font-weight:800;cursor:pointer}.quiz-nav-dot.answered{border-color:#5b4eff;background:#5b4eff;color:#fff}.quiz-nav-dot.skipped{border-style:dashed;border-color:#f59e0b;color:#b45309}.quiz-nav-dot.current{box-shadow:0 0 0 4px #5b4eff29}.quiz-modal{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#1118276b;padding:20px;z-index:10000}.quiz-modal-panel{display:grid;width:min(440px,100%);gap:14px;border-radius:16px;background:var(--color-surface);box-shadow:var(--shadow-md);padding:24px}.quiz-modal-panel h2,.quiz-modal-panel p{margin:0}.quiz-modal-panel p{color:var(--color-text-secondary);line-height:1.6}.quiz-modal-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.upgrade-modal-panel{justify-items:center;text-align:center}.upgrade-modal-icon{display:grid;place-items:center;width:52px;height:52px;border-radius:50%;background:var(--color-primary-light);color:var(--color-primary)}.upgrade-modal-icon .inline-icon{width:26px;height:26px}.upgrade-modal-note{font-size:13px}.upgrade-modal-panel .quiz-modal-actions{width:100%}.score-card{display:grid;grid-template-columns:1fr auto;gap:22px;align-items:center;padding:24px}.score-circle{display:grid;width:138px;height:138px;place-items:center;border:10px solid currentColor;border-radius:999px;background:var(--color-surface);font-size:2rem;font-weight:900}.score-visual{display:grid;justify-items:center;gap:12px}.score-encouragement{max-width:220px;margin:0;color:var(--color-text);font-size:.95rem;font-weight:800;line-height:1.5;text-align:center}.score-summary,.score-actions{display:grid;gap:14px}.score-actions{grid-template-columns:repeat(2,minmax(0,180px))}.score-label{font-size:1.15rem}.score-green{color:#22c55e}.score-amber{color:#f59e0b}.score-red{color:#ef4444}.answer-review-list{display:grid;gap:14px}.answer-review-card{display:grid;gap:12px;padding:18px}.answer-review-card.correct{border-color:#22c55e61;background:#f0fdf4}.answer-review-card.wrong{border-color:#ef444461;background:#fef2f2}.answer-review-card h3,.answer-review-card p{margin:0}.answer-review-card h3{font-size:1rem;line-height:1.6}.answer-review-card p{color:var(--color-text-secondary);line-height:1.55}.answer-review-header{display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--color-text-secondary);font-size:.88rem}.answer-review-card.correct .answer-review-header strong{color:#22c55e}.answer-review-card.wrong .answer-review-header strong,.correct-answer-text{color:#ef4444}.answer-review-card.correct .status-icon{color:#22c55e}.answer-review-card.wrong .status-icon{color:#ef4444}.answer-status,.answer-choice-line{display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap}.answer-choice-line{border:1px solid transparent;border-radius:8px;padding:12px}.answer-choice-correct{border-color:#22c55e57;background:#dcfce7}.answer-choice-wrong{border-color:#ef444457;background:#fee2e2}.explanation-toggle{display:inline-flex;width:-moz-fit-content;width:fit-content;min-height:48px;align-items:center;gap:6px;border:1px solid rgba(91,78,255,.24);border-radius:999px;background:#f8f7ff;color:#5b4eff;padding:8px 12px;font-weight:700;cursor:pointer}.explanation-panel{display:grid;gap:8px;border-radius:14px;background:#fbfcff;padding:14px}.explanation-section{display:grid;gap:4px}.explanation-section strong{color:var(--color-text);font-weight:800}.quiz-stats-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.quiz-stat-card{display:grid;gap:6px;padding:18px}.quiz-stat-card span{color:var(--color-text-secondary);font-size:.86rem}.quiz-stat-card strong{color:#5b4eff;font-size:1.65rem}.quiz-filter-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.history-attempt-list{display:grid;gap:14px}.history-attempt-card{display:grid;grid-template-columns:1fr auto minmax(180px,220px);gap:16px;align-items:center;padding:18px}.history-attempt-card h2,.history-attempt-card p{margin:0}.history-attempt-card h2{font-size:1rem;line-height:1.45}.history-attempt-card p{color:var(--color-text-secondary);line-height:1.55}.history-score{font-size:1.35rem;white-space:nowrap}.payment-main{display:grid;width:min(1120px,calc(100% - 32px));gap:22px;margin:0 auto;padding:32px 0 44px}.payment-heading{display:grid;gap:6px}.payment-plan-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;align-items:stretch}.payment-plan-card{display:grid;position:relative;overflow:hidden;gap:16px;align-content:start;min-height:430px;--plan-accent: var(--color-primary);--plan-accent-strong: #4338CA;--plan-accent-soft: rgba(91,78,255,.1);--plan-accent-faint: rgba(91,78,255,.045);--plan-border: rgba(229,231,235,.78);--plan-badge-bg: #FFF7D6;--plan-badge-border: rgba(245,158,11,.24);--plan-badge-color: #92400E;--plan-shadow: var(--shadow-sm);--plan-cta-bg: var(--gradient-primary);border:1px solid var(--plan-border);border-radius:var(--radius-md);background:linear-gradient(180deg,var(--plan-accent-faint),rgba(255,255,255,0) 210px),var(--color-surface);box-shadow:var(--plan-shadow);padding:18px;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.payment-plan-card:before{content:"";position:absolute;inset:0 0 auto;height:4px;background:linear-gradient(90deg,var(--plan-accent),rgba(255,255,255,0));opacity:.55}.payment-plan-card:not(.payment-plan-card-free):hover{transform:translateY(-2px);box-shadow:0 20px 44px #0f172a1a}.payment-plan-card-free{--plan-accent: #16A34A;--plan-accent-strong: #15803D;--plan-accent-soft: rgba(22,163,74,.11);--plan-accent-faint: rgba(22,163,74,.035)}.payment-plan-card-weekly{--plan-accent: #2563EB;--plan-accent-strong: #1D4ED8;--plan-accent-soft: rgba(37,99,235,.11);--plan-accent-faint: rgba(37,99,235,.04);--plan-cta-bg: linear-gradient(135deg, #2563EB 0%, #38BDF8 100%)}.payment-plan-card-monthly{--plan-accent: #0F766E;--plan-accent-strong: #115E59;--plan-accent-soft: rgba(20,184,166,.13);--plan-accent-faint: rgba(20,184,166,.055);--plan-border: rgba(20,184,166,.22);--plan-cta-bg: linear-gradient(135deg, #0F766E 0%, #2DD4BF 100%)}.payment-plan-card-six-months{--plan-accent: #D97706;--plan-accent-strong: #92400E;--plan-accent-soft: rgba(251,191,36,.18);--plan-accent-faint: rgba(251,191,36,.12);--plan-border: rgba(217,119,6,.36);--plan-badge-bg: linear-gradient(135deg, #F43F5E 0%, #B91C1C 100%);--plan-badge-border: rgba(244,63,94,.3);--plan-badge-color: #FFFFFF;--plan-shadow: 0 22px 48px rgba(217,119,6,.16);--plan-cta-bg: linear-gradient(135deg, #F59E0B 0%, #F97316 100%)}.payment-plan-card-yearly{--plan-accent: #7C3AED;--plan-accent-strong: #5B21B6;--plan-accent-soft: rgba(124,58,237,.14);--plan-accent-faint: rgba(124,58,237,.09);--plan-border: rgba(124,58,237,.34);--plan-badge-bg: linear-gradient(135deg, #8B5CF6 0%, #5B21B6 100%);--plan-badge-border: rgba(124,58,237,.28);--plan-badge-color: #FFFFFF;--plan-shadow: 0 22px 48px rgba(91,33,182,.15);--plan-cta-bg: linear-gradient(135deg, #7C3AED 0%, #5B4EFF 55%, #2563EB 100%)}.payment-plan-highlight{border-color:var(--plan-border);background:linear-gradient(180deg,var(--plan-accent-faint),rgba(255,255,255,0) 260px),var(--color-surface);box-shadow:var(--plan-shadow)}.payment-plan-header,.payment-status-header,.payment-history-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.payment-plan-header h2,.payment-status-header h2,.payment-empty-state h2,.payment-history-title-row h2{margin:0;font-size:1.08rem;line-height:1.35}.payment-plan-header p,.payment-history-title-row p,.payment-empty-state p{margin:4px 0 0;color:var(--color-text-secondary);font-size:.9rem}.payment-plan-badge,.payment-status-pill{display:inline-flex;min-height:30px;align-items:center;justify-content:center;border-radius:999px;padding:5px 10px;font-size:.76rem;font-weight:800;white-space:nowrap}.payment-plan-badge{background:var(--plan-badge-bg);border:1px solid var(--plan-badge-border);box-shadow:0 10px 22px color-mix(in srgb,var(--plan-accent) 22%,transparent);color:var(--plan-badge-color);max-width:168px;min-height:34px;padding:7px 12px;font-size:.78rem;font-weight:900;line-height:1.25;text-align:center;text-transform:uppercase;white-space:normal}.payment-price-block{display:grid;gap:7px}.payment-original-price{display:flex;align-items:baseline;gap:5px;color:var(--color-text-secondary);font-weight:800}.payment-original-price span{text-decoration:line-through;text-decoration-thickness:2px}.payment-original-price small{font-size:.78rem}.payment-savings-badge{display:inline-flex;width:-moz-fit-content;width:fit-content;min-height:28px;align-items:center;justify-content:center;border:1px solid color-mix(in srgb,var(--plan-accent) 24%,transparent);border-radius:999px;background:var(--plan-accent-soft);color:var(--plan-accent-strong);padding:4px 10px;font-size:.78rem;font-weight:900;line-height:1.2}.payment-price-row{display:flex;align-items:baseline;gap:6px}.payment-price-row span{color:var(--plan-accent-strong);font-size:2rem;font-weight:800;line-height:1}.payment-plan-card-free .payment-price-row span{color:var(--color-text)}.payment-price-row small{color:var(--color-text-secondary);font-size:.88rem;font-weight:700}.payment-daily-caption{display:inline-flex;width:-moz-fit-content;width:fit-content;max-width:100%;align-items:center;border-radius:999px;margin:0;background:var(--plan-accent-soft);color:var(--plan-accent-strong);padding:5px 10px;font-size:.88rem;font-weight:900;line-height:1.35}.payment-one-time-note{margin:0;color:var(--color-text-secondary);font-size:.82rem;font-weight:700;line-height:1.45}.payment-plan-summary{min-height:44px;margin:0;color:var(--color-text-secondary);font-size:.92rem;line-height:1.5}.payment-right-list{display:grid;gap:10px;margin:0;padding:0;list-style:none}.payment-right-list li{display:flex;align-items:flex-start;gap:8px;color:var(--color-text);font-size:.9rem;line-height:1.5}.payment-right-list .inline-icon{margin-top:3px;color:#15803d}.payment-muted-right{color:var(--color-text-secondary)!important}.payment-current-button{display:inline-flex;width:100%;height:50px;align-items:center;justify-content:center;border:1px solid var(--color-border);border-radius:14px;background:#f3f4f6;color:var(--color-text-secondary);font-weight:800}.payment-plan-card .button-primary{background:var(--plan-cta-bg);box-shadow:0 14px 30px color-mix(in srgb,var(--plan-accent) 26%,transparent)}.payment-plan-card .button-primary:not(:disabled):hover{box-shadow:0 18px 38px color-mix(in srgb,var(--plan-accent) 34%,transparent)}.payment-shortcuts{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.payment-shortcut-card{display:flex;min-height:72px;align-items:center;gap:12px;border:1px solid rgba(229,231,235,.78);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-sm);color:var(--color-text);padding:18px;font-weight:800;text-decoration:none}.payment-shortcut-card svg{color:var(--color-primary)}.payment-checkout-grid,.payment-status-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.75fr);gap:18px;align-items:start}.payment-summary-card,.payment-upload-card,.payment-status-card{display:grid;gap:18px}.payment-amount-box{display:grid;gap:4px;border:1px solid rgba(91,78,255,.2);border-radius:var(--radius-md);background:#f8f7ff;padding:18px}.payment-amount-box span,.payment-detail-list dt{color:var(--color-text-secondary);font-size:.86rem}.payment-amount-box strong{color:var(--color-primary);font-size:2rem}.payment-detail-list{display:grid;gap:12px;margin:0}.payment-detail-list div{display:grid;grid-template-columns:130px minmax(0,1fr);gap:12px}.payment-detail-list dd{margin:0;color:var(--color-text);font-weight:800;overflow-wrap:anywhere}.payment-membership-until{margin:8px 0 0;color:#166534;font-size:.92rem;font-weight:800;line-height:1.5}.payment-qr-box{display:grid;min-height:330px;place-items:center;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#fbfcff;padding:18px}.payment-qr-box img{width:min(300px,100%);aspect-ratio:1;-o-object-fit:contain;object-fit:contain}.payment-qr-placeholder{display:grid;width:min(220px,100%);aspect-ratio:1;place-items:center;border:1px dashed rgba(91,78,255,.36);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:2rem;font-weight:800}.payment-steps{display:grid;gap:12px}.payment-step{display:flex;align-items:flex-start;gap:12px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#fbfcff;padding:16px}.payment-step strong,.payment-step span{display:block}.payment-step strong{color:var(--color-text)}.payment-step span{color:var(--color-text-secondary);font-size:.88rem}.payment-step-success{border-color:#22c55e3d;background:#f0fdf4}.payment-step-success .status-icon{color:#15803d}.payment-step-active{border-color:#f6c45385;background:#fffbeb}.payment-step-active .status-icon{color:#b45309}.payment-step-danger{border-color:#f871715c;background:#fef2f2}.payment-step-danger .status-icon{color:#b91c1c}.payment-status-pending_review{background:#fffbeb;color:#b45309}.payment-status-approved{background:#f0fdf4;color:#15803d}.payment-status-rejected{background:#fef2f2;color:#b91c1c}.payment-history-link{color:var(--color-primary);font-weight:800;text-decoration:none}.payment-history-list{display:grid;gap:14px}.payment-history-card{display:grid;grid-template-columns:52px minmax(0,1fr);gap:14px;border:1px solid rgba(229,231,235,.78);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-sm);padding:18px}.payment-history-icon{display:grid;width:52px;height:52px;place-items:center;border-radius:16px;background:#eff6ff;color:var(--color-primary-dark)}.payment-history-main{display:grid;min-width:0;gap:10px}.payment-history-meta{display:flex;flex-wrap:wrap;gap:8px 14px;color:var(--color-text-secondary);font-size:.9rem}.payment-waiting-meta{display:inline-flex;align-items:center;gap:6px}.payment-admin-note{margin:0;border-radius:14px;background:#fef2f2;color:#991b1b;padding:10px 12px}.payment-empty-state{display:grid;justify-items:start;gap:12px}.payment-empty-state .button{width:min(220px,100%)}.law-main{display:grid;width:min(1120px,calc(100% - 32px));gap:22px;margin:0 auto;padding:32px 0 44px}.law-heading,.law-viewer-header,.law-viewer-meta{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.law-heading-actions,.law-viewer-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px}.law-heading-actions .button,.law-viewer-header .button,.law-viewer-actions .button{width:auto;min-width:150px}.law-category-list,.law-category-section{display:grid;gap:18px}.law-file-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;align-items:stretch}.law-file-card{display:grid;gap:14px;align-content:start;border:1px solid rgba(229,231,235,.78);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-sm);padding:18px}.law-file-card h3,.law-file-card p{margin:0}.law-file-card h3{font-size:1.02rem;line-height:1.4}.law-file-card p{color:var(--color-text-secondary);line-height:1.55}.law-file-meta,.law-file-footnote{display:flex;flex-wrap:wrap;gap:8px 14px;color:var(--color-text-secondary);font-size:.9rem}.law-tag-row{display:flex;flex-wrap:wrap;gap:8px}.law-tag{display:inline-flex;min-height:28px;align-items:center;border-radius:999px;background:#ecfdf5;color:#047857;padding:4px 9px;font-size:.78rem;font-weight:800}.law-card-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.law-viewer-meta{border-bottom:1px solid var(--color-border);padding-bottom:16px}.law-viewer-meta h1,.law-viewer-meta p{margin:0}.law-viewer-shell{min-height:72vh;overflow:hidden;border:1px solid rgba(229,231,235,.84);border-radius:var(--radius-md);background:#f3f4f6}.law-viewer-frame{display:block;width:100%;height:min(80vh,900px);min-height:620px;border:0;background:#fff}.flashcard-main{display:grid;width:min(1120px,calc(100% - 32px));gap:22px;margin:0 auto;padding:32px 0 44px}.flashcard-deck-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.flashcard-deck-card{display:grid;min-height:150px;align-content:space-between;gap:16px;border:1px solid rgba(229,231,235,.78);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-sm);color:var(--color-text);padding:18px;text-align:left;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.flashcard-deck-card:hover,.flashcard-deck-card:focus-visible{border-color:#5b4eff6b;box-shadow:var(--shadow-md);transform:translateY(-1px)}.flashcard-deck-name{font-size:1.04rem;font-weight:800;line-height:1.45}.flashcard-deck-meta{color:var(--color-text-secondary);font-size:.92rem;font-weight:700}.flashcard-study-shell{display:grid;gap:16px;width:min(760px,100%);margin:0 auto}.flashcard-study-status{display:flex;justify-content:space-between;gap:12px;color:var(--color-text-secondary);font-size:.92rem;font-weight:800}.flashcard-study-card{display:grid;min-height:320px;align-content:center;gap:16px;border:1px solid rgba(91,78,255,.24);border-radius:var(--radius-md);background:#fbfcff;box-shadow:var(--shadow-md);color:var(--color-text);padding:28px;text-align:center;transition:background-color .15s ease,border-color .15s ease}.flashcard-study-card:hover,.flashcard-study-card:focus-visible{border-color:var(--color-primary);background:#f8f7ff}.flashcard-study-card.is-flipped{background:#f0fdf4;border-color:#22c55e5c}.flashcard-card-face-label{color:var(--color-text-secondary);font-size:.86rem;font-weight:900;text-transform:uppercase}.flashcard-card-content{color:var(--color-text);font-size:1.35rem;font-weight:800;line-height:1.7;overflow-wrap:anywhere;white-space:pre-wrap}.flashcard-hint,.flashcard-no-hint,.flashcard-source{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-secondary);padding:14px 16px;line-height:1.55}.flashcard-hint{display:grid;min-height:58px;gap:4px;text-align:left}.flashcard-hint span{color:var(--color-primary);font-size:.82rem;font-weight:900;text-transform:uppercase}.flashcard-hint strong{color:var(--color-text);filter:blur(5px);transition:filter .15s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.flashcard-hint.is-revealed strong{filter:blur(0);-webkit-user-select:text;-moz-user-select:text;user-select:text}.flashcard-source span{color:var(--color-text);font-weight:700}.flashcard-controls{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.flashcard-import-deck-list{display:grid;gap:10px}.flashcard-import-deck{display:flex;justify-content:space-between;gap:12px;border:1px solid var(--color-border);border-radius:12px;background:#fbfcff;padding:12px 14px}.flashcard-import-deck strong{overflow-wrap:anywhere}.flashcard-import-deck span{flex:0 0 auto;color:var(--color-text-secondary);font-weight:800}@media (max-width: 720px){.auth-page{align-items:start;padding:18px}.auth-card{padding:28px 20px}.topbar{height:auto}.topbar-inner{width:calc(100% - 32px);flex-direction:column;align-items:flex-start;gap:0;padding:12px 0}.admin-topbar-inner{gap:10px}.admin-nav-links{width:100%;padding-top:10px}.admin-nav-links a{flex:1 1 calc(50% - 8px);justify-content:center}.topbar-user{width:100%;justify-content:space-between;padding-top:10px}.auth-message .payment-status-link{display:flex;margin-left:0;margin-top:4px}.dashboard-main{width:calc(100% - 32px);padding:18px 0 30px}.payment-main,.law-main,.flashcard-main{width:calc(100% - 32px);gap:16px;padding:18px 0 30px}.dashboard-hero{align-items:stretch;flex-direction:column;padding:16px}.upgrade-wrap{width:100%}.admin-main,.quiz-main{width:calc(100% - 32px);gap:16px;padding:18px 0 30px}.admin-step-grid,.flashcard-controls,.admin-law-detail-list div,.admin-law-filter-row,.admin-law-form,.admin-law-replace-row,.admin-payment-detail-list div,.admin-payment-filter-row,.admin-user-filter-row,.choice-grid,.review-summary-card,.quiz-grid,.quiz-choice-grid,.payment-checkout-grid,.payment-detail-list div,.payment-history-card,.payment-shortcuts,.payment-status-grid,.score-card,.quiz-stats-row,.quiz-filter-row,.history-attempt-card,.admin-stats-grid,.admin-action-grid,.admin-activity-row,.admin-filter-row,.batch-group-header,.admin-question-row,.admin-edit-grid,.category-tree-line,.category-inline-form,.category-rename-form,.law-card-actions,.flashcard-deck-grid,.law-file-grid{grid-template-columns:1fr}.admin-law-wide{grid-column:auto}.admin-step-card,.question-review-card,.quiz-card,.quiz-question-card,.score-card,.answer-review-card,.history-attempt-card{padding:16px}.payment-plan-card{min-height:0}.stat-card{padding:16px 8px}.stat-value{font-size:1.35rem}.payment-qr-box{min-height:0;padding:14px}.payment-qr-box img{width:min(300px,calc(100vw - 96px))}.payment-plan-header,.payment-status-header,.payment-history-title-row,.law-heading,.law-viewer-header,.law-viewer-meta{align-items:flex-start;flex-direction:column}.law-heading-actions,.flashcard-import-deck,.law-viewer-actions{width:100%;justify-content:stretch}.law-heading-actions .button,.flashcard-controls .button,.law-viewer-header .button,.law-viewer-actions .button{width:100%}.flashcard-study-card{min-height:300px;padding:22px 18px}.flashcard-card-content{font-size:1.16rem}.flashcard-import-deck{align-items:flex-start;flex-direction:column}.law-viewer-frame{height:70vh;min-height:460px}.quiz-play-header{align-items:flex-start;flex-direction:column}.quiz-nav-actions,.quiz-modal-actions,.score-actions{grid-template-columns:1fr}.quiz-question-navigator{display:flex;justify-content:flex-start;overflow-x:auto;padding:14px}.quiz-nav-dot{flex:0 0 48px;width:48px;height:48px}.score-circle{width:118px;height:118px;font-size:1.65rem}.result-stats-grid{grid-template-columns:1fr}.admin-pagination,.admin-bottom-actions{align-items:stretch;flex-direction:column}.admin-pagination .button,.admin-bottom-actions .button{width:100%}.question-card-actions{justify-content:stretch}.question-card-actions .button{width:100%}.cancel-confirm-actions{grid-template-columns:1fr}.admin-section-header,.category-tree-actions,.batch-actions,.question-row-actions{align-items:stretch;flex-direction:column}.admin-section-header .button,.category-tree-actions .button,.batch-actions .button,.question-row-actions .button,.admin-inline-actions .button{width:100%}.category-tree-row.level-2,.category-tree-row.level-3,.category-inline-form{margin-left:0}.category-toggle,.icon-action{width:100%;min-height:48px}.category-leaf-spacer{display:none}}
