:root{--primary: #2c5f4f;--primary-dark: #1a3d31;--primary-light: #4a8c75;--accent: #d4a574;--bg: #fafaf8;--bg-secondary: #f5f3ef;--text: #2a2a2a;--text-secondary: #666;--border: #e0ddd8;--shadow: rgba(44, 95, 79, .08);--success: #5a9b7f;--warning: #e8a05d;--danger: #c86a5a;--ion-color-primary: #2c5f4f;--ion-color-primary-rgb: 44, 95, 79;--ion-color-primary-contrast: #ffffff;--ion-color-primary-contrast-rgb: 255, 255, 255;--ion-color-primary-shade: #1a3d31;--ion-color-primary-tint: #4a8c75;--ion-color-secondary: #d4a574;--ion-color-secondary-rgb: 212, 165, 116;--ion-color-secondary-contrast: #000000;--ion-color-secondary-contrast-rgb: 0, 0, 0;--ion-color-secondary-shade: #baa166;--ion-color-secondary-tint: #e0b685;--ion-color-success: #5a9b7f;--ion-color-success-rgb: 90, 155, 127;--ion-color-success-contrast: #ffffff;--ion-color-success-contrast-rgb: 255, 255, 255;--ion-color-success-shade: #4f8870;--ion-color-success-tint: #6ba58c;--ion-color-warning: #e8a05d;--ion-color-warning-rgb: 232, 160, 93;--ion-color-warning-contrast: #000000;--ion-color-warning-contrast-rgb: 0, 0, 0;--ion-color-warning-shade: #cc8d52;--ion-color-warning-tint: #eaaa6d;--ion-color-danger: #c86a5a;--ion-color-danger-rgb: 200, 106, 90;--ion-color-danger-contrast: #ffffff;--ion-color-danger-contrast-rgb: 255, 255, 255;--ion-color-danger-shade: #b05d4f;--ion-color-danger-tint: #ce796b;--ion-background-color: #fafaf8;--ion-background-color-rgb: 250, 250, 248;--ion-text-color: #2a2a2a;--ion-text-color-rgb: 42, 42, 42;--ion-border-color: #e0ddd8;--ion-font-family: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-h1: 2rem;--font-size-h2: 1.5rem;--font-size-h3: 1.25rem;--font-size-h4: 1rem;--font-size-body: 1rem;--font-size-small: .875rem;--font-size-caption: .75rem;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-xxl: 48px;--elevation-0: none;--elevation-1: 0 1px 3px rgba(0,0,0,.12), 0 1px 2px rgba(0,0,0,.24);--elevation-2: 0 3px 6px rgba(0,0,0,.15), 0 2px 4px rgba(0,0,0,.12);--elevation-3: 0 10px 20px rgba(0,0,0,.15), 0 3px 6px rgba(0,0,0,.1);--elevation-4: 0 15px 25px rgba(0,0,0,.15), 0 5px 10px rgba(0,0,0,.05);--elevation-5: 0 20px 40px rgba(0,0,0,.2);--primary-hover: rgba(44, 95, 79, .08);--primary-active: rgba(44, 95, 79, .16);--primary-disabled: rgba(44, 95, 79, .38);--divider-color: rgba(0, 0, 0, .12);--overlay-color: rgba(0, 0, 0, .32);--tab-reports: #6366f1;--tab-people: #8b5cf6;--tab-hours: #f59e0b;--tab-territory: #10b981;--tab-calls: #ec4899;--tab-dashboard: #3b82f6;--tab-group: #8b5cf6;--tab-congregations: #f97316;--tab-secretaries: #14b8a6;--tab-admin-dashboard: #8b5cf6}body.dark-mode{--primary: #4a9b82;--primary-dark: #3a8a6f;--primary-light: #5aac92;--accent: #e8b896;--bg: #1a1a1a;--bg-secondary: #2a2a2a;--text: #f0f0f0;--text-secondary: #a0a0a0;--border: #404040;--shadow: rgba(0, 0, 0, .3);--success: #5aab8a;--warning: #f0b070;--danger: #d88070;--ion-background-color: #1a1a1a;--ion-background-color-rgb: 26, 26, 26;--ion-text-color: #f0f0f0;--ion-text-color-rgb: 240, 240, 240;--ion-border-color: #404040;--ion-color-primary: #4a9b82;--ion-toolbar-background: #0d0d0d;--ion-tab-bar-background: transparent;--ion-tab-bar-border-color: transparent;--primary-hover: rgba(74, 155, 130, .15);--primary-active: rgba(74, 155, 130, .25);--divider-color: rgba(255, 255, 255, .12);--overlay-color: rgba(0, 0, 0, .6)}body.dark-mode .card,body.dark-mode .form-input,body.dark-mode .form-select,body.dark-mode select{background:var(--bg-secondary);border-color:var(--border);color:var(--text)}body.dark-mode .header{background:linear-gradient(135deg,#2a4a3f,#1a3a2f)}body.dark-mode ion-toolbar{--background: #0d0d0d;--color: #ffffff;--border-color: transparent}body.dark-mode .modal-content{background:#2a2a2a}body.dark-mode .loading-overlay{background:#1a1a1ae6}body.dark-mode .loading-text{color:var(--text)}body.dark-mode ion-input,body.dark-mode ion-select,body.dark-mode ion-textarea{--background: #333;--color: #f0f0f0}body.dark-mode .btn{background:var(--primary);color:#fff}body.dark-mode .btn-secondary{background:var(--bg-secondary);color:var(--text);border:1px solid var(--border)}body.dark-mode .empty-state{background:var(--bg-secondary)}body.dark-mode ion-header{--ion-background-color: #0d0d0d;background:#0d0d0d}body.dark-mode ion-content{--background: #1a1a1a}body.dark-mode ion-chip{--background: #333}ion-button[title="Light Mode"] ion-icon,ion-button[title="Dark Mode"] ion-icon{transition:transform .3s ease}ion-button[title="Light Mode"]:hover ion-icon,ion-button[title="Dark Mode"]:hover ion-icon{transform:rotate(20deg)}ion-segment-button{--color: var(--text-secondary);--color-checked: var(--primary);--indicator-color: var(--bg-secondary)}ion-segment-button ion-label{color:var(--text-secondary)}ion-segment-button.segment-button-checked ion-label{color:var(--primary)}body.dark-mode ion-segment{--background: rgba(255, 255, 255, .1)}body.dark-mode ion-segment-button{--color: #9ca3af;--color-checked: white;--indicator-color: var(--primary)}body.dark-mode ion-segment-button ion-label{color:#9ca3af}body.dark-mode ion-segment-button.segment-button-checked ion-label{color:#fff}select.form-input,.form-select{background-position:right 10px center;background-repeat:no-repeat;padding-right:35px}body.dark-mode select.form-input,body.dark-mode .form-select{color:#f0f0f0;background-color:#2a2a2a}@supports (-webkit-backdrop-filter: blur(10px)){.tab-bar-wrapper{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{height:100%;height:100dvh}body{font-family:Poppins,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);overflow-x:hidden;position:fixed;width:100%;height:100%}.text-h1{font-size:var(--font-size-h1);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight)}.text-h2{font-size:var(--font-size-h2);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight)}.text-h3{font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);line-height:var(--line-height-normal)}.text-h4{font-size:var(--font-size-h4);font-weight:var(--font-weight-medium);line-height:var(--line-height-normal)}.text-body{font-size:var(--font-size-body);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal)}.text-small{font-size:var(--font-size-small);line-height:var(--line-height-normal)}.text-caption{font-size:var(--font-size-caption);line-height:var(--line-height-normal)}.p-xs{padding:var(--spacing-xs)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}.mb-xs{margin-bottom:var(--spacing-xs)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.mt-xs{margin-top:var(--spacing-xs)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}html,body{height:100%;background:var(--bg-secondary)}body.dark-mode html,body.dark-mode{background:#111}.app-container{display:flex;flex-direction:column;height:100vh;height:100dvh;max-width:480px;margin:0 auto;background:#fff;box-shadow:0 0 20px var(--shadow)}body.dark-mode .app-container{background:#1a1a1a}@media (min-width: 640px){.app-container,.bottom-nav,.custom-tab-bar-container{max-width:640px}}@media (min-width: 768px){.app-container,.bottom-nav,.custom-tab-bar-container{max-width:768px}:root{--spacing-sm: 10px;--spacing-md: 18px;--spacing-lg: 26px}body{font-size:17px}.btn{padding:14px 24px;font-size:1rem}.btn-small{padding:10px 18px;font-size:.95rem}.form-input{padding:14px;font-size:1rem}.card{padding:22px}}@media (min-width: 1024px){.app-container,.bottom-nav,.custom-tab-bar-container{max-width:900px}:root{--spacing-sm: 12px;--spacing-md: 20px;--spacing-lg: 30px}body{font-size:18px}.btn{padding:16px 28px;font-size:1.1rem}.btn-small{padding:12px 20px;font-size:1rem}.form-input{padding:16px;font-size:1.05rem}.card{padding:24px}.modal{max-width:600px}ion-modal{--max-width: 600px}}.app-header{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;padding:max(20px,env(safe-area-inset-top) + 10px) max(20px,env(safe-area-inset-right)) 20px max(20px,env(safe-area-inset-left));box-shadow:0 2px 10px var(--shadow);z-index:100;position:relative}.header-content{display:flex;justify-content:space-between;align-items:center}.app-title{font-size:1.5rem;font-weight:700}.logout-btn{background:#fff3;border:none;padding:8px 16px;border-radius:20px;color:#fff;cursor:pointer;font-size:.85rem}.content-area{flex:1;display:flex;flex-direction:column;overflow:hidden;transition:opacity .15s ease-in-out}.content-transitioning{opacity:0}ion-content{--background: var(--bg);--padding-top: var(--spacing-md);--padding-bottom: calc(80px + env(safe-area-inset-bottom)) ;--padding-start: max(var(--spacing-md), env(safe-area-inset-left));--padding-end: max(var(--spacing-md), env(safe-area-inset-right))}.bottom-nav{position:fixed;bottom:0;left:0;right:0;max-width:480px;margin:0 auto;background:#fff;display:flex;justify-content:space-around;padding:8px max(8px,env(safe-area-inset-right)) calc(8px + env(safe-area-inset-bottom)) max(8px,env(safe-area-inset-left));box-shadow:0 -2px 10px var(--shadow);z-index:1000}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px;cursor:pointer;color:var(--text-secondary);transition:all .2s;border:none;background:none;position:relative}.nav-item.active{color:var(--primary)}.nav-item.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:40px;height:3px;background:var(--primary);border-radius:0 0 3px 3px}.nav-icon{font-size:1.4rem}.nav-label{font-size:.65rem;font-weight:500}.nav-badge{position:absolute;top:4px;right:50%;transform:translate(10px);background:var(--danger);color:#fff;border-radius:10px;padding:2px 6px;font-size:.6rem;font-weight:600}.tab-bar-wrapper{position:fixed;bottom:0;left:0;right:0;z-index:1000;max-width:480px;margin:0 auto;background:#fffffff2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 -4px 20px #00000014;border-top:1px solid rgba(0,0,0,.05)}body.dark-mode .tab-bar-wrapper{background:#1e1e1efa;border-top:1px solid rgba(255,255,255,.15);box-shadow:0 -4px 20px #00000080}ion-tab-bar{--background: transparent;background:transparent!important;border:none!important;padding-bottom:calc(8px + env(safe-area-inset-bottom));padding-left:max(8px,env(safe-area-inset-left));padding-right:max(8px,env(safe-area-inset-right))}body.dark-mode ion-tab-bar{--background: transparent;--border-color: transparent;background:transparent!important}body.dark-mode ion-tab-button{--color: #9ca3af;--background: transparent;--background-focused: rgba(255, 255, 255, .05);--color-selected: #60a5fa;background:transparent!important}body.dark-mode ion-tab-button{--color: #9ca3af;--color-selected: #60a5fa}body.dark-mode ion-tab-button[data-tab=congregations]{--color-selected: #60a5fa}body.dark-mode ion-tab-button[data-tab=secretaries]{--color-selected: #60a5fa}body.dark-mode ion-tab-button[data-tab=admin-dashboard]{--color-selected: #60a5fa}ion-tab-button{--color: #6b7280;--color-selected: var(--primary);--ripple-color: var(--primary);--background: transparent;--background-focused: rgba(0, 0, 0, .05);flex:1;min-width:0;min-height:50px;transition:all .2s ease;padding:4px 2px}ion-tab-button.tab-selected{--color: var(--tab-color, var(--primary))}ion-tab-button.tab-selected::part(native){border-top:2px solid var(--tab-color, var(--primary))}ion-tab-button ion-icon{font-size:1.2rem;transition:transform .2s ease;margin-bottom:2px}ion-tab-button.tab-selected ion-icon{transform:scale(1.1)}ion-tab-button ion-label{font-size:.65rem;font-weight:500;white-space:nowrap;overflow:visible;text-overflow:clip;max-width:100%;margin-top:4px}ion-tab-button[data-tab=reports]{--color: #a5a8fc}ion-tab-button[data-tab=people]{--color: #c4b5fd}ion-tab-button[data-tab=hours]{--color: #fcd34d}ion-tab-button[data-tab=territory]{--color: #6ee7b7}ion-tab-button[data-tab=calls]{--color: #f9a8d4}ion-tab-button[data-tab=dashboard]{--color: #93c5fd}ion-tab-button[data-tab=group]{--color: #c4b5fd}ion-tab-button[data-tab=congregations]{--color: #fdba74}ion-tab-button[data-tab=secretaries]{--color: #5eead4}ion-tab-button[data-tab=admin-dashboard]{--color: #c4b5fd}ion-tab-button[data-tab=reports].tab-selected{--tab-color: var(--tab-reports);--color: var(--tab-reports)}ion-tab-button[data-tab=people].tab-selected{--tab-color: var(--tab-people);--color: var(--tab-people)}ion-tab-button[data-tab=hours].tab-selected{--tab-color: var(--tab-hours);--color: var(--tab-hours)}ion-tab-button[data-tab=territory].tab-selected{--tab-color: var(--tab-territory);--color: var(--tab-territory)}ion-tab-button[data-tab=calls].tab-selected{--tab-color: var(--tab-calls);--color: var(--tab-calls)}ion-tab-button[data-tab=dashboard].tab-selected{--tab-color: var(--tab-dashboard);--color: var(--tab-dashboard)}ion-tab-button[data-tab=group].tab-selected{--tab-color: var(--tab-group);--color: var(--tab-group)}ion-tab-button[data-tab=congregations].tab-selected{--tab-color: var(--tab-congregations);--color: var(--tab-congregations)}ion-tab-button[data-tab=secretaries].tab-selected{--tab-color: var(--tab-secretaries);--color: var(--tab-secretaries)}ion-tab-button[data-tab=admin-dashboard].tab-selected{--tab-color: var(--tab-admin-dashboard);--color: var(--tab-admin-dashboard)}ion-tab-button .custom-badge{position:absolute;top:4px;right:50%;transform:translate(10px);font-size:.6rem;padding:2px 6px}ion-list{background:transparent;padding:0}ion-item{--background: transparent;--border-color: var(--border);--padding-start: 0;--inner-padding-end: 0;margin-bottom:16px}ion-label[position=stacked]{margin-bottom:8px;font-size:.9rem;font-weight:500;color:var(--text)}ion-input,ion-select,ion-textarea{--background: white;--padding-start: 14px;--padding-end: 14px;--padding-top: 12px;--padding-bottom: 12px;border:2px solid var(--border);border-radius:10px;margin-top:4px}ion-input:focus-within,ion-select:focus-within,ion-textarea:focus-within{border-color:var(--primary)}ion-select::part(icon){color:var(--primary)}ion-textarea{min-height:80px}ion-modal{--border-radius: 20px;--width: 100%;--max-width: 480px;--height: auto;--max-height: 90vh}ion-modal ion-header{--background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%)}ion-modal ion-toolbar{--background: transparent;--color: white;--border-width: 0}ion-modal ion-title{font-size:1.1rem;font-weight:600}ion-modal ion-content{--background: white}ion-modal ion-button{--color: white}ion-item-sliding{margin-bottom:12px;border-radius:12px;overflow:hidden}ion-item-sliding ion-item.swipeable-item{--background: transparent;--border-color: transparent;--padding-start: 0;--inner-padding-end: 0}ion-item-sliding ion-item-option{font-size:1.5rem}ion-item-sliding ion-item-option[expandable]{transition:width .2s}ion-button{--border-radius: 12px;--padding-top: 14px;--padding-bottom: 14px;font-weight:500;font-size:1rem;margin-top:16px}ion-button[color=primary]::part(native){background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%)}ion-button[size=small]{--padding-top: 10px;--padding-bottom: 10px;font-size:.9rem}ion-button[fill=clear]{--padding-top: 8px;--padding-bottom: 8px}ion-header{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);padding-bottom:4px}ion-header ion-toolbar{--background: transparent;--color: white;--border-width: 0;--padding-top: calc(env(safe-area-inset-top) + 8px) ;--padding-bottom: 12px;--padding-start: 8px;--padding-end: 8px;--min-height: 64px}ion-header ion-title{font-size:1.15rem;font-weight:600}ion-header ion-chip{--background: rgba(255, 255, 255, .2);display:flex;align-items:center;justify-content:center}ion-header ion-button{--color: white;font-size:1rem;--padding-start: 12px;--padding-end: 12px;min-width:48px;min-height:48px}ion-header ion-button ion-icon{font-size:1.5rem}ion-header ion-badge{margin-left:4px}ion-badge{padding:4px 8px}.fab-add-btn{position:fixed;bottom:calc(70px + env(safe-area-inset-bottom));right:max(16px,env(safe-area-inset-right));width:56px;height:56px;border-radius:50%;background:var(--accent);color:#fff;border:none;box-shadow:0 4px 12px #0000004d;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.6rem;z-index:100;-webkit-tap-highlight-color:transparent}.fab-add-btn:hover{opacity:.9}.fab-add-btn:active{transform:scale(.92)}.card{background:#fff;border-radius:16px;padding:20px;margin-bottom:16px;box-shadow:0 2px 12px var(--shadow)}.stat-card{margin-bottom:var(--spacing-md);box-shadow:var(--elevation-2);padding:0!important}.stat-card ion-card-content{padding:var(--spacing-md) var(--spacing-sm)}.stat-card ion-icon{color:#fff;opacity:.9}.stat-card h1,.stat-card p{color:#fff}.metric-container{padding:var(--spacing-sm);text-align:center}.metric-value{font-size:2.5rem;font-weight:var(--font-weight-bold);color:var(--ion-color-primary);margin:var(--spacing-xs) 0}ion-title{padding-left:var(--spacing-sm)}ion-buttons[slot=start]{margin-inline-end:0!important}ion-card{padding:var(--spacing-sm)}ion-card ion-card-content{padding:var(--spacing-md)}ion-grid ion-card{margin-bottom:0}ion-col{padding:var(--spacing-xs)}ion-avatar{margin-right:var(--spacing-md)}ion-item ion-icon[slot=start]{margin-right:var(--spacing-md)}ion-button ion-icon{margin-right:var(--spacing-sm)}ion-button ion-icon[slot=icon-only]{margin-right:0}.btn{padding:14px 24px;border:none;border-radius:12px;font-size:1rem;font-weight:500;cursor:pointer;width:100%;transition:all .2s}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff}.btn-primary:active{transform:scale(.98)}.btn-secondary{background:var(--bg-secondary);color:var(--text)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-small{padding:10px 16px;font-size:.9rem}.form-group{margin-bottom:16px}.form-label{display:block;font-weight:500;margin-bottom:6px;color:var(--text);font-size:.875rem}.form-input,.form-textarea{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:8px;font-size:.95rem;font-family:inherit;background:var(--bg);color:var(--text);transition:border-color .2s,box-shadow .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none}body.dark-mode .form-input,body.dark-mode .form-textarea{background:#2a2a2a;color:#f0f0f0;border-color:#ffffff1a}body.dark-mode .form-input:focus,body.dark-mode .form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #5eead41a}.assignments-view-mode .form-select:disabled,.assignments-view-mode .form-input:disabled,.assignments-view-mode select:disabled,.assignments-view-mode input[type=text]:disabled,.assignments-view-mode input[type=number]:disabled,.assignments-view-mode textarea:disabled{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:transparent!important;border:none!important;box-shadow:none!important;padding:4px 0;color:var(--text);opacity:1;cursor:default;font-weight:500}.assignments-view-mode input[type=number]:disabled::-webkit-inner-spin-button,.assignments-view-mode input[type=number]:disabled::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.assignments-view-mode input[type=number]:disabled{-moz-appearance:textfield}.assignments-view-mode input[type=checkbox]:disabled{display:none}.form-input:-webkit-autofill,.form-input:-webkit-autofill:hover,.form-input:-webkit-autofill:focus,.form-input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px white inset!important;-webkit-text-fill-color:var(--text)!important;transition:background-color 5000s ease-in-out 0s}body.dark-mode .form-input:-webkit-autofill,body.dark-mode .form-input:-webkit-autofill:hover,body.dark-mode .form-input:-webkit-autofill:focus,body.dark-mode .form-input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px #2a2a2a inset!important;-webkit-text-fill-color:#f0f0f0!important;transition:background-color 5000s ease-in-out 0s}.form-select,select.form-input{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:8px;font-size:.95rem;font-family:inherit;background:var(--bg);color:var(--text);transition:border-color .2s,box-shadow .2s;-webkit-appearance:menulist-button;-moz-appearance:menulist-button;appearance:menulist-button;cursor:pointer;min-height:48px;text-align:left;text-align-last:left}.form-input:focus,.form-select:focus,.form-textarea:focus,select.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2c5f4f1a}.form-input[type=date],.form-input[type=time],.form-input[type=datetime-local]{min-height:44px;line-height:1.2}.form-input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.form-input[type=number]::-webkit-inner-spin-button,.form-input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;margin:0}.form-textarea{min-height:80px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-group-compact{margin-bottom:12px}.form-group-compact .form-label{font-size:.8rem;margin-bottom:4px}.form-group-compact .form-input{padding:10px 12px;font-size:.9rem}.qr-scanner-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000;z-index:3000;display:flex;flex-direction:column;align-items:center;justify-content:center}.qr-scanner-header{position:absolute;top:0;left:0;right:0;padding:16px;padding-top:calc(16px + env(safe-area-inset-top));display:flex;justify-content:space-between;align-items:center;z-index:10}.qr-scanner-header h3{color:#fff;margin:0;font-size:1.1rem}.qr-scanner-close{background:#fff3;border:none;color:#fff;width:40px;height:40px;border-radius:50%;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.qr-scanner-container{position:relative;width:280px;height:280px}.qr-scanner-video{width:100%;height:100%;object-fit:cover;border-radius:16px}.qr-scanner-guide{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.qr-scanner-guide:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border:3px solid rgba(255,255,255,.5);border-radius:16px}.qr-corner{position:absolute;width:30px;height:30px;border:4px solid var(--primary-light)}.qr-corner-tl{top:-2px;left:-2px;border-right:none;border-bottom:none;border-radius:16px 0 0}.qr-corner-tr{top:-2px;right:-2px;border-left:none;border-bottom:none;border-radius:0 16px 0 0}.qr-corner-bl{bottom:-2px;left:-2px;border-right:none;border-top:none;border-radius:0 0 0 16px}.qr-corner-br{bottom:-2px;right:-2px;border-left:none;border-top:none;border-radius:0 0 16px}.qr-scan-line{position:absolute;left:10px;right:10px;height:3px;background:linear-gradient(90deg,transparent,var(--primary-light),var(--primary),var(--primary-light),transparent);border-radius:2px;animation:scanLine 2s ease-in-out infinite}@keyframes scanLine{0%,to{top:20px;opacity:.5}50%{top:calc(100% - 23px);opacity:1}}.qr-scanner-hint{position:absolute;bottom:80px;left:0;right:0;text-align:center;color:#fffc;font-size:.9rem}.qr-scanner-footer{position:absolute;bottom:0;left:0;right:0;padding:20px;padding-bottom:calc(20px + env(safe-area-inset-bottom));text-align:center}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:2000;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg);border-radius:20px 20px 0 0;width:100%;max-width:480px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s;color:var(--text)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px max(24px,env(safe-area-inset-right)) 16px max(24px,env(safe-area-inset-left));border-bottom:2px solid var(--border);flex-shrink:0;background:var(--bg);border-radius:20px 20px 0 0;z-index:1}.modal-body{overflow-y:auto;padding:20px max(24px,env(safe-area-inset-right)) calc(24px + env(safe-area-inset-bottom)) max(24px,env(safe-area-inset-left));flex:1;min-height:0}.modal-title{font-size:1.3rem;font-weight:600;color:var(--primary)}.close-btn{background:var(--bg-secondary);border:none;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem}.list-item{background:var(--bg-secondary);border-radius:12px;padding:16px;margin-bottom:12px;cursor:pointer;transition:all .2s}.list-item:active{transform:scale(.98)}.list-item-title{font-weight:600;color:var(--primary);margin-bottom:8px}.list-item-meta{font-size:.85rem;color:var(--text-secondary)}.month-selector{display:flex;align-items:center;justify-content:space-between;background:var(--bg);padding:16px;border-radius:12px;margin-bottom:20px;box-shadow:0 2px 8px var(--shadow)}.month-nav-btn{background:var(--primary);color:#fff;border:none;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem}.month-display{flex:1;text-align:center;font-size:1.1rem;font-weight:600;color:var(--primary)}#map{width:100%;height:300px;border-radius:12px;margin-bottom:16px}.success{background:#e0ffe0;color:var(--success);padding:12px;border-radius:8px;margin-bottom:16px}.error{background:#ffe0e0;color:var(--danger);padding:12px;border-radius:8px;margin-bottom:16px}.success{background:#e0ffe0;color:var(--primary);padding:12px;border-radius:8px;margin-bottom:16px}.loading{display:flex;justify-content:center;padding:40px}.spinner{width:40px;height:40px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--spacing-xxl) var(--spacing-lg);color:var(--text-secondary);min-height:300px}.empty-icon{font-size:6rem;color:var(--ion-color-medium);opacity:.5;margin-bottom:var(--spacing-lg)}.empty-state p{margin:0;font-size:var(--font-size-body);color:var(--ion-color-medium)}.empty-state ion-button{margin-top:var(--spacing-md)}.badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:500;margin-left:8px}.badge-administrator{background:#b8d4ff;color:#1a4d8f}.tabs{display:flex;gap:8px;margin-bottom:20px;border-bottom:2px solid var(--border)}.tab{flex:1;padding:12px;border:none;background:none;cursor:pointer;font-size:1rem;font-weight:500;color:var(--text-secondary);position:relative}.tab.active{color:var(--primary)}.tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--primary)}.fab{position:absolute;bottom:calc(90px + env(safe-area-inset-bottom));right:max(20px,env(safe-area-inset-right));width:56px;height:56px;border-radius:50%;background:var(--accent);color:#fff;border:none;box-shadow:0 4px 12px #0000004d;display:flex;align-items:center;justify-content:center;font-size:1.5rem;cursor:pointer;z-index:99}.fab:active{transform:scale(.9)}.household-card{background:#fff;border-radius:12px;padding:16px;margin-bottom:12px;box-shadow:0 2px 8px var(--shadow);border-left:4px solid var(--primary)}.household-name{font-weight:600;font-size:1.1rem;color:var(--primary);margin-bottom:8px}.household-info{font-size:.9rem;color:var(--text-secondary);margin-bottom:4px}.household-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.tag{padding:4px 8px;border-radius:8px;font-size:.75rem;font-weight:500}.onf{min-width:32px}.tag-new-call{background:#e3f2fd;color:#1976d2}.tag-return-visit{background:#fff3e0;color:#f57c00}.tag-bible-study{background:#f3e5f5;color:#7b1fa2}.swipe-container{position:relative;overflow:hidden;margin-bottom:12px;border-radius:12px}.swipe-actions{position:absolute;top:0;bottom:0;display:flex;align-items:stretch}.swipe-actions-left{left:0;transform:translate(-100%)}.swipe-actions-right{right:0;transform:translate(100%)}.swipe-action{display:flex;align-items:center;justify-content:center;width:80px;color:#fff;font-size:1.5rem;cursor:pointer}.swipe-action-edit{background:var(--primary)}.swipe-action-delete{background:var(--danger)}.swipe-content{position:relative;background:#fff;transition:transform .2s ease-out;z-index:1}.household-card.swipeable{margin-bottom:0;border-radius:12px}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#ffffffd9;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:3000}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.spinner-small{width:20px;height:20px;border-width:2px}.spinner-inline{display:inline-block;vertical-align:middle;margin-right:8px}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{margin-top:12px;color:var(--text-secondary);font-size:.9rem}.login-container{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 1px,transparent 1px);background-size:50px 50px;animation:backgroundMove 20s linear infinite}@keyframes backgroundMove{0%{transform:translate(0)}to{transform:translate(50px,50px)}}body.dark-mode .login-container{background:linear-gradient(135deg,#1e3a8a,#3730a3)}.login-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:24px;padding:40px 30px;max-width:420px;width:100%;box-shadow:0 20px 60px #0000004d;position:relative;z-index:1;color:var(--text)}body.dark-mode .login-card{background:#1e1e1ef2;box-shadow:0 20px 60px #0009}.login-logo{text-align:center;font-size:4.5rem;margin-bottom:16px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}.login-title{text-align:center;font-size:1.75rem;margin-bottom:8px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700}
