:root{--primary-color: #003f87;--secondary-color: #7ab800;--background-color: #f4f7f6;--card-background: #ffffff;--text-color: #333333;--text-light: #f8f9fa;--border-color: #dee2e6;--shadow-color: rgba(0, 0, 0, .1);--danger-color: #dc3545;--danger-hover: #c82333;--font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;--success-color: #28a745}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--background-color);color:var(--text-color);line-height:1.6}#app{display:flex;flex-direction:column;min-height:100vh}header{background-color:var(--primary-color);color:var(--text-light);padding:1rem 2rem;box-shadow:0 2px 4px var(--shadow-color);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.logo-area{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.logo{font-size:1.5rem;font-weight:700;display:flex;align-items:center;gap:.5rem}.logo-icon{font-size:2rem}.unit-selector{display:flex;align-items:center;gap:.5rem}.unit-selector select{background-color:#ffffffe6;color:var(--primary-color);border:1px solid var(--border-color);border-radius:5px;padding:.5rem;font-weight:600;max-width:200px}.header-icon-btn{background:transparent;border:none;color:var(--text-light);opacity:.8;cursor:pointer;padding:6px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;transition:background-color .2s,opacity .2s}.header-icon-btn:hover{background-color:#fff3;opacity:1}.header-icon-btn svg{width:24px;height:24px}nav ul{list-style:none;display:flex;gap:1rem;flex-wrap:wrap}nav a{color:var(--text-light);text-decoration:none;font-size:1rem;padding:.5rem 1rem;border-radius:5px;transition:background-color .3s}nav a.active,nav a:hover{background-color:#fff3}#auth-container{display:flex;align-items:center;gap:1rem}.sync-status{font-size:.85rem;padding:.3rem .6rem;border-radius:4px;background-color:#ffffff26;transition:all .3s}.sync-status.local{background-color:#6c757d80}.sync-status.saving{background-color:#ffc10780;animation:pulse 1.5s infinite}.sync-status.saved{background-color:#28a745b3}.sync-status.error{background-color:#dc3545b3;cursor:help}@keyframes pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}#auth-controls .user-profile{display:flex;align-items:center;gap:.75rem}#auth-controls .profile-pic{width:40px;height:40px;border-radius:50%;border:2px solid var(--text-light)}main{flex:1;padding:2rem;max-width:1200px;width:100%;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.page-header h1{color:var(--primary-color);margin:0}.page-subtitle{font-size:1.1rem;font-weight:400;color:#6c757d;margin:.25rem 0 0}.header-actions{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.btn{padding:.75rem 1.5rem;border:none;border-radius:5px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;text-align:center}.btn-primary{background-color:var(--secondary-color);color:var(--text-light)}.btn-primary:hover{background-color:#6a9a00;transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow-color)}.btn-secondary{background-color:#6c757d;color:var(--text-light)}.btn-secondary:hover{background-color:#5a6268}.btn-danger{background-color:var(--danger-color);color:var(--text-light)}.btn-danger:hover{background-color:var(--danger-hover)}.btn-danger-outline{background-color:transparent;border:1px solid var(--danger-color);color:var(--danger-color)}.btn-danger-outline:hover{background-color:var(--danger-color);color:var(--text-light)}.btn-success{background-color:var(--success-color);color:var(--text-light)}.btn-success:hover{background-color:#218838}.btn-icon{padding:0;width:38px;height:38px;border-radius:50%;flex-shrink:0}.btn-icon svg{width:20px;height:20px}.btn svg{width:22px;height:22px;fill:currentColor}.card{background-color:var(--card-background);border-radius:8px;box-shadow:0 2px 5px var(--shadow-color);padding:1.5rem;margin-bottom:1.5rem;transition:box-shadow .3s;display:flex;flex-direction:column}.card:hover{box-shadow:0 4px 12px var(--shadow-color)}.card h3{color:var(--primary-color);margin-bottom:.5rem}.card p{margin-bottom:1rem;color:#6c757d}.card .recurrence-info{font-style:italic;font-size:.9em;color:#6c757d;margin-top:-.5rem;margin-bottom:1rem}.card-actions{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;margin-top:auto;gap:.5rem;padding-top:1rem;border-top:1px solid var(--border-color)}.card-actions-left,.card-actions-right{display:flex;gap:.5rem;align-items:center}.card-title-container{display:flex;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.5rem}.card-title-container h3{margin-bottom:0}.attendance-indicator-icon{color:var(--secondary-color);flex-shrink:0}.attendance-indicator-icon svg{width:24px;height:24px;display:block}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.month-navigator{flex-direction:row;display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;flex-wrap:wrap;gap:1rem}.month-navigator h2{color:var(--primary-color);margin:0}.month-nav-controls{display:flex;gap:.5rem}.month-nav-controls .btn{padding:.5rem 1rem;background-color:#e9ecef;color:var(--primary-color);border:1px solid var(--border-color)}.month-nav-controls .btn:hover{background-color:#d8dde1}.month-nav-controls .btn-secondary{background-color:var(--primary-color);color:var(--text-light);border-color:var(--primary-color)}.month-nav-controls .btn-secondary:hover{background-color:#002c5c}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;opacity:0;transition:opacity .3s}.modal-overlay.visible{opacity:1}.modal-content{background-color:var(--card-background);padding:2rem;border-radius:8px;width:90%;max-width:600px;box-shadow:0 5px 15px var(--shadow-color);transform:translateY(-50px);transition:transform .3s}.modal-overlay.visible .modal-content{transform:translateY(0)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;border-bottom:1px solid var(--border-color);padding-bottom:1rem}.modal-header h2{color:var(--primary-color)}.modal-body{padding-top:.5rem}.modal-body p{margin:0;line-height:1.5}.modal-body h3{color:var(--primary-color)}.modal-section{padding:1.5rem 0;border-bottom:1px solid var(--border-color)}.modal-section:first-child{padding-top:0}.modal-section:last-child{padding-bottom:0;border-bottom:none}.close-button{background:none;border:none;font-size:2rem;cursor:pointer;color:#6c757d;width:32px;height:32px;line-height:1}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:5px;font-size:1rem;background-color:#fff}.form-group textarea{font-family:Courier New,Courier,monospace;resize:vertical;min-height:150px}.form-hint{font-size:.9em;color:#6c757d;margin-bottom:.5rem;background-color:#f8f9fa;padding:.75rem;border-radius:4px;border:1px solid var(--border-color);line-height:1.4}.form-hint code{background-color:#e9ecef;padding:.1em .4em;border-radius:3px;font-family:inherit}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.import-instructions{font-size:.9rem;color:#6c757d;background-color:#f8f9fa;border-radius:4px;padding:.75rem;margin-bottom:1rem!important;border:1px solid var(--border-color)}.import-scout-modal .form-group textarea{min-height:200px;font-family:Courier New,Courier,monospace}.unit-manager-list{list-style:none;padding:0;margin-bottom:1rem}.unit-manager-list li{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border-radius:4px;transition:background-color .2s;gap:1rem}.unit-manager-list li:hover{background-color:#f8f9fa}.unit-manager-list .unit-name{font-weight:600;flex-grow:1}.unit-manager-list .unit-actions{display:flex;gap:.5rem;flex-shrink:0}.empty-list-message{text-align:center;color:#6c757d;padding:1rem 0}.unit-add-form .form-group{margin-bottom:.5rem}.unit-add-form .modal-actions{margin-top:.5rem}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse;margin-top:1rem}th,td{padding:1rem;text-align:left;border-bottom:1px solid var(--border-color);vertical-align:middle}th{background-color:#e9ecef;font-weight:600;color:var(--primary-color)}tr:hover{background-color:#f8f9fa}.table-actions{display:flex;gap:.5rem;justify-content:flex-end}.table-actions-header{text-align:right}.attendance-list .scout-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--border-color)}.attendance-list .scout-item:last-child{border-bottom:none}.attendance-list label{display:flex;align-items:center;gap:1rem;font-size:1.1rem;cursor:pointer;flex-grow:1}.attendance-list input[type=checkbox]{width:1.5rem;height:1.5rem;cursor:pointer;flex-shrink:0}#report-output{background-color:#e9ecef;border-radius:8px;padding:1.5rem;margin-top:2rem;min-height:200px;white-space:pre-wrap;line-height:1.7;font-family:Courier New,Courier,monospace}#report-output.loading{position:relative;color:transparent}#report-output.loading:after{content:"Generating report...";position:absolute;top:0;left:0;right:0;bottom:0;display:flex;justify-content:center;align-items:center;color:var(--primary-color);font-family:var(--font-family)}.empty-state{text-align:center;padding:3rem;border:2px dashed var(--border-color);border-radius:8px;background-color:#f8f9fa}.empty-state h2{color:var(--primary-color);margin-bottom:.5rem}.login-container{display:flex;justify-content:center;align-items:center;width:100%;flex-grow:1}.login-box{background-color:var(--card-background);padding:2rem 3rem 3rem;border-radius:8px;box-shadow:0 4px 15px var(--shadow-color);text-align:center;max-width:450px;width:90%}.login-box .logo{justify-content:center;margin-bottom:1rem}.login-box .logo h1{font-size:2rem;color:var(--primary-color);font-weight:700}.login-box p{margin-bottom:2rem;color:#6c757d;font-size:1.1rem}#google-sign-in-btn{background-color:#fff;color:#444;border:1px solid #ddd;box-shadow:0 2px 4px #0000001a;font-weight:500;padding:.75rem 1.5rem}#google-sign-in-btn:hover{background-color:#f8f8f8;border-color:#ccc;box-shadow:0 3px 6px #00000026;transform:none}#google-sign-in-btn svg{width:20px;height:20px;margin-right:.5rem}#google-sign-in-btn span{vertical-align:middle}.error-message{color:var(--danger-color);background-color:#f8d7da;border:1px solid #f5c6cb;padding:1rem;border-radius:5px;margin-top:1.5rem;text-align:left}.error-message h2{font-size:1.2rem;color:var(--danger-hover);margin-bottom:.75rem;text-align:center}.error-message p{color:var(--danger-hover);text-align:center}.error-message ul{list-style-position:inside;padding:.5rem 0 1rem;margin:0 auto;display:table}.error-message ul li{font-family:Courier New,Courier,monospace;font-weight:600;color:var(--danger-hover);margin-bottom:.25rem}@media (max-width: 850px){header{flex-direction:column;align-items:stretch;gap:1rem}.logo-area{justify-content:center}nav ul{gap:.5rem;width:100%;justify-content:center}nav a{flex-grow:1;text-align:center}#auth-container{justify-content:center}}@media (max-width: 768px){main{padding:1rem}.page-header{flex-direction:column;align-items:center;text-align:center;gap:.5rem}.page-header>div{width:100%}.page-header .header-actions{justify-content:center}.table-container table{border:0}.table-container thead{border:none;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.table-container tr{border:1px solid var(--border-color);border-radius:8px;display:block;margin-bottom:1rem;background:var(--card-background);box-shadow:0 2px 5px var(--shadow-color)}.table-container td{border:none;border-bottom:1px solid #eee;display:block;font-size:.8em;text-align:right}.table-container td:before{content:attr(data-label);float:left;font-weight:700;text-transform:uppercase}.table-container td:last-child{border-bottom:0}.table-container .table-actions{justify-content:flex-end}}
