@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";
:root{--bg:#f4f1ea;--bg-soft:#ebe6dc;--surface:#fff;--surface-muted:#f8f6f1;--ink:#1d2528;--muted:#6d7678;--line:#ded8ca;--gold:#b7791f;--gold-strong:#8f5512;--green:#1f7a5a;--blue:#315f8a;--rose:#a54857;--shadow:0 18px 48px #221f191a;--radius:8px;--font-sans:"Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*{box-sizing:border-box}html{background:var(--bg)}body{background:linear-gradient(135deg, #b7791f14, transparent 32%), linear-gradient(315deg, #1f7a5a14, transparent 28%), var(--bg);color:var(--ink);font-family:var(--font-sans);min-height:100vh;margin:0;line-height:1.5}body:before{content:"";opacity:.15;filter:grayscale();pointer-events:none;z-index:0;background-image:url(/gracefields-logo.jpeg);background-position:50%;background-repeat:no-repeat;background-size:clamp(300px,50vw,600px);width:100vw;height:100vh;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}button,input,select,textarea{font:inherit}button{cursor:pointer}a{color:inherit}.app-container{z-index:1;width:100%;min-height:100vh;display:flex;position:relative}.sidebar{color:#f9faf4;background:#172023;flex-direction:column;flex:0 0 276px;min-height:100vh;padding:28px 20px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:12px;margin-bottom:34px;text-decoration:none;display:flex}.brand-mark{border-radius:var(--radius);color:#fff;letter-spacing:0;background:linear-gradient(135deg,#d69e2e,#1f7a5a);justify-content:center;align-items:center;width:42px;height:42px;font-weight:800;display:inline-flex}.brand strong,.brand small{display:block}.brand strong{font-size:17px}.brand small{color:#aeb8b8;font-size:12px}.compact-brand{margin:0}.nav-stack{gap:6px;display:grid}.nav-link{border-radius:var(--radius);color:#c6d0d0;border:1px solid #0000;align-items:center;gap:12px;padding:12px;font-weight:650;text-decoration:none;display:flex}.nav-link:hover,.nav-link.active{color:#fff;background:#ffffff14;border-color:#ffffff1a}.nav-link.active .nav-icon{background:var(--gold);color:#fff}.nav-icon{background:#ffffff14;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:800;display:inline-flex}.sidebar-footer{color:#aeb8b8;align-items:center;gap:8px;margin-top:auto;padding:16px 12px 0;font-size:13px;display:flex}.status-dot{background:#48bb78;border-radius:999px;width:8px;height:8px;box-shadow:0 0 0 5px #48bb7826}.main-content{flex:1;min-width:0;max-width:1500px;padding:34px}.header{justify-content:space-between;align-items:center;gap:20px;margin-bottom:26px;display:flex}.eyebrow{color:var(--gold-strong);letter-spacing:.08em;text-transform:uppercase;margin:0 0 6px;font-size:12px;font-weight:800}.header-title{letter-spacing:0;margin:0;font-size:clamp(28px,4vw,42px);line-height:1.1}.header-profile{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.user-menu{border:1px solid var(--line);border-radius:var(--radius);color:var(--ink);text-align:left;background:#fff;align-items:center;gap:10px;min-height:48px;padding:4px 10px 4px 4px;display:inline-flex}.user-menu strong,.user-menu small{display:block}.user-menu small{color:var(--muted);font-size:12px}.avatar,.mini-avatar,.profile-avatar{border-radius:var(--radius);color:#fff;background:#172023;justify-content:center;align-items:center;font-weight:800;display:inline-flex}.avatar{width:42px;height:42px}.auth-loading{place-items:center;gap:12px;width:100%;min-height:100vh;display:grid}.login-shell{grid-template-columns:minmax(0,1fr) minmax(360px,440px);width:100%;min-height:100vh;display:grid}.login-hero{color:#fff;background-color:#0000;background-image:linear-gradient(135deg,#172023eb,#1f7a5abd),url(https://images.unsplash.com/photo-1438232992991-995b7058bbb3?auto=format&fit=crop&w=1600&q=80);background-position:50%;background-repeat:repeat,repeat;background-size:cover;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;flex-direction:column;justify-content:space-between;padding:44px;display:flex}.brand-lockup{align-items:center;gap:12px;display:flex}.brand-lockup strong,.brand-lockup small{display:block}.brand-lockup small,.login-copy{color:#ffffffc7}.login-hero h1{letter-spacing:0;margin:0 0 18px;font-size:clamp(44px,7vw,76px);line-height:.96}.login-copy{max-width:560px;font-size:18px}.login-panel{background:#ffffffeb;align-content:center;gap:22px;padding:44px;display:grid}.login-panel h2{margin:0;font-size:30px}.login-form{gap:16px;display:grid}.mini-avatar{flex:0 0 38px;width:38px;height:38px}.btn{border-radius:var(--radius);border:1px solid #0000;justify-content:center;align-items:center;min-height:42px;padding:10px 16px;font-weight:750;text-decoration:none;display:inline-flex}.btn-primary{background:var(--gold);color:#fff}.btn-primary:hover{background:var(--gold-strong)}.btn-secondary{border-color:var(--line);color:var(--ink);background:#fff}.btn-ghost{border-color:var(--line);color:var(--ink);background:0 0}.dashboard-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:18px;display:grid}.metric-card,.panel,.portal-panel,.portal-link{border-radius:var(--radius);box-shadow:var(--shadow);background:#ffffffe0;border:1px solid #ded8cae0}.metric-card{padding:22px;position:relative;overflow:hidden}.metric-card:before{background:var(--gold);content:"";height:4px;position:absolute;top:0;left:0;right:0}.metric-card.tone-green:before{background:var(--green)}.metric-card.tone-blue:before{background:var(--blue)}.metric-card.tone-rose:before{background:var(--rose)}.metric-title{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-size:12px;font-weight:800}.metric-value{letter-spacing:0;overflow-wrap:anywhere;margin-top:12px;font-size:clamp(26px,3vw,34px);font-weight:800;line-height:1.1}.metric-trend{color:var(--muted);margin-top:10px;font-size:13px}.work-grid,.report-grid,.split-grid{gap:18px;display:grid}.work-grid{grid-template-columns:2fr 1fr}.report-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.report-filter-stack{gap:16px;display:grid}.report-filters{background:var(--surface-muted);border:1px solid var(--line);border-radius:var(--radius);grid-template-columns:minmax(180px,1.2fr) repeat(3,minmax(140px,.8fr)) auto;align-items:end;gap:12px;padding:14px;display:grid}.filter-actions{align-items:end;min-height:42px;display:flex}.split-grid{grid-template-columns:minmax(0,1.55fr) minmax(320px,.8fr)}.span-2{grid-column:span 2}.span-3{grid-column:1/-1}.panel{min-width:0;margin-bottom:18px;padding:22px}.accent-panel{border-color:#b7791f6b}.panel-header{justify-content:space-between;align-items:center;gap:14px;margin-bottom:18px;display:flex}.panel-title{margin:0;font-size:18px}.notice{border-radius:var(--radius);color:#76460c;background:#fff7e6;border:1px solid #f3d29b;margin-bottom:18px;padding:12px 14px;font-weight:650}.empty-state{color:var(--muted);text-align:center;place-items:center;gap:6px;min-height:150px;padding:28px;display:grid}.empty-state strong{color:var(--ink)}.activity-list,.shortcut-stack,.category-list{gap:10px;display:grid}.activity-item,.event-card,.shortcut,.category-row{background:var(--surface-muted);border:1px solid var(--line);border-radius:var(--radius)}.activity-item{justify-content:space-between;align-items:center;gap:16px;padding:14px;display:flex}.activity-item strong,.activity-item span,.activity-meta small,.shortcut strong,.shortcut span,.event-card strong,.event-card span,.event-card small{display:block}.activity-item span,.activity-meta small,.shortcut span,.event-card span,.event-card small,.category-row span,.person-cell small{color:var(--muted);font-size:13px}.activity-meta{text-align:right;justify-items:end;gap:6px;display:grid}.shortcut{text-align:left;width:100%;padding:14px;text-decoration:none;display:block}.shortcut:hover,.portal-link:hover{border-color:#b7791f8c}.event-strip{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.event-card{padding:14px}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.form-grid.single-column{grid-template-columns:1fr}.inline-form{grid-template-columns:1fr 2fr auto;align-items:end;gap:14px;display:grid}label{color:var(--muted);gap:7px;font-size:13px;font-weight:750;display:grid}.field-label-row{color:var(--muted);justify-content:space-between;align-items:center;margin-bottom:7px;font-size:13px;font-weight:750;display:flex}.field-label-row small{color:var(--gold-strong);font-size:12px;font-weight:800}input,select,textarea{border:1px solid var(--line);border-radius:var(--radius);color:var(--ink);background:#fff;outline:none;width:100%;min-height:42px;padding:10px 12px}textarea{resize:vertical;min-height:105px}input:focus,select:focus,textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px #b7791f29}.toolbar-input{min-width:230px}.check-row{align-items:center;gap:10px;display:flex}.check-row input{width:18px;height:18px;min-height:18px}.department-picker{grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:10px;display:grid}.department-option{border:1px solid var(--line);border-radius:var(--radius);color:var(--ink);cursor:pointer;background:#fff;flex-direction:row;align-items:center;gap:10px;min-height:62px;padding:10px 12px;display:flex}.department-option:has(input:checked){background:#fff8ec;border-color:#b7791f8c;box-shadow:0 0 0 3px #b7791f1a}.department-option input{width:18px;height:18px;min-height:18px}.department-option span,.department-option strong,.department-option small{display:block}.department-option small,.muted-box{color:var(--muted);font-size:13px}.muted-box{background:var(--surface-muted);border:1px dashed var(--line);border-radius:var(--radius);padding:12px}.department-admin-list{gap:10px;margin-top:16px;display:grid}.department-admin-row{background:var(--surface-muted);border:1px solid var(--line);border-radius:var(--radius);grid-template-columns:minmax(0,1fr) minmax(190px,.45fr) auto;align-items:center;gap:12px;padding:12px;display:grid}.department-admin-row strong,.department-admin-row span{display:block}.department-admin-row span{color:var(--muted);font-size:13px}button:disabled{cursor:not-allowed;opacity:.55}.chip-row{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.chip,.badge{border-radius:999px;padding:5px 9px;font-size:12px;font-weight:800;display:inline-flex}.chip{color:var(--gold-strong);background:#f1eadc}.badge-success{color:#0e6245;background:#def7ec}.badge-warning{color:#7a4a08;background:#fff2cc}.badge-danger{color:#9b1c1c;background:#fde2e1}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:760px}th,td{border-bottom:1px solid var(--line);text-align:left;vertical-align:middle;padding:13px 10px}th{color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-size:12px}td small{color:var(--muted);margin-top:2px;display:block}tbody tr{transition:background .14s}tbody tr:hover,.selected-row{background:#b7791f14}.strong-cell{font-weight:800}.person-cell{align-items:center;gap:10px;display:flex}.profile-card{border-bottom:1px solid var(--line);text-align:center;justify-items:center;gap:6px;margin-bottom:16px;padding-bottom:18px;display:grid}.profile-card h3,.profile-card p{margin:0}.profile-card p{color:var(--muted)}.profile-avatar{width:78px;height:78px;font-size:24px}.detail-list{gap:10px;margin:0;display:grid}.detail-list div{grid-template-columns:120px 1fr;gap:4px;display:grid}.detail-list dt{color:var(--muted);font-size:13px;font-weight:800}.detail-list dd{margin:0}.qr-panel{text-align:center;place-items:center;gap:10px;display:grid}.qr-panel img{border:1px solid var(--line);border-radius:var(--radius);background:#fff;padding:10px}.bar-chart{grid-template-columns:repeat(12,minmax(24px,1fr));align-items:end;gap:10px;height:260px;display:grid}.bar-column{grid-template-rows:1fr auto;align-items:center;gap:8px;height:100%;display:grid}.bar-column span{background:linear-gradient(#d69e2e,#1f7a5a);border-radius:6px 6px 0 0;align-self:end;width:100%;min-height:8px}.bar-column small{color:var(--muted);font-size:11px}.category-row{grid-template-columns:150px 1fr auto;align-items:center;gap:14px;padding:14px;display:grid}.category-meter,.inline-meter{background:#ece5d8;border-radius:999px;height:10px;overflow:hidden}.category-meter span,.inline-meter span{background:var(--green);height:100%;display:block}.portal-shell{width:100%;max-width:760px;margin:0 auto;padding:22px}.portal-shell-wide{max-width:1180px}.portal-page{position:relative}.portal-page:before{content:"";pointer-events:none;z-index:-1;background:linear-gradient(120deg,#17202314,#0000 36%),linear-gradient(280deg,#1f7a5a1a,#0000 38%);min-height:360px;position:fixed;inset:0}.portal-auth-shell{align-items:center;min-height:100vh;padding:24px;display:grid}.portal-auth-card{background-blend-mode:screen;border-radius:var(--radius);background-color:#0000;background-image:linear-gradient(#fffffff2,#f8f6f1f2),url(https://images.unsplash.com/photo-1507692049790-de58290a4334?auto=format&fit=crop&w=1200&q=80);background-position:50%;background-repeat:repeat,repeat;background-size:cover;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;border:1px solid #ded8caeb;gap:22px;width:100%;max-width:460px;margin:0 auto;padding:28px;display:grid;box-shadow:0 24px 70px #17202329}.portal-logo,.portal-logo-small{border-radius:var(--radius);object-fit:contain;background:#fff;border:1px solid #ded8caeb}.portal-logo{width:74px;height:74px;padding:8px;box-shadow:0 14px 34px #17202324}.portal-logo-small{flex:0 0 44px;width:44px;height:44px;padding:5px}.portal-auth-heading h1{margin:0 0 12px;font-size:clamp(34px,8vw,52px);line-height:1}.portal-auth-heading p{color:var(--muted);margin:0}.portal-auth-footer{border-top:1px solid var(--line);text-align:center;padding-top:16px}.portal-auth-footer a{color:var(--gold-strong);font-size:13px;font-weight:800;text-decoration:none}.portal-header,.portal-grid,.portal-actions,.portal-links{gap:14px;display:grid}.portal-header{justify-content:space-between;align-items:center;margin-bottom:28px;display:flex}.portal-header-actions{align-items:center;gap:10px;display:flex}.portal-avatar{background:linear-gradient(135deg, #172023, var(--green))}.portal-member-hero{border-radius:var(--radius);color:#fff;background-color:#0000;background-image:linear-gradient(135deg,#172023f0,#1f7a5ad1),url(https://images.unsplash.com/photo-1490730141103-6cac27aaab94?auto=format&fit=crop&w=1400&q=80);background-position:50%;background-repeat:repeat,repeat;background-size:cover;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;border:1px solid #ffffff24;grid-template-columns:1fr auto;align-items:end;gap:22px;margin-bottom:16px;padding:30px;display:grid;overflow:hidden;box-shadow:0 24px 70px #1720232e}.portal-member-hero h1{margin:0 0 10px;font-size:clamp(34px,5vw,56px);line-height:1}.portal-member-hero span{color:#ffffffc7;font-weight:700}.portal-member-hero .eyebrow{color:#f6d58a}.portal-hero-actions{flex-wrap:wrap;gap:10px;margin-top:22px;display:flex}.portal-member-hero .btn-secondary{color:#fff;background:#ffffff1f;border-color:#ffffff38}.portal-hero-stats{grid-template-columns:repeat(3,minmax(110px,1fr));gap:10px;display:grid}.portal-hero-stats div{border-radius:var(--radius);background:#ffffff1f;border:1px solid #ffffff29;min-width:138px;padding:14px}.portal-hero-stats strong,.portal-hero-stats span{display:block}.portal-hero-stats strong{font-size:20px}.portal-hero-stats span{color:#ffffffb8;margin-top:3px;font-size:12px;font-weight:750}.portal-tabs{border:1px solid var(--line);border-radius:var(--radius);background:#ffffffdb;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px;margin-bottom:16px;padding:6px;display:grid}.portal-tabs button{color:var(--muted);background:0 0;border:0;border-radius:6px;justify-content:center;align-items:center;gap:8px;min-height:40px;padding:8px 10px;font-weight:800;display:inline-flex}.portal-tabs button span{background:#17202314;border-radius:999px;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;display:inline-flex}.portal-tabs button.active{color:#fff;background:#172023}.portal-tabs button.active span{background:var(--gold);color:#fff}.portal-hero{margin-bottom:18px}.portal-hero h1{margin:0 0 8px;font-size:38px;line-height:1.05}.portal-hero span{color:var(--muted);font-weight:700}.tithe-card{border-radius:var(--radius);box-shadow:var(--shadow);color:#fff;background:linear-gradient(135deg,#172023f5,#1f7a5ae0),linear-gradient(90deg,#f6d58a3d,#0000 52%);justify-content:space-between;margin-bottom:16px;padding:24px;display:flex;overflow:hidden}.tithe-card span,.tithe-card strong,.tithe-card small{display:block}.tithe-card span,.tithe-card small{color:#ffffffc2}.tithe-card strong{margin:8px 0;font-size:30px}.card-chip{background:#ffffff24;border:1px solid #ffffff38;border-radius:999px;align-self:start;padding:6px 10px;font-size:12px;font-weight:800}.portal-grid{grid-template-columns:1fr auto}.qr-lite{align-items:center;gap:16px;padding:18px;display:flex}.qr-lite strong,.qr-lite span{display:block}.qr-lite span{color:var(--muted);font-size:14px}.qr-mock{border-radius:var(--radius);background:linear-gradient(90deg,#111 10px,#0000 10px) 0 0/20px 20px,linear-gradient(#111 10px,#0000 10px) 0 0/20px 20px,#fff;border:8px solid #fff;flex:0 0 84px;height:84px;box-shadow:inset 0 0 0 1px #111}.portal-actions{align-content:stretch;min-width:170px}.portal-links{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:16px}.portal-dashboard,.portal-two-column{gap:16px;display:grid}.portal-dashboard{grid-template-columns:1.2fr 1fr}.portal-two-column{grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr)}.portal-panel{padding:20px;position:relative;overflow:hidden}.portal-panel h2{margin:0 0 16px;font-size:18px}.portal-panel:before{background:linear-gradient(90deg, var(--gold), transparent);content:"";opacity:.75;height:3px;position:absolute;top:0;left:0;right:0}.portal-card-large{min-height:180px;margin:0}.portal-card-large strong{font-size:clamp(32px,5vw,48px)}.portal-task-list,.portal-history-list,.portal-event-list,.portal-contact-list,.portal-form,.portal-detail-list{gap:10px;display:grid}.portal-task-list button,.portal-event,.portal-history-item,.payment-result,.ministry-card,.portal-contact-list div{background:var(--surface-muted);border:1px solid var(--line);border-radius:var(--radius);color:var(--ink);padding:14px}.portal-task-list button,.portal-event{text-align:left;font-weight:750}.portal-task-list button{gap:4px;display:grid}.portal-task-list button span{color:var(--muted);font-size:13px;font-weight:600}.portal-task-list button:hover,.portal-event:hover,.portal-event.active{border-color:#b7791f94}.portal-history-item{justify-content:space-between;align-items:center;gap:12px;display:flex}.portal-history-item,.portal-event,.portal-task-list button,.payment-result,.ministry-card,.portal-contact-list div{transition:border-color .16s,transform .16s,box-shadow .16s}.portal-history-item:hover,.portal-event:hover,.portal-task-list button:hover,.payment-result:hover,.ministry-card:hover,.portal-contact-list div:hover{transform:translateY(-1px);box-shadow:0 12px 28px #17202314}.portal-history-item strong,.portal-history-item span,.portal-event strong,.portal-event span,.portal-event small,.payment-result strong,.payment-result span,.ministry-card strong,.ministry-card span,.portal-contact-list strong,.portal-contact-list span{display:block}.portal-history-item span,.portal-event span,.portal-event small,.payment-result span,.ministry-card span,.ministry-card p,.portal-contact-list span{color:var(--muted);font-size:13px}.payment-result{gap:10px;margin-top:14px;display:grid}.qr-image,.qr-image img{width:84px;height:84px}.qr-image img,.qr-focus img{border:1px solid var(--line);border-radius:var(--radius);background:#fff;padding:8px}.qr-focus{text-align:center;align-content:start;justify-items:center;gap:12px;display:grid}.qr-focus img,.qr-focus .qr-mock{width:220px;height:220px}.profile-completion{background:#ece5d8;border-radius:999px;height:12px;margin-bottom:16px;overflow:hidden}.profile-completion span{background:linear-gradient(90deg, var(--gold), var(--green));height:100%;display:block}.portal-detail-list{margin:0}.portal-detail-list div{border-bottom:1px solid var(--line);grid-template-columns:130px 1fr;gap:8px;padding:10px 0;display:grid}.portal-detail-list dt{color:var(--muted);font-size:13px;font-weight:800}.portal-detail-list dd{margin:0}.portal-link{color:var(--ink);text-align:left;gap:6px;padding:18px;display:grid}.portal-link span{color:var(--muted);font-size:13px}.mobile-actions{display:none}.text-left{text-align:left}.finance-tabs{border:1px solid var(--line);border-radius:var(--radius);background:#ffffffb8;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:6px;margin-bottom:18px;padding:6px;display:grid}.finance-tabs button{color:var(--muted);background:0 0;border:0;border-radius:6px;min-height:42px;padding:8px 10px;font-weight:800}.finance-tabs button.active{color:#fff;background:#172023}.finance-management-grid{grid-template-columns:minmax(300px,.75fr) minmax(0,1.45fr);gap:18px;display:grid}.instrument-grid,.account-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.instrument-card,.account-card,.finance-breakdown-row{background:var(--surface-muted);border:1px solid var(--line);border-radius:var(--radius);padding:14px}.instrument-card strong,.instrument-card span,.instrument-card p,.account-card span,.account-card strong,.account-card small,.account-card b,.finance-breakdown-row strong,.finance-breakdown-row span,.finance-breakdown-row b{display:block}.instrument-card strong,.account-card strong,.account-card b,.finance-breakdown-row b{font-size:18px}.instrument-card span,.instrument-card p,.account-card span,.account-card small,.finance-breakdown-row span{color:var(--muted);font-size:13px}.instrument-card p{margin:8px 0 12px}.account-card{position:relative;overflow:hidden}.account-card:before{background:var(--blue);content:"";height:4px;position:absolute;top:0;left:0;right:0}.account-card b{margin-top:14px}.finance-breakdown-row{gap:4px;display:grid}.approval-list{gap:14px;display:grid}.approval-card{background:var(--surface-muted);border:1px solid var(--line);border-radius:var(--radius);grid-template-columns:minmax(240px,.65fr) minmax(0,1fr);gap:18px;padding:16px;display:grid}.approval-card h3,.approval-card p{margin:0}.approval-card h3{font-size:20px}.approval-card p{color:var(--muted);margin:6px 0 16px}.approval-card strong{font-size:24px}.approval-controls{gap:12px;display:grid}.approval-controls textarea{min-height:76px}.approval-actions{flex-wrap:wrap;gap:10px;display:flex}.crm-layout{grid-template-columns:minmax(300px,.85fr) minmax(0,1.15fr);gap:18px;display:grid}.crm-composer{align-self:start}.crm-actions,.merge-field-row{flex-wrap:wrap;gap:8px;display:flex}.segment-tabs{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;margin-bottom:12px;display:grid}.segment-tabs button,.merge-field-row button{border:1px solid var(--line);color:var(--muted);background:#fff;border-radius:6px;min-height:34px;padding:7px 9px;font-size:12px;font-weight:800}.segment-tabs button.active,.merge-field-row button:hover{color:#fff;background:#172023}.crm-search{min-width:0;margin-bottom:12px}.contact-list,.template-list{gap:10px;max-height:560px;padding-right:4px;display:grid;overflow:auto}.contact-card,.template-card,.sms-preview{background:var(--surface-muted);border:1px solid var(--line);border-radius:var(--radius)}.contact-card{color:var(--ink);text-align:left;align-items:center;gap:10px;padding:12px;display:flex}.contact-card.selected{border-color:var(--green);box-shadow:inset 4px 0 0 var(--green)}.contact-card strong,.contact-card small,.template-card strong,.template-card span,.template-card small,.sms-preview strong,.sms-preview span{display:block}.contact-card small,.template-card small,.template-card span,.sms-preview span{color:var(--muted);font-size:13px}.template-card{color:var(--ink);text-align:left;gap:5px;padding:13px;display:grid}.template-card:hover{border-color:#b7791f94}.template-card small{max-height:42px;overflow:hidden}.sms-preview{gap:10px;padding:14px;display:grid}.sms-preview p{border:1px solid var(--line);border-radius:var(--radius);white-space:pre-wrap;background:#fff;min-height:88px;margin:0;padding:12px}.visitor-list{gap:10px;max-height:520px;padding-right:4px;display:grid;overflow:auto}.visitor-card{background:var(--surface-muted);border:1px solid var(--line);border-radius:var(--radius);justify-content:space-between;align-items:center;gap:14px;padding:14px;display:flex}.visitor-card strong,.visitor-card span,.visitor-card small{display:block}.visitor-card span,.visitor-card small{color:var(--muted);font-size:13px}.visitor-actions{align-items:end;gap:8px;min-width:160px;display:grid}.file-chip,.attachment-link{border:1px solid var(--line);border-radius:var(--radius);background:#fff;padding:10px 12px}.file-chip strong,.file-chip span{display:block}.file-chip span{color:var(--muted);font-size:13px}.attachment-link{color:var(--blue);margin-top:8px;font-size:13px;font-weight:800;text-decoration:none;display:inline-flex}.role-matrix{gap:14px;display:grid}.role-card{background:var(--surface-muted);border:1px solid var(--line);border-radius:var(--radius);padding:16px}.role-card-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.role-card-header strong,.role-card-header span{display:block}.role-card-header span{color:var(--muted);font-size:13px}.privilege-groups{grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px;display:grid}.privilege-group{border:1px solid var(--line);border-radius:var(--radius);background:#fff;padding:12px}.privilege-group h3{margin:0 0 10px;font-size:13px}.privilege-check{flex-direction:row;align-items:center;gap:8px;margin-bottom:8px;font-weight:650;display:flex}.privilege-check input{width:16px;height:16px;min-height:16px}@media (max-width:1120px){.dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.work-grid,.report-grid,.report-filters,.split-grid,.portal-grid,.portal-dashboard,.portal-two-column,.portal-member-hero,.finance-management-grid,.approval-card,.crm-layout{grid-template-columns:1fr}.span-2,.span-3{grid-column:auto}.event-strip{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:820px){.app-container{display:block}.login-shell{grid-template-columns:1fr}.login-hero{min-height:360px;padding:28px}.login-panel{padding:28px}.sidebar{width:100%;min-height:auto;position:static}.nav-stack{grid-template-columns:repeat(2,minmax(0,1fr))}.sidebar-footer{display:none}.main-content{padding:22px}.header{flex-direction:column;align-items:flex-start}.header-profile{justify-content:flex-start;width:100%}.dashboard-grid,.form-grid,.inline-form,.department-admin-row,.event-strip,.portal-links,.portal-hero-stats,.instrument-grid,.account-grid{grid-template-columns:1fr}.portal-shell{padding:16px}.portal-tabs{grid-template-columns:repeat(3,minmax(0,1fr))}.toolbar-input{min-width:0}.panel-header,.activity-item,.category-row,.tithe-card,.qr-lite,.portal-history-item,.visitor-card{flex-direction:column;align-items:stretch}.panel-header,.activity-item,.tithe-card,.qr-lite,.portal-history-item,.visitor-card{display:flex}.visitor-actions{min-width:0}.portal-detail-list div,.category-row{grid-template-columns:1fr}.span-2{grid-column:auto}.portal-actions{min-width:0}}.portal-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.portal-modal{background:var(--bg-card);border-radius:12px;width:90%;max-width:500px;padding:2rem;box-shadow:0 10px 40px #0003}.portal-modal h3{color:var(--text-base);margin-top:0;margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.portal-modal p{color:var(--text-muted);margin-bottom:1.5rem;font-size:.9rem}.portal-modal-actions{justify-content:flex-end;gap:1rem;margin-top:2rem;display:flex}
