*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: #5eb85c;--color-primary-hover: #69d24c;--color-primary-dark: #4a9c48;--color-primary-darkest: #3d8b3a;--color-primary-rgb: 94, 184, 92;--color-accent: #0d9488;--color-accent-light: #14b8a6;--color-guest-hover: #4a9c48;--gradient-body: #f5f9f5;--gradient-header: #5eb85c;--color-text: #333;--color-text-heading: #1f2937;--color-text-muted: #374151;--color-text-muted-light: #64748b;--color-text-muted-lighter: #6b7280;--color-placeholder: #9ca3af;--color-border: #e2e8f0;--color-border-focus: #86efac;--color-bg-subtle: #f8fafc;--color-bg-subtle-hover: #f1f5f9;--color-overlay-10: rgba(255, 255, 255, .1);--color-overlay-15: rgba(255, 255, 255, .15);--color-overlay-20: rgba(255, 255, 255, .2);--color-overlay-25: rgba(255, 255, 255, .25);--color-overlay-30: rgba(255, 255, 255, .3);--color-overlay-50: rgba(255, 255, 255, .5);--color-overlay-60: rgba(255, 255, 255, .6);--shadow-hover: 0 4px 12px rgba(0, 0, 0, .15);--shadow-card: 0 20px 40px rgba(0, 0, 0, .1);--shadow-modal: 0 20px 40px rgba(0, 0, 0, .2);--shadow-focus: 0 0 0 3px rgba(var(--color-primary-rgb), .1);--shadow-focus-subtle: 0 4px 12px rgba(var(--color-primary-rgb), .05);--shadow-focus-sm: 0 2px 8px rgba(var(--color-primary-rgb), .1);--color-neutral-100: #f8f9fa;--color-neutral-200: #f5f5f5;--color-neutral-300: #f0f0f0;--color-neutral-400: #e9ecef;--color-neutral-500: #dee2e6;--color-neutral-600: #ddd;--color-neutral-700: #d1d5db;--color-neutral-800: #ccc;--color-neutral-900: #adb5bd;--color-neutral-muted: #999;--color-table-stripe: #f9f9f9;--color-blue: #3b82f6;--color-blue-hover: #2563eb;--color-red: #ef4444;--color-red-hover: #dc2626;--color-green: #5eb85c;--color-green-hover: #4a9c48;--color-green-bg: #f0fdf4;--color-green-rgb: 16, 185, 129;--color-orange: #f59e0b;--color-orange-hover: #d97706;--color-cyan: #06b6d4;--color-cyan-hover: #0891b2;--color-link: #0284c7;--color-link-hover: #0369a1;--color-disabled-bg: #9ca3af;--color-disabled-text: #6b7280;--color-disabled-border: #d1d5db;--color-surface-dark: #1f2937;--color-google-bg: #374151;--color-google-hover: #6b6d6e;--color-secondary-hover: #4b5563;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-input: 6px;--transition-fast: .2s ease}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;color:var(--color-text);background:var(--gradient-body);min-height:100vh;padding:20px}.btn{padding:12px 24px;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:8px}.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-hover)}.container{max-width:1200px;margin:0 auto;background:#fff;border-radius:var(--radius-xl);box-shadow:0 4px 24px #00000014;overflow:hidden}.header{background:var(--gradient-header);color:#fff}.header-nav{display:flex;justify-content:space-between;align-items:center;padding:15px 40px;border-bottom:1px solid rgba(255,255,255,.2)}.header-content{padding:40px;text-align:center;position:relative;z-index:1}.header-text{text-align:center}.header h1{font-family:Nunito,Inter,sans-serif;font-size:2.5rem;font-weight:800;margin-bottom:10px;letter-spacing:-.02em;text-shadow:0 2px 4px rgba(0,0,0,.15)}.hero-title-letter{display:inline}.subtitle{font-size:1.1rem;opacity:.95;font-weight:400;text-shadow:0 1px 2px rgba(0,0,0,.1)}.textbook-promo{margin-bottom:30px;padding:20px;background:#00000040;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.25);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.textbook-content{display:flex;align-items:center;gap:20px;max-width:800px;margin:0 auto}.textbook-icon{flex-shrink:0;width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#ffffff26}.textbook-icon-img{width:100%;height:100%;object-fit:cover;object-position:center}.textbook-text{flex:1;color:#fff}.textbook-text h3{font-size:1.2rem;font-weight:600;margin-bottom:5px;color:#fff}.textbook-text p{font-size:.95rem;opacity:.9;margin:0;line-height:1.4}.textbook-text strong{font-weight:600}.textbook-link{flex-shrink:0;display:flex;align-items:center;gap:8px;padding:12px 20px;background:#ffffff40;color:#fff;text-decoration:none;border-radius:var(--radius-md);font-weight:500;font-size:.9rem;transition:all var(--transition-fast);border:1px solid rgba(255,255,255,.35)}.textbook-link:hover{background:#ffffff59;transform:translateY(-1px);box-shadow:var(--shadow-hover);color:#fff;text-decoration:none}.textbook-link svg{transition:transform .2s ease}.textbook-link:hover svg{transform:translate(2px)}.auth-section{display:flex;align-items:center;gap:15px}.nav-links{display:flex;align-items:center;gap:20px}.nav-link{color:#fff;text-decoration:none;font-weight:500;padding:8px 16px;border-radius:var(--radius-input);transition:all var(--transition-fast);opacity:.9;font-size:.95rem}.nav-link:hover{background:var(--color-overlay-10);opacity:1;transform:translateY(-1px)}.nav-link-external{background:var(--color-overlay-15);border:1px solid var(--color-overlay-20);font-weight:600;position:relative;overflow:hidden}.nav-link-external:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,var(--color-overlay-20),transparent);transition:left .5s}.nav-link-external:hover:before{left:100%}.nav-link-external:hover{background:var(--color-overlay-25);border-color:var(--color-overlay-30);transform:translateY(-2px);box-shadow:var(--shadow-hover)}.nav-link-external svg{margin-right:6px;transition:transform .2s ease}.nav-link-external:hover svg{transform:rotate(45deg)}.user-info{display:flex;align-items:center;gap:15px}.user-name{font-weight:500;font-size:1rem;opacity:.9}.btn-google{background:var(--color-google-bg);color:#fff;border:2px solid var(--color-overlay-20);display:flex;align-items:center;gap:10px;font-weight:500;transition:all var(--transition-fast);width:100%;justify-content:center}.btn-google:hover{background:var(--color-google-hover);border-color:var(--color-overlay-30);transform:translateY(-1px);box-shadow:var(--shadow-hover)}.login-options{display:flex;flex-direction:column;gap:20px;max-width:500px;margin:0 auto;position:absolute;z-index:1000;top:2rem;left:0;right:0;padding:8px}.login-option{text-align:center}.login-description{margin:8px 0 0;font-size:.9rem;color:var(--color-primary);line-height:1.4;font-weight:700}.login-divider{position:relative;text-align:center;margin:10px 0}.login-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#000}.login-divider span{background:var(--color-surface-dark);padding:0 15px;color:var(--color-overlay-60);font-size:.9rem}.btn-guest{background:var(--color-primary);color:#fff;border:2px solid var(--color-overlay-20);display:flex;align-items:center;justify-content:center;gap:10px;font-weight:600;transition:all var(--transition-fast);width:100%}.btn-guest:hover{background:var(--color-guest-hover);border-color:var(--color-overlay-30);transform:translateY(-1px);box-shadow:var(--shadow-hover)}.btn-outline{background:transparent;color:#fff;border:2px solid var(--color-overlay-30);transition:all var(--transition-fast)}.btn-outline:hover{background:var(--color-overlay-10);border-color:var(--color-overlay-50)}.google-icon{flex-shrink:0}.form{padding:40px;transition:filter .3s ease}.form.blurred{filter:blur(10px) grayscale(100%);pointer-events:none;-webkit-user-select:none;user-select:none}.family-header{background:var(--color-bg-subtle);border-radius:var(--radius-lg);padding:30px;margin-bottom:30px;border:2px solid var(--color-border);text-align:center}.family-header small{opacity:.3}.family-header h2{font-size:1.5rem;color:var(--color-primary);margin-bottom:20px;text-align:center}.family-names{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:20px;flex-wrap:wrap}.name-input{flex:1;min-width:200px;padding:12px 16px;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:1.1rem;transition:all var(--transition-fast)}.name-input:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.and-text{font-weight:500;color:var(--color-text-muted-light);font-size:1.1rem}.record-date{display:flex;align-items:center;justify-content:center;gap:10px}.record-date label{font-weight:500;color:var(--color-text-muted)}.date-input{padding:8px 12px;border:2px solid var(--color-border);border-radius:var(--radius-input);font-size:1rem;transition:all var(--transition-fast)}.date-input:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.person-section,.children-section,.preparer-section,.comments-section{background:#fff;border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:30px;margin-bottom:30px;transition:all var(--transition-fast)}.person-section:hover,.children-section:hover,.preparer-section:hover,.comments-section:hover{border-color:var(--color-border-focus);box-shadow:var(--shadow-focus-subtle)}.section-title{font-size:1.4rem;font-weight:600;color:var(--color-text-heading);margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid var(--color-border)}.person-info{display:grid;grid-template-columns:1fr 2fr;gap:30px}.basic-info{display:flex;flex-direction:column;gap:20px}.full-name-input{padding:12px 16px;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:1.1rem;font-weight:500;transition:all var(--transition-fast)}.full-name-input:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.parents-info{display:flex;flex-direction:column;gap:10px}.parent-input{padding:10px 14px;border:2px solid var(--color-border);border-radius:var(--radius-input);font-size:1rem;transition:all var(--transition-fast)}.parent-input:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.events-section h4{font-size:1.1rem;font-weight:600;color:var(--color-text-muted);margin-bottom:15px}.events-list{display:flex;flex-direction:column;gap:12px;margin-bottom:15px}.event-item{background:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:20px;display:flex;flex-direction:column;gap:12px;transition:all var(--transition-fast);position:relative;width:100%;max-width:100%;box-sizing:border-box}.event-item:hover{background:var(--color-bg-subtle-hover);border-color:var(--color-border-focus);box-shadow:var(--shadow-focus-sm)}.event-header{display:flex;justify-content:space-between;align-items:flex-start;gap:15px}.event-type{font-weight:600;color:var(--color-primary);text-transform:capitalize;font-size:1.1rem;flex-shrink:0}.event-actions{display:flex;gap:8px;flex-shrink:0}.event-content{display:flex;flex-direction:column;gap:8px;flex:1}.event-date{font-weight:600;color:var(--color-text-heading);font-size:1rem}.event-description{color:var(--color-text-muted);font-size:.95rem;line-height:1.4}.event-place{color:var(--color-text-muted-light);font-size:.9rem;font-style:italic}.event-sources{color:var(--color-text-muted-lighter);font-size:.85rem;line-height:1.4;word-wrap:break-word;word-break:break-word;overflow-wrap:break-word;max-width:100%}.event-sources a{color:var(--color-primary);text-decoration:none;word-wrap:break-word;word-break:break-all;overflow-wrap:break-word}.event-sources a:hover{text-decoration:underline}.event-sources.expanded{max-height:none}.event-sources.collapsed{max-height:2.5em;overflow:hidden;position:relative}.event-sources.collapsed:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1.2em;background:linear-gradient(transparent,var(--color-bg-subtle));pointer-events:none}.sources-toggle{background:none;border:none;color:var(--color-primary);font-size:.8rem;cursor:pointer;padding:4px 0;margin-top:4px;text-decoration:underline;transition:color .2s ease}.sources-toggle:hover{color:var(--color-primary-dark)}.rich-text-container{border:1px solid var(--color-neutral-600);border-radius:var(--radius-sm);background:#fff}.rich-text-toolbar{display:flex;align-items:center;gap:4px;padding:8px;background:var(--color-neutral-100);border-bottom:1px solid var(--color-neutral-600);border-radius:var(--radius-sm) var(--radius-sm) 0 0}.toolbar-btn{padding:4px 8px;border:1px solid var(--color-neutral-800);background:#fff;border-radius:3px;cursor:pointer;font-size:12px;font-weight:700;min-width:24px;height:24px;display:flex;align-items:center;justify-content:center}.toolbar-btn:hover{background:var(--color-neutral-400);border-color:var(--color-neutral-900)}.toolbar-btn:active{background:var(--color-neutral-500)}.toolbar-separator{width:1px;height:16px;background:var(--color-neutral-800);margin:0 4px}.rich-text-editor{min-height:100px;max-height:200px;overflow-y:auto;padding:12px;font-family:inherit;font-size:14px;line-height:1.5;border:none;outline:none;background:#fff;border-radius:0 0 var(--radius-sm) var(--radius-sm)}.rich-text-editor:empty:before{content:attr(data-placeholder);color:var(--color-neutral-muted);font-style:italic}.rich-text-editor:focus{outline:none}.rich-text-editor a{color:var(--color-link);text-decoration:underline}.rich-text-editor a:hover{color:var(--color-link-hover)}.rich-text-editor strong,.rich-text-editor b{font-weight:700}.rich-text-editor em,.rich-text-editor i{font-style:italic}.rich-text-editor u{text-decoration:underline}.sources-container{position:relative;width:100%;max-width:100%;overflow:hidden}.source-link{color:var(--color-primary);text-decoration:none;font-weight:500;border-bottom:1px solid transparent;transition:all var(--transition-fast);display:inline-block;margin:0 2px}.source-link:hover{color:var(--color-primary-dark);border-bottom-color:var(--color-primary);text-decoration:none}.source-link:visited{color:var(--color-accent)}.source-link:active{color:var(--color-primary-darkest)}.event-actions{display:flex;gap:8px}.btn-small{padding:4px 8px;border:none;border-radius:var(--radius-sm);font-size:.8rem;cursor:pointer;transition:all var(--transition-fast)}.btn-edit{background:var(--color-blue);color:#fff}.btn-edit:hover{background:var(--color-blue-hover)}.btn-delete{background:var(--color-red);color:#fff}.btn-delete:hover{background:var(--color-red-hover)}.child-delete-btn{position:absolute;top:8px;right:8px;z-index:10}.add-event-btn{background:var(--color-green);color:#fff;border:none;padding:10px 20px;border-radius:var(--radius-input);font-weight:500;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:8px;margin-bottom:8px}.add-event-btn:hover{background:var(--color-green-hover);transform:translateY(-1px)}.children-list{display:flex;flex-direction:column;gap:20px;margin-bottom:20px}.child-item{background:var(--color-bg-subtle);border:2px solid var(--color-border);border-radius:var(--radius-md);padding:20px;transition:all var(--transition-fast);display:flex;gap:30px;align-items:flex-start;position:relative;margin:10px 0}.child-item:hover{border-color:var(--color-border-focus);background:var(--color-bg-subtle-hover)}.child-info-section{display:flex;flex-direction:column;gap:20px;flex:1}.events-section{flex:1;width:100%}.child-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.child-name-input{flex:1;padding:10px 14px;border:2px solid var(--color-border);border-radius:var(--radius-input);font-size:1.1rem;font-weight:500;margin-right:15px;transition:all var(--transition-fast)}.child-name-input:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.child-actions{display:flex;gap:8px}.spouses-section{margin-top:15px}.spouses-section h5{font-size:1rem;font-weight:600;color:var(--color-text-muted);margin-bottom:10px}.spouse-item{display:flex;gap:10px;margin-bottom:10px;align-items:center}.spouse-input{flex:1;padding:8px 12px;border:2px solid var(--color-border);border-radius:var(--radius-input);font-size:.95rem;transition:all var(--transition-fast);margin:2px 0}.spouse-input:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.add-spouse-btn{background:var(--color-accent-light);color:#fff;border:none;padding:8px 12px;border-radius:var(--radius-input);font-size:.9rem;cursor:pointer;transition:all var(--transition-fast)}.add-spouse-btn:hover{background:var(--color-accent)}.add-child-btn{background:var(--color-orange);color:#fff;border:none;padding:12px 24px;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:8px;margin:8px auto}.add-child-btn:hover{background:var(--color-orange-hover);transform:translateY(-1px)}.preparer-info{display:flex;flex-direction:column;gap:15px}.preparer-input{padding:12px 16px;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;transition:all var(--transition-fast)}.preparer-input:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.comments-textarea{width:100%;min-height:120px;padding:12px 16px;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;font-family:inherit;resize:vertical;transition:all var(--transition-fast)}.comments-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus)}textarea{width:100%;min-height:120px;padding:12px 16px;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;font-family:inherit;resize:vertical;transition:all var(--transition-fast);background-color:#fff;color:var(--color-text)}textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus)}textarea::placeholder{color:var(--color-disabled-bg)}.action-buttons{display:flex;gap:15px;justify-content:center;margin-top:40px;flex-wrap:wrap}.btn-primary{background:var(--color-primary);color:#fff;font-weight:600}.btn-primary:hover{background:var(--color-primary-hover)}.btn-secondary{background:var(--color-text-muted-lighter);color:#fff}.btn-secondary:hover{background:var(--color-secondary-hover)}.btn-success{background:var(--color-green);color:#fff}.btn-success:hover{background:var(--color-green-hover)}.btn-info{background:var(--color-cyan);color:#fff}.btn-info:hover{background:var(--color-cyan-hover)}.exported-table{width:100%;max-width:100%;border-collapse:collapse;margin:0;padding:0;font-family:Arial,sans-serif;font-size:14px;table-layout:fixed}.exported-table th,.exported-table td{border:1px solid var(--color-neutral-600);padding:2px;text-align:left;vertical-align:top;word-wrap:break-word;overflow-wrap:break-word}.exported-table th{background-color:var(--color-neutral-200);font-weight:700;text-align:center}.exported-table tbody tr:nth-child(2n){background-color:var(--color-table-stripe)}.exported-table tbody tr:hover{background-color:var(--color-neutral-300)}.exported-table th:nth-child(1){width:25%}.exported-table th:nth-child(2){width:15%}.exported-table th:nth-child(3){width:30%}.exported-table th:nth-child(4){width:30%}.modal{position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background-color:#fff;margin:2% auto;padding:0;border-radius:var(--radius-lg);width:90%;max-width:500px;max-height:90vh;box-shadow:var(--shadow-modal);animation:modalSlideIn .3s ease;display:flex;flex-direction:column}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}.modal-header{background:var(--gradient-header);color:#fff;padding:20px 30px;border-radius:12px 12px 0 0;display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0;font-size:1.3rem;font-weight:600}.close{color:#fff;font-size:28px;font-weight:700;cursor:pointer;transition:all var(--transition-fast)}.close:hover{opacity:.7;transform:scale(1.1)}.modal-body{padding:30px;overflow-y:auto;flex:1;min-height:0}.modal-footer{padding:20px 30px;background:var(--color-bg-subtle);border-radius:0 0 12px 12px;display:flex;gap:15px;justify-content:flex-end;flex-shrink:0}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--color-text-muted)}.form-input{width:100%;padding:10px 14px;border:2px solid var(--color-border);border-radius:var(--radius-input);font-size:1rem;transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.custom-event-type-input{transition:all .3s ease;border-color:var(--color-green);background-color:var(--color-green-bg)}.custom-event-type-input:focus{border-color:var(--color-green-hover);box-shadow:0 0 0 3px rgba(var(--color-green-rgb),.1);background-color:#fff}.custom-event-type-input::placeholder{color:var(--color-text-muted-lighter);font-style:italic}.form-help{display:block;margin-top:6px;font-size:.875rem;color:var(--color-text-muted-lighter);font-style:italic}button:disabled,.btn:disabled,.btn-small:disabled,.btn-google:disabled,.btn-outline:disabled,.add-event-btn:disabled,.add-child-btn:disabled,.add-spouse-btn:disabled,.btn-primary:disabled,.btn-secondary:disabled,.btn-success:disabled,.btn-edit:disabled,.btn-delete:disabled{background:var(--color-disabled-bg)!important;color:var(--color-text-muted-lighter)!important;border-color:var(--color-disabled-border)!important;cursor:not-allowed!important;opacity:.6;transform:none!important;box-shadow:none!important}button:disabled:hover,.btn:disabled:hover,.btn-small:disabled:hover,.btn-google:disabled:hover,.btn-outline:disabled:hover,.add-event-btn:disabled:hover,.add-child-btn:disabled:hover,.add-spouse-btn:disabled:hover,.btn-primary:disabled:hover,.btn-secondary:disabled:hover,.btn-success:disabled:hover,.btn-edit:disabled:hover,.btn-delete:disabled:hover{background:var(--color-disabled-bg)!important;color:var(--color-text-muted-lighter)!important;border-color:var(--color-disabled-border)!important;transform:none!important;box-shadow:none!important}.fgr-item{background:var(--color-bg-subtle);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:24px;margin-bottom:16px;transition:all var(--transition-fast);cursor:pointer;position:relative}.fgr-item:hover{background:var(--color-bg-subtle-hover);border-color:var(--color-border-focus);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.1);transform:translateY(-1px)}.fgr-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;gap:16px}.fgr-item-title{font-size:1.3rem;font-weight:600;color:var(--color-primary);margin:0;flex:1;line-height:1.3}.fgr-item-actions{display:flex;gap:8px;flex-shrink:0}.fgr-item-meta{display:flex;flex-direction:column;gap:8px;color:var(--color-text-muted-light);font-size:.95rem}.fgr-record-date{display:flex;align-items:center;gap:8px;font-weight:500}.fgr-record-date i{color:var(--color-primary);font-size:.9rem}.fgr-item-actions .btn{padding:8px 12px;font-size:.85rem;border-radius:var(--radius-input);display:flex;align-items:center;gap:6px;min-width:auto}.fgr-item-actions .btn-edit{background:var(--color-blue);color:#fff;border:none}.fgr-item-actions .btn-edit:hover{background:var(--color-blue-hover);transform:translateY(-1px);box-shadow:0 2px 8px #3b82f64d}.fgr-item-actions .btn-delete{background:var(--color-red);color:#fff;border:none}.fgr-item-actions .btn-delete:hover{background:var(--color-red-hover);transform:translateY(-1px);box-shadow:0 2px 8px #ef44444d}.fgr-item-actions .btn i{font-size:.8rem}.fgr-manager-modal .modal-content{max-width:800px;width:95%}.fgr-manager-modal .modal-body{max-height:60vh;overflow-y:auto}.fgr-manager-modal .fgr-item{margin-bottom:12px}.fgr-manager-modal .fgr-item:last-child{margin-bottom:0}@media (max-width: 768px){.container{margin:10px;border-radius:var(--radius-lg)}.header{padding:30px 20px}.header-content{flex-direction:column;gap:20px;text-align:center}.header-text{text-align:center}.header h1{font-size:2rem}.textbook-promo{margin:20px 0;padding:15px}.textbook-content{flex-direction:column;text-align:center;gap:15px}.textbook-icon{width:40px;height:40px;font-size:1.2rem}.textbook-text h3{font-size:1.1rem}.textbook-text p{font-size:.9rem}.textbook-link{padding:10px 16px;font-size:.85rem}.auth-section{justify-content:center}.form{padding:20px}.person-info{grid-template-columns:1fr;gap:20px}.family-names{flex-direction:column;gap:15px}.name-input{min-width:100%}.event-item{padding:15px}.event-header{flex-direction:column;align-items:flex-start;gap:5px}.event-actions{align-self:flex-end}.child-item{flex-direction:column;gap:20px}.action-buttons{flex-direction:column;align-items:center}.btn{width:100%;justify-content:center}.modal-content{width:95%;margin:5% auto;max-height:85vh}.modal-body{padding:20px}.modal-footer{padding:15px 20px;flex-direction:column}.fgr-item-header{flex-direction:column;align-items:flex-start;gap:12px}.fgr-item-actions{align-self:flex-end;width:100%;justify-content:flex-end}.fgr-item-actions .btn{flex:1;justify-content:center;max-width:120px}}@media (max-width: 480px){body{padding:10px}.header h1{font-size:1.8rem}.subtitle{font-size:1rem}.person-section,.children-section,.preparer-section,.comments-section{padding:20px}.section-title{font-size:1.2rem}.modal-content{width:98%;margin:2% auto;max-height:90vh}.modal-body{padding:15px}.modal-footer{padding:12px 15px}}.parent-info{padding:0 1rem}.pdf .family-header-for-pdf{text-align:center;font-size:2rem;font-weight:600;color:var(--color-primary);margin-bottom:20px}.pdf .subtitle{text-align:center;font-size:1.2rem;font-weight:600;color:var(--color-text-muted)}.pdf ul,.pdf ol{padding-left:1rem}#form-container{position:relative}#recordId{display:none}@media print{body *:not(#to-print,#to-print *){display:none}#to-print,#to-print *{visibility:visible}#to-print{display:block!important;position:absolute;left:0;top:0;width:auto;height:99%}.page-break-here{page-break-after:always}.source-description-container{overflow-wrap:break-word}.source-content *{display:inline;font-weight:400;font-size:1rem;text-decoration:none;font-style:normal;overflow-wrap:break-word}a{text-decoration:none;color:var(--color-primary);overflow-wrap:break-word;word-wrap:break-word;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}a:hover{color:var(--color-cyan)}}progress{accent-color:var(--color-primary);width:100%;height:20px;border-radius:var(--radius-sm);overflow:hidden}progress::-webkit-progress-bar{background-color:var(--color-border);border-radius:var(--radius-sm)}progress::-webkit-progress-value{background-color:var(--color-primary);border-radius:var(--radius-sm)}progress::-moz-progress-bar{background-color:var(--color-primary);border-radius:var(--radius-sm)}
