:root{color-scheme:light;font-family:Arial,Helvetica,sans-serif;color:#111827;background:#f8fafc;line-height:1.5;font-weight:400}*{box-sizing:border-box}body{margin:0;min-width:320px;background:#f8fafc;color:#111827}button,input,textarea{font:inherit}button{cursor:pointer}input,textarea{width:100%;border:1px solid #d1d5db;border-radius:10px;padding:.75rem .875rem;background:#fff;color:#111827}textarea{resize:vertical}label{display:grid;gap:.4rem;font-size:.95rem;color:#374151}.login-shell,.setup-shell,.auth-shell{min-height:100vh;display:grid;padding:1.5rem}.login-shell{place-items:center}.setup-shell,.auth-shell{align-content:start;gap:1.5rem}.login-card,.setup-card{display:grid;gap:1rem;padding:2rem;background:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 10px 30px #0f172a0a}.login-card{width:min(100%,420px)}.setup-card{width:min(100%,920px);margin:0 auto}.login-card h1,.login-card h2,.setup-card h1,.message-meta h2,.auth-header h1{margin:0;font-size:1.5rem}.login-card p,.setup-card p,.auth-header p{margin:.4rem 0 0;color:#6b7280}.auth-header{width:min(100%,960px);margin:0 auto;display:grid;gap:.75rem}.auth-grid,.setup-grid,.admin-grid{display:grid;gap:1rem}.auth-grid{width:min(100%,960px);margin:0 auto;grid-template-columns:repeat(2,minmax(0,1fr))}.auth-grid .login-card{width:100%}.app-shell,.admin-shell{min-height:100vh;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.9rem 1.25rem;background:#fff;border-bottom:1px solid #e5e7eb}.topbar-subtitle{display:block;font-size:.85rem;color:#6b7280}.topbar-actions{display:flex;gap:.75rem}.mail-grid{flex:1;display:grid;grid-template-columns:240px 360px 1fr;min-height:0}.admin-grid{flex:1;grid-template-columns:minmax(360px,460px) minmax(0,1fr);min-height:0}.panel{min-height:0;background:#fff;border-right:1px solid #e5e7eb}.panel:last-child{border-right:0}.panel-heading{padding:1rem 1rem .85rem;font-size:.9rem;font-weight:700;color:#6b7280;border-bottom:1px solid #f0f2f4}.sidebar,.list-panel,.viewer-panel,.admin-form-panel,.admin-list-panel{display:flex;flex-direction:column}.folder-list,.message-list,.user-list{overflow:auto;padding:.5rem}.folder-button,.message-row{width:100%;text-align:left;border:1px solid transparent;background:transparent;border-radius:12px}.folder-button{display:flex;justify-content:space-between;padding:.8rem .9rem;color:#374151}.folder-button:hover,.message-row:hover,.ghost-button:hover{background:#f8fafc}.folder-button.active,.message-row.active{background:#f3f4f6;border-color:#e5e7eb}.folder-count{color:#9ca3af}.message-row{display:grid;gap:.3rem;padding:.9rem;margin-bottom:.35rem;border-color:#eef2f7}.message-row-top{display:flex;justify-content:space-between;gap:.75rem;font-size:.9rem}.message-row-top span,.message-row-preview{color:#6b7280}.message-row-subject{font-weight:600}.message-view{display:grid;gap:1rem;padding:1rem;min-height:0}.message-meta{display:grid;gap:.35rem}.message-iframe{width:100%;min-height:60vh;border:1px solid #e5e7eb;border-radius:12px;background:#fff}.message-text{margin:0;padding:1rem;white-space:pre-wrap;background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px}.admin-form{display:grid;gap:1rem;padding:1rem}.user-card{display:grid;gap:.2rem;padding:1rem;background:#fff;border:1px solid #e5e7eb;border-radius:14px}.checkbox-row{grid-template-columns:auto 1fr;align-items:center}.checkbox-row input{width:16px;height:16px}.empty-state{padding:1rem;color:#6b7280}.error-banner{padding:.8rem .9rem;border:1px solid #fecaca;background:#fef2f2;color:#991b1b;border-radius:12px}.viewer-error{margin:1rem}.primary-button,.ghost-button{border-radius:10px;border:1px solid #d1d5db;padding:.7rem 1rem;background:#fff;color:#111827}.primary-button{background:#111827;border-color:#111827;color:#fff}.primary-button:disabled,.ghost-button:disabled{opacity:.65;cursor:not-allowed}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a2e;display:grid;place-items:center;padding:1rem}.modal-card{width:min(100%,640px);display:grid;gap:1rem;background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:1.25rem;box-shadow:0 16px 50px #0f172a1f}.modal-header,.modal-actions{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.screen-loading{min-height:100vh;display:grid;place-items:center;color:#6b7280}@media (max-width: 1080px){.mail-grid{grid-template-columns:220px 320px 1fr}}@media (max-width: 920px){.auth-grid,.admin-grid,.mail-grid,.setup-grid{grid-template-columns:1fr}.panel{border-right:0;border-bottom:1px solid #e5e7eb}.panel:last-child{border-bottom:0}.message-iframe{min-height:420px}.topbar{align-items:flex-start;flex-direction:column}}
