@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-size-h1: 48px;--font-size-h2: 28px;--font-size-h3: 20px;--font-size-body: 15px;--font-size-small: 13px;--font-size-button: 14px;--font-size-modal-title: 24px;--line-height-heading: 1.15;--line-height-body: 1.6;--line-height-tight: 1.3;--letter-spacing-tight: -.02em;--letter-spacing-normal: 0;--letter-spacing-wide: .01em;--color-background: #FAFBFA;--color-background-elevated: #FFFFFF;--color-background-subtle: #F7F6F4;--color-background-muted: #F0EFED;--color-background-warm: #FBF9F6;--color-background-cool: #F5F7F9;--color-background-primary: #E9F5EC;--color-background-primary-gradient: linear-gradient(135deg, #E9F5EC 0%, #d4eeda 100%);--color-background-cream: #FFFDF8;--color-background-ivory: #FEFEFE;--color-text-primary: #1A1A1A;--color-text-secondary: #4A4A4A;--color-text-tertiary: #757575;--color-text-inverse: #FFFFFF;--color-primary: #45B35B;--color-primary-hover: #3DA150;--color-primary-active: #2F7A3C;--color-primary-light: rgba(69, 179, 91, .08);--color-primary-rgb: 69, 179, 91;--color-primary-text: #2F7A3C;--color-brand-emerald: #45B35B;--color-brand-fresh: #51B764;--color-brand-dark: #2F7A3C;--color-brand-mint: #E9F5EC;--color-brand-offwhite: #FAFBFA;--color-brand-grey: #6B7280;--color-border: #E8E6E3;--color-border-strong: #D6D4D1;--color-border-subtle: #F2F0ED;--color-success: #45B35B;--color-error: #C53030;--color-warning: #B7791F;--color-info: #2B6CB0;--color-danger: #EF4444;--color-danger-rgb: 239, 68, 68;--color-focus-ring: rgba(69, 179, 91, .4);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--space-20: 80px;--space-24: 96px;--space-30: 120px;--section-padding-y: 96px;--section-padding-y-lg: 120px;--card-padding: 24px;--card-padding-lg: 32px;--container-max-width: 1200px;--container-padding-x: 24px;--container-padding-x-lg: 48px;--border-width: 1px;--border-width-thick: 2px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 24px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(26, 26, 26, .04);--shadow-sm: 0 2px 4px rgba(26, 26, 26, .06);--shadow-md: 0 4px 12px rgba(26, 26, 26, .08);--shadow-lg: 0 8px 24px rgba(26, 26, 26, .1);--shadow-xl: 0 16px 48px rgba(26, 26, 26, .12);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--transition-slower: .4s ease;--transition-colors: color var(--transition-base), background-color var(--transition-base), border-color var(--transition-base);--transition-transform: transform var(--transition-base);--transition-opacity: opacity var(--transition-base);--transition-shadow: box-shadow var(--transition-base);--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700;--z-toast: 800;--button-height: 52px;--button-height-sm: 40px;--button-height-lg: 56px;--button-padding-x: 28px;--button-padding-x-sm: 20px;--button-padding-x-lg: 36px;--button-font-size: 16px;--button-font-weight: 600;--button-radius: var(--radius-lg);--input-height: 52px;--input-height-sm: 40px;--input-height-lg: 56px;--input-padding-x: 16px;--input-font-size: 16px;--input-radius: var(--radius-lg);--input-border-color: var(--color-border);--input-border-color-focus: var(--color-primary);--input-background: var(--color-background-elevated);--card-radius: var(--radius-xl);--card-background: var(--color-background-elevated);--card-border-color: var(--color-border);--navbar-height: 72px;--navbar-background: rgba(250, 251, 250, .95);--navbar-backdrop-blur: 12px;--footer-background: var(--color-background-subtle)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:100%;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{font-family:var(--font-family);font-size:var(--font-size-body);font-weight:var(--font-weight-regular);line-height:var(--line-height-body);color:var(--color-text-primary);background-color:var(--color-background);min-height:100vh}ul,ol{list-style:none}a{color:inherit;text-decoration:none}button{font-family:inherit;font-size:inherit;line-height:inherit;color:inherit;background:none;border:none;cursor:pointer}input,textarea,select{font-family:inherit;font-size:inherit;line-height:inherit;color:inherit;background:none;border:none;outline:none}img,picture,video,canvas,svg{display:block;max-width:100%;height:auto}table{border-collapse:collapse;border-spacing:0}fieldset{border:none}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--line-height-heading);letter-spacing:var(--letter-spacing-tight);color:var(--color-text-primary)}h1{font-size:var(--font-size-h1);font-weight:var(--font-weight-bold)}h2{font-size:var(--font-size-h2)}h3{font-size:var(--font-size-h3)}p{font-size:var(--font-size-body);line-height:var(--line-height-body);color:var(--color-text-secondary)}small{font-size:var(--font-size-small)}strong{font-weight:var(--font-weight-semibold)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}::selection{background-color:var(--color-primary-light);color:var(--color-primary)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link{position:absolute;top:-100%;left:50%;transform:translate(-50%);z-index:var(--z-toast);padding:var(--space-4) var(--space-6);background:var(--color-primary);color:var(--color-text-inverse);font-weight:var(--font-weight-semibold);border-radius:var(--radius-md);transition:top var(--transition-fast)}.skip-link:focus{top:var(--space-4)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.text-accent{color:var(--color-primary-text)}.font-regular{font-weight:var(--font-weight-regular)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}@media(max-width:1024px){:root{--font-size-h1: 40px;--font-size-h2: 28px;--font-size-h3: 20px}}@media(max-width:640px){:root{--font-size-h1: 34px;--font-size-h2: 24px;--font-size-h3: 18px;--font-size-body: 15px;--section-padding-y: 64px;--section-padding-y-lg: 80px;--container-padding-x: 20px}}.container{width:100%;max-width:var(--container-max-width);margin-left:auto;margin-right:auto;padding-left:var(--container-padding-x);padding-right:var(--container-padding-x)}.container--narrow{max-width:800px}.container--wide{max-width:1400px}.container--full{max-width:100%}@media(min-width:1024px){.container{padding-left:var(--container-padding-x-lg);padding-right:var(--container-padding-x-lg)}}.section{padding-top:var(--section-padding-y);padding-bottom:var(--section-padding-y)}.section--spacing-sm{padding-top:var(--space-12);padding-bottom:var(--space-12)}.section--spacing-lg{padding-top:var(--section-padding-y-lg);padding-bottom:var(--section-padding-y-lg)}.section--spacing-none{padding-top:0;padding-bottom:0}.section--bg-subtle{background-color:var(--color-background-subtle)}.section--bg-elevated{background-color:var(--color-background-elevated)}.section--bg-primary{background-color:var(--color-primary);color:var(--color-text-inverse)}.section--bg-primary .section__title,.section--bg-primary .section__subtitle{color:var(--color-text-inverse)}.heading{font-family:var(--font-family);line-height:var(--line-height-heading);letter-spacing:var(--letter-spacing-tight);color:var(--color-text-primary);margin:0}.heading--h1{font-size:var(--font-size-h1);font-weight:var(--font-weight-bold)}.heading--h2{font-size:var(--font-size-h2);font-weight:var(--font-weight-semibold)}.heading--h3{font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold)}.heading--center{text-align:center}.heading--right{text-align:right}@media(max-width:640px){.heading--h1{font-size:clamp(32px,8vw,var(--font-size-h1))}.heading--h2{font-size:clamp(26px,6vw,var(--font-size-h2))}}.text{font-family:var(--font-family);line-height:var(--line-height-body);margin:0}.text--body{font-size:var(--font-size-body)}.text--small{font-size:var(--font-size-small);line-height:var(--line-height-tight)}.text--large{font-size:20px}.text--primary{color:var(--color-text-primary)}.text--secondary{color:var(--color-text-secondary)}.text--tertiary{color:var(--color-text-tertiary)}.text--accent{color:var(--color-primary)}.text--inverse{color:var(--color-text-inverse)}.text--medium{font-weight:var(--font-weight-medium)}.text--semibold{font-weight:var(--font-weight-semibold)}.text--bold{font-weight:var(--font-weight-bold)}.text--center{text-align:center}.text--right{text-align:right}.text--readable{max-width:65ch}.text--readable.text--center{margin-left:auto;margin-right:auto}.button{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);height:var(--button-height);padding:0 var(--button-padding-x);font-family:var(--font-family);font-size:var(--button-font-size);font-weight:var(--button-font-weight);line-height:1;text-decoration:none;border:var(--border-width-thick) solid transparent;border-radius:var(--button-radius);cursor:pointer;transition:background-color var(--transition-base),border-color var(--transition-base),color var(--transition-base),transform var(--transition-fast),box-shadow var(--transition-base);position:relative;overflow:hidden}.button:focus-visible{outline:none;box-shadow:0 0 0 3px var(--color-focus-ring)}.button:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.button__content{display:inline-flex;align-items:center;gap:var(--space-2)}.button--primary{background-color:var(--color-primary);color:var(--color-text-inverse);border-color:var(--color-primary)}.button--primary:hover{background-color:var(--color-primary-hover);border-color:var(--color-primary-hover);transform:translateY(-2px);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.3)}.button--primary:active{background-color:var(--color-primary-active);border-color:var(--color-primary-active);transform:translateY(1px)}.button--secondary{background-color:transparent;color:var(--color-text-primary);border-color:var(--color-border-strong)}.button--secondary:hover{background-color:var(--color-background-subtle);border-color:var(--color-text-tertiary)}.button--secondary:active{background-color:var(--color-border);transform:translateY(1px)}.button--ghost{background-color:transparent;color:var(--color-primary);border-color:transparent}.button--ghost:hover{background-color:var(--color-primary-light)}.button--ghost:active{background-color:rgba(var(--color-primary-rgb),.15)}.button--danger{background-color:var(--color-danger);color:var(--color-text-inverse);border-color:var(--color-danger)}.button--danger:hover{background-color:#dc2626;border-color:#dc2626}.button--danger:active{background-color:#b91c1c;border-color:#b91c1c;transform:translateY(1px)}.button--text{background-color:transparent;color:var(--color-primary);border-color:transparent;padding:0;height:auto}.button--text:hover{background-color:transparent;text-decoration:underline}.button--sm{height:var(--button-height-sm);padding:0 var(--button-padding-x-sm);font-size:14px;border-radius:var(--radius-md)}.button--lg{height:var(--button-height-lg);padding:0 var(--button-padding-x-lg);font-size:17px}.button--full-width{width:100%}.button--loading .button__content{visibility:hidden}.button__loader{position:absolute;width:20px;height:20px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:button-spin .75s linear infinite}@keyframes button-spin{to{transform:rotate(360deg)}}.button svg{width:20px;height:20px;flex-shrink:0;transform:translateY(1px)}.button--sm svg{width:16px;height:16px}.button--lg svg{width:22px;height:22px}.input-wrapper{display:flex;flex-direction:column;gap:var(--space-2)}.input-wrapper--full-width{width:100%}.input__label{font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-text-primary);display:flex;align-items:center;gap:var(--space-1)}.input__required{color:var(--color-error)}.input__container{position:relative;display:flex;align-items:center}.input{width:100%;height:var(--input-height);padding:0 var(--input-padding-x);font-size:var(--input-font-size);font-weight:var(--font-weight-regular);color:var(--color-text-primary);background-color:var(--input-background);border:var(--border-width) solid var(--input-border-color);border-radius:var(--input-radius);transition:border-color var(--transition-base),box-shadow var(--transition-base),background-color var(--transition-base)}.input::placeholder{color:var(--color-text-tertiary)}.input:hover:not(:disabled){border-color:var(--color-border-strong)}.input:focus{border-color:var(--input-border-color-focus);box-shadow:0 0 0 3px var(--color-focus-ring)}.input:disabled{background-color:var(--color-background-subtle);color:var(--color-text-tertiary);cursor:not-allowed}.input--has-left-icon{padding-left:48px}.input--has-right-icon{padding-right:48px}.input__icon{position:absolute;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);pointer-events:none}.input__icon svg{width:20px;height:20px}.input__icon--left{left:var(--input-padding-x)}.input__icon--right{right:var(--input-padding-x)}.input__helper,.input__error{font-size:13px;line-height:var(--line-height-tight)}.input__helper{color:var(--color-text-tertiary)}.input__error{color:var(--color-error)}.input-wrapper--error .input{border-color:var(--color-error)}.input-wrapper--error .input:focus{box-shadow:0 0 0 3px #c5303033}.input-wrapper--sm .input{height:var(--input-height-sm);font-size:14px;border-radius:var(--radius-md)}.input-wrapper--lg .input{height:var(--input-height-lg);font-size:17px}.input-wrapper--disabled .input__label{color:var(--color-text-tertiary)}.input-wrapper--disabled .input__icon{opacity:.5}.select-wrapper{display:flex;flex-direction:column;gap:var(--space-2)}.select-wrapper--full-width{width:100%}.select__label{font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--space-1)}.select__required{color:var(--color-error);margin-left:2px}.select__error{font-size:13px;color:var(--color-error);margin-top:4px}.famili-select__control{border-color:var(--color-border)!important}.famili-select__control--is-focused{border-color:var(--color-primary)!important;box-shadow:0 0 0 1px var(--color-primary)!important}.year-input-wrapper{display:flex;flex-direction:column;gap:var(--space-1);width:100%}.year-input__label{font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--space-1)}.year-input__required{color:var(--color-danger)}.year-input__container{position:relative;display:flex;align-items:center}.year-input__field{width:100%;height:44px;padding:var(--space-2) var(--space-3);padding-right:40px;font-size:var(--text-base);font-family:var(--font-family-mono, monospace);letter-spacing:.1em;color:var(--color-text-primary);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color .2s ease,box-shadow .2s ease;-moz-appearance:textfield}.year-input__field::placeholder{color:var(--color-text-tertiary);letter-spacing:.15em}.year-input__field::-webkit-outer-spin-button,.year-input__field::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.year-input__field:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2f5d461a}.year-input__field:disabled{background-color:var(--color-bg-tertiary);cursor:not-allowed;opacity:.6}.year-input__icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--color-text-tertiary);pointer-events:none}.year-input__icon svg{width:100%;height:100%}.year-input-wrapper--error .year-input__field{border-color:var(--color-danger)}.year-input-wrapper--error .year-input__field:focus{box-shadow:0 0 0 3px #dc26261a}.year-input-wrapper--error .year-input__icon{color:var(--color-danger)}.year-input__error{font-size:var(--text-sm);color:var(--color-danger);display:flex;align-items:center;gap:var(--space-1)}.year-input__error:before{content:"";width:14px;height:14px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23dc2626' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cline x1='12' y1='8' x2='12' y2='12'/%3E%3Cline x1='12' y1='16' x2='12.01' y2='16'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;flex-shrink:0}.year-input__helper{font-size:var(--text-sm);color:var(--color-text-tertiary)}.year-input-wrapper--focused .year-input__icon{color:var(--color-primary)}.card{background-color:var(--card-background);border:var(--border-width) solid var(--card-border-color);border-radius:var(--card-radius);padding:var(--card-padding);transition:box-shadow var(--transition-base),transform var(--transition-base),border-color var(--transition-base)}.card--padding-sm{padding:var(--space-4)}.card--padding-lg{padding:var(--card-padding-lg)}.card--padding-none{padding:0}.card--no-border{border-color:transparent}.card--elevated{border-color:transparent;box-shadow:var(--shadow-md)}.card--hoverable:hover{box-shadow:var(--shadow-lg);border-color:var(--color-border-strong)}.card--clickable{cursor:pointer}.card--clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--color-border-strong)}.card--clickable:active{transform:translateY(0);box-shadow:var(--shadow-md)}.card--clickable:focus-visible{outline:none;box-shadow:0 0 0 3px var(--color-focus-ring),var(--shadow-md)}.card__header{margin-bottom:var(--space-4)}.card__title{font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.card__subtitle{font-size:var(--font-size-small);color:var(--color-text-tertiary);margin-top:var(--space-1)}.card__body{color:var(--color-text-secondary)}.card__footer{margin-top:var(--space-6);padding-top:var(--space-4);border-top:var(--border-width) solid var(--color-border-subtle)}.card__image{margin:calc(var(--card-padding) * -1);margin-bottom:var(--card-padding);border-radius:var(--card-radius) var(--card-radius) 0 0;overflow:hidden}.card__image img{width:100%;height:auto;display:block}.card--padding-lg .card__image{margin:calc(var(--card-padding-lg) * -1);margin-bottom:var(--card-padding-lg)}@media(max-width:640px){.card{padding:var(--space-5)}.card--padding-lg{padding:var(--card-padding)}}.search-suggestions{position:absolute;top:calc(100% + 8px);left:0;right:0;min-width:360px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 8px 24px #0000001a,0 2px 8px #0000000f;z-index:200;overflow:hidden;animation:suggestionsIn .15s ease forwards}@keyframes suggestionsIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.search-suggestions--inline{position:static;top:auto;left:auto;right:auto;border-radius:0;border:none;box-shadow:none;animation:none}.search-suggestions__list{list-style:none;margin:0;padding:6px 0;max-height:380px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#d1d5db transparent}.search-suggestions--inline .search-suggestions__list{max-height:calc(100dvh - 80px)}.search-suggestions__list::-webkit-scrollbar{width:4px}.search-suggestions__list::-webkit-scrollbar-track{background:transparent}.search-suggestions__list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:2px}.search-suggestions__group-header{padding:8px 16px 4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#9ca3af;pointer-events:none}.search-suggestions__item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:background .12s ease}.search-suggestions__item:hover,.search-suggestions__item--active{background:#f9fafb}.search-suggestions__item--active{background:#eef7ef}.search-suggestions__avatar{width:40px;height:40px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:#fff}.search-suggestions__avatar--male{background:#1d2842}.search-suggestions__avatar--female{background:#d4869e}.search-suggestions__avatar--unknown{background:#9ca3af}.search-suggestions__avatar--family{background:linear-gradient(135deg,#45b35b,#2f7a3c)}.search-suggestions__item-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.search-suggestions__item-name{font-size:14px;font-weight:500;color:#1a1a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-suggestions__item-sub{font-size:12px;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-suggestions__highlight{background:none;color:#2f7a3c;font-weight:700;padding:0}.search-suggestions__empty{padding:20px 16px;text-align:center;font-size:13px;color:#9ca3af}.search-suggestions__footer{border-top:1px solid #f3f4f6;padding:4px 0}.search-suggestions__see-all{display:block;width:100%;padding:10px 16px;font-family:inherit;font-size:13px;font-weight:500;color:#45b35b;background:none;border:none;text-align:left;cursor:pointer;transition:background .12s ease,color .12s ease}.search-suggestions__see-all:hover{background:#f9fafb;color:#2f7a3c}.search-suggestions__see-all:focus-visible{outline:2px solid #45b35b;outline-offset:-2px}.top-nav-search{position:relative;display:none}@media(min-width:769px){.top-nav-search{display:block;width:100%}}.top-nav-search__input-wrap{position:relative;display:flex;align-items:center}.top-nav-search__icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);display:flex;align-items:center;color:#6b7280;pointer-events:none;z-index:1;transition:color .2s ease}.top-nav-search--focused .top-nav-search__icon{color:#45b35b}.top-nav-search__input{width:100%;height:38px;padding:0 36px 0 38px;background:#f3f4f6;border:1.5px solid transparent;border-radius:24px;font-family:inherit;font-size:13px;font-weight:400;color:#1a1a1a;outline:none;transition:background .2s ease,border-color .2s ease,box-shadow .2s ease;-webkit-appearance:none}.top-nav-search__input::-webkit-search-decoration,.top-nav-search__input::-webkit-search-cancel-button,.top-nav-search__input::-webkit-search-results-button,.top-nav-search__input::-webkit-search-results-decoration{-webkit-appearance:none}.top-nav-search__input::placeholder{color:#9ca3af}.top-nav-search__input:focus,.top-nav-search--focused .top-nav-search__input{width:100%;background:#fff;border-color:#45b35b;box-shadow:0 0 0 3px #45b35b1f}.top-nav-search__input:focus-visible{outline:none}.top-nav-search__clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:#d1d5db;border:none;border-radius:50%;cursor:pointer;color:#6b7280;padding:0;transition:background .15s ease,color .15s ease}.top-nav-search__clear:hover{background:#9ca3af;color:#fff}.top-nav-search__clear:focus-visible{outline:2px solid #45b35b;outline-offset:1px}.top-nav-search__mobile-btn{display:none;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:none;border-radius:50%;cursor:pointer;color:#1a1a1a;padding:0;transition:background .15s ease}.top-nav-search__mobile-btn:hover{background:#f3f4f6}.top-nav-search__mobile-btn:focus-visible{outline:2px solid #45b35b;outline-offset:2px}@media(max-width:768px){.top-nav-search__mobile-btn{display:flex}}.top-nav-search__overlay-backdrop{position:fixed;inset:0;background:#00000073;z-index:350;animation:topNavSearchBackdropIn .2s ease forwards}@keyframes topNavSearchBackdropIn{0%{opacity:0}to{opacity:1}}.top-nav-search__overlay{position:fixed;top:0;left:0;right:0;background:#fff;z-index:360;box-shadow:0 4px 24px #0000001f;animation:topNavSearchOverlayIn .22s ease forwards}@keyframes topNavSearchOverlayIn{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.top-nav-search__overlay-inner{display:flex;flex-direction:column}.top-nav-search__overlay-input-wrap{display:flex;align-items:center;padding:12px 16px;gap:10px;border-bottom:1px solid #e5e7eb}.top-nav-search__overlay-icon{flex-shrink:0;color:#6b7280;display:flex;align-items:center}.top-nav-search__overlay-input{flex:1;height:44px;padding:0 8px;background:none;border:none;font-family:inherit;font-size:15px;color:#1a1a1a;outline:none;-webkit-appearance:none}.top-nav-search__overlay-input::-webkit-search-decoration,.top-nav-search__overlay-input::-webkit-search-cancel-button{-webkit-appearance:none}.top-nav-search__overlay-input::placeholder{color:#9ca3af}.top-nav-search__overlay-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:none;border-radius:50%;cursor:pointer;color:#6b7280;padding:0;transition:background .15s ease,color .15s ease}.top-nav-search__overlay-close:hover{background:#f3f4f6;color:#1a1a1a}.top-nav-search__overlay-close:focus-visible{outline:2px solid #45b35b;outline-offset:2px}.navbar{width:100%;height:var(--navbar-height);background-color:var(--navbar-background);backdrop-filter:blur(var(--navbar-backdrop-blur));-webkit-backdrop-filter:blur(var(--navbar-backdrop-blur));border-bottom:var(--border-width) solid var(--color-border);transition:background-color var(--transition-base),border-color var(--transition-base),box-shadow var(--transition-base);z-index:var(--z-sticky)}.navbar--sticky{position:fixed;top:0;left:0;right:0}.navbar--scrolled{box-shadow:var(--shadow-sm)}.navbar--transparent{background-color:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom-color:transparent}.navbar--transparent .navbar__link{color:var(--color-text-primary)}.navbar__inner{display:flex;align-items:center;justify-content:space-between;height:var(--navbar-height);gap:var(--space-8)}.navbar__logo{display:flex;align-items:center;flex-shrink:0;text-decoration:none}.navbar__logo-text{font-size:22px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:var(--letter-spacing-tight)}.navbar__logo svg,.navbar__logo img{height:32px;width:auto}.navbar__links{display:flex;align-items:center;gap:var(--space-8);list-style:none;margin:0;padding:0}.navbar__link-item{margin:0}.navbar__link{font-size:var(--font-size-button);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-decoration:none;padding:var(--space-2) 0;position:relative;transition:color var(--transition-base);white-space:nowrap}.navbar__link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background-color:var(--color-primary);transition:width var(--transition-base)}.navbar__link:hover{color:var(--color-text-primary)}.navbar__link:hover:after{width:100%}.navbar__link--active{color:var(--color-primary)}.navbar__link--active:after{width:100%}.navbar__search{display:flex;align-items:center;flex:1;min-width:0}.navbar__actions{display:flex;align-items:center;gap:var(--space-4);flex-shrink:0;white-space:nowrap}.navbar__sign-in{font-size:var(--font-size-button);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-decoration:none;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);transition:color var(--transition-base),background-color var(--transition-base);white-space:nowrap}.navbar__sign-in:hover{color:var(--color-text-primary);background-color:var(--color-background-subtle)}.navbar__user-menu{position:relative}.navbar__user-trigger{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:none;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:background-color var(--transition-base)}.navbar__user-trigger:hover{background-color:var(--color-background-subtle)}.navbar__user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-text-inverse);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:var(--font-weight-semibold);overflow:hidden}.navbar__user-avatar--has-image{background:none}.navbar__user-avatar-img{width:100%;height:100%;object-fit:cover}.navbar__user-name{font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}@media(max-width:480px){.navbar__user-name{display:none}}.navbar__user-chevron{width:16px;height:16px;color:var(--color-text-tertiary);transition:transform var(--transition-base)}.navbar__user-trigger[aria-expanded=true] .navbar__user-chevron{transform:rotate(180deg)}.navbar__user-dropdown{position:absolute;top:calc(100% + var(--space-2));right:0;min-width:220px;background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);padding:var(--space-2);animation:dropdownFadeIn .15s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.navbar__dropdown-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3)}.navbar__dropdown-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-text-inverse);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:var(--font-weight-semibold);flex-shrink:0;overflow:hidden}.navbar__dropdown-avatar--has-image{background:none}.navbar__dropdown-avatar-img{width:100%;height:100%;object-fit:cover}.navbar__dropdown-info{display:flex;flex-direction:column;gap:2px;min-width:0}.navbar__dropdown-name{font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.navbar__dropdown-email{font-size:12px;color:var(--color-text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar__dropdown-divider{height:1px;background:var(--color-border-subtle);margin:var(--space-2) 0}.navbar__dropdown-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3);font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-decoration:none;text-align:left;background:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.navbar__dropdown-icon{width:18px;height:18px;flex-shrink:0;color:var(--color-text-tertiary);transition:color var(--transition-fast)}.navbar__dropdown-item:hover{background-color:var(--color-background-subtle);color:var(--color-text-primary)}.navbar__dropdown-item:hover .navbar__dropdown-icon{color:var(--color-primary)}.navbar__dropdown-item--signout,.navbar__dropdown-item--signout .navbar__dropdown-icon,.navbar__dropdown-item--signout:hover .navbar__dropdown-icon{color:var(--color-error, #dc2626)}.navbar__dropdown-item--signout:hover{background-color:#dc26261a;color:var(--color-error, #dc2626)}.navbar__mobile-toggle{display:none;width:44px;height:44px;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:0;margin-right:-8px}.navbar__hamburger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:22px;height:22px}.navbar__hamburger span{display:block;width:100%;height:2px;background-color:var(--color-text-primary);border-radius:1px;transition:transform var(--transition-base),opacity var(--transition-base);transform-origin:center}.navbar--menu-open .navbar__hamburger span:nth-child(1){transform:translateY(7px) rotate(45deg)}.navbar--menu-open .navbar__hamburger span:nth-child(2){opacity:0}.navbar--menu-open .navbar__hamburger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.navbar__mobile-menu{position:fixed;top:var(--navbar-height);left:0;right:0;height:calc(100vh - var(--navbar-height));height:calc(100dvh - var(--navbar-height));background-color:var(--color-background);border-top:var(--border-width) solid var(--color-border);opacity:0;visibility:hidden;transform:translateY(-10px);transition:opacity var(--transition-base),visibility var(--transition-base),transform var(--transition-base);overflow-y:auto;z-index:var(--z-sticky);display:flex;flex-direction:column}.navbar--menu-open .navbar__mobile-menu{opacity:1;visibility:visible;transform:translateY(0)}.navbar__mobile-links{list-style:none;margin:0;padding:var(--space-6) 0}.navbar__mobile-link-item{margin:0}.navbar__mobile-link{display:block;padding:var(--space-4) var(--space-6);font-size:var(--font-size-body);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-decoration:none;border-bottom:var(--border-width) solid var(--color-border-subtle);transition:color var(--transition-base)}.navbar__mobile-link:hover,.navbar__mobile-link--active{color:var(--color-primary);background-color:var(--color-background-subtle)}.navbar__mobile-actions{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-6) 0}.navbar__mobile-sign-in{display:block;text-align:center;padding:var(--space-4);font-size:var(--font-size-body);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-decoration:none;border:var(--border-width) solid var(--color-border);border-radius:var(--radius-lg);transition:color var(--transition-base),border-color var(--transition-base),background-color var(--transition-base)}.navbar__mobile-sign-in:hover{color:var(--color-primary);border-color:var(--color-primary);background-color:var(--color-primary-light)}@media(max-width:768px){.navbar__links{display:none}.navbar__mobile-toggle{display:flex}.navbar__actions .button{display:none}}@media(min-width:769px){.navbar__mobile-menu{display:none}}.footer{background-color:var(--footer-background);padding-top:var(--space-16);padding-bottom:var(--space-8);border-top:var(--border-width) solid var(--color-border)}.footer__inner{display:grid;grid-template-columns:1fr;gap:var(--space-12);padding-bottom:var(--space-12);border-bottom:var(--border-width) solid var(--color-border)}@media(min-width:768px){.footer__inner{grid-template-columns:1.2fr 2fr;gap:var(--space-16)}}.footer__brand{max-width:320px}.footer__logo{display:inline-flex;align-items:center;text-decoration:none;margin-bottom:var(--space-4)}.footer__logo-text{font-size:22px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:var(--letter-spacing-tight)}.footer__logo svg,.footer__logo img{height:32px;width:auto}.footer__description{margin-bottom:var(--space-6)}.footer__social{display:flex;align-items:center;gap:var(--space-3)}.footer__social-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background-color:var(--color-background-elevated);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);transition:background-color var(--transition-base),border-color var(--transition-base),color var(--transition-base)}.footer__social-link:hover{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-inverse)}.footer__social-link svg{width:18px;height:18px}.footer__columns{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-8)}@media(min-width:640px){.footer__columns{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.footer__columns{grid-template-columns:repeat(4,1fr)}}.footer__column-title{font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--space-4)}.footer__column-links{list-style:none;margin:0;padding:0}.footer__column-links li{margin-bottom:var(--space-3)}.footer__column-link{font-size:var(--font-size-small);color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition-base)}.footer__column-link:hover{color:var(--color-primary)}.footer__bottom{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding-top:var(--space-8);text-align:center}@media(min-width:640px){.footer__bottom{flex-direction:row;justify-content:space-between;text-align:left}}.footer__bottom-left{display:flex;flex-direction:column;gap:var(--space-1)}.footer__copyright{margin:0}.footer__owner-line{margin:0;font-size:12px}.footer__bottom-links{display:flex;align-items:center;gap:var(--space-6)}.footer__bottom-link{font-size:13px;color:var(--color-text-tertiary);text-decoration:none;transition:color var(--transition-base)}.footer__bottom-link:hover{color:var(--color-text-secondary)}@media(max-width:640px){.footer{padding-top:var(--space-12)}.footer__brand{max-width:100%;text-align:center}.footer__social{justify-content:center}.footer__columns{gap:var(--space-6)}}.family-switcher{position:relative}.family-switcher__trigger{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:transparent;border:1px solid var(--color-border);border-radius:8px;cursor:default;font-family:inherit;font-size:.875rem;font-weight:500;color:var(--color-text-primary);transition:all .2s ease;max-width:220px}.family-switcher__trigger--dropdown{cursor:pointer}.family-switcher__trigger--dropdown:hover{background:var(--color-surface-subtle, #F9FAFB);border-color:var(--color-primary)}.family-switcher__trigger:focus-visible{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2f5d461a}.family-switcher__icon{flex-shrink:0;width:18px;height:18px;color:var(--color-primary)}.family-switcher__icon svg{width:100%;height:100%}.family-switcher__name{flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.family-switcher__chevron{flex-shrink:0;width:14px;height:14px;color:var(--color-text-tertiary);transition:transform .2s ease}.family-switcher__chevron svg{width:100%;height:100%}.family-switcher__chevron--open{transform:rotate(180deg)}.family-switcher__dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:240px;max-width:300px;background:var(--color-surface, #FFFFFF);border:1px solid var(--color-border);border-radius:12px;box-shadow:0 4px 16px #0000001f;z-index:1000;overflow:hidden;animation:familySwitcherSlideIn .15s ease-out}@keyframes familySwitcherSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.family-switcher__dropdown-header{padding:.75rem 1rem;border-bottom:1px solid var(--color-border);font-size:.75rem;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em}.family-switcher__list{padding:.5rem;max-height:280px;overflow-y:auto}.family-switcher__item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.75rem;background:transparent;border:none;border-radius:8px;cursor:pointer;font-family:inherit;text-align:left;transition:background-color .15s ease}.family-switcher__item:hover{background:var(--color-surface-subtle, #F9FAFB)}.family-switcher__item--active,.family-switcher__item--active:hover{background:var(--color-primary-light, #E8F5E9)}.family-switcher__item-content{display:flex;flex-direction:column;gap:.125rem;overflow:hidden}.family-switcher__item-name{font-size:.9375rem;font-weight:500;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.family-switcher__item-role{font-size:.75rem;color:var(--color-text-tertiary)}.family-switcher__item-check{flex-shrink:0;width:18px;height:18px;color:var(--color-primary)}.family-switcher__item-check svg{width:100%;height:100%}.family-switcher__dropdown-footer{padding:.5rem;border-top:1px solid var(--color-border)}.family-switcher__create{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem;background:transparent;border:none;border-radius:8px;color:var(--color-primary);font-size:.875rem;font-weight:500;text-decoration:none;transition:background-color .15s ease}.family-switcher__create:hover{background:var(--color-surface-subtle, #F9FAFB)}.family-switcher__create-icon{width:16px;height:16px}.family-switcher__create-icon svg{width:100%;height:100%}.family-switcher--compact .family-switcher__trigger{padding:.375rem .625rem;font-size:.8125rem}.family-switcher--compact .family-switcher__icon{width:16px;height:16px}.family-switcher--compact .family-switcher__dropdown{min-width:200px}@media(max-width:768px){.family-switcher__trigger{padding:.375rem .625rem}.family-switcher__name{max-width:120px}.family-switcher__dropdown{left:auto;right:0;min-width:220px}}.otp-input{width:100%;display:flex;flex-direction:column;gap:var(--space-4)}.otp-input__label{font-size:15px;font-weight:var(--font-weight-medium);color:var(--color-text-primary);text-align:center}.otp-input__container{display:flex;justify-content:center;gap:var(--space-3)}.otp-input__digit{width:52px;height:64px;font-family:var(--font-family);font-size:28px;font-weight:var(--font-weight-semibold);text-align:center;color:var(--color-text-primary);background-color:var(--color-background-elevated);border:var(--border-width-thick) solid var(--color-border);border-radius:var(--radius-lg);outline:none;transition:border-color var(--transition-base),box-shadow var(--transition-base),background-color var(--transition-base),transform var(--transition-fast);caret-color:var(--color-primary)}.otp-input__digit::-webkit-outer-spin-button,.otp-input__digit::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.otp-input__digit[type=number]{-moz-appearance:textfield}.otp-input__digit--filled{border-color:#2e7a3c;background-color:#2e7a3c0d;color:#111827}.otp-input__digit:focus{border-color:#2e7a3c;box-shadow:0 0 0 3px #2e7a3c2e;transform:translateY(-2px)}.otp-input__digit:hover:not(:focus):not(:disabled){border-color:var(--color-text-tertiary)}@keyframes otpShake{0%,to{transform:translate(0)}15%,45%,75%{transform:translate(-5px)}30%,60%,90%{transform:translate(5px)}}.otp-input--error .otp-input__container{animation:otpShake .45s cubic-bezier(.36,.07,.19,.97)}.otp-input--error .otp-input__digit{border-color:#dc2626;background-color:#dc26260a}.otp-input--error .otp-input__digit:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26262e}.otp-input__error{font-size:var(--font-size-small);color:#dc2626;text-align:center;margin:0}.otp-input--disabled .otp-input__digit{opacity:.6;cursor:not-allowed;background-color:var(--color-background-muted)}@media(max-width:480px){.otp-input__container{gap:var(--space-2)}.otp-input__digit{width:44px;height:56px;font-size:24px}}@media(max-width:360px){.otp-input__digit{width:40px;height:52px;font-size:22px}}@media(prefers-reduced-motion:no-preference){.otp-input__digit{animation:otpDigitFadeIn .3s ease backwards}.otp-input__digit:nth-child(1){animation-delay:.05s}.otp-input__digit:nth-child(2){animation-delay:.1s}.otp-input__digit:nth-child(3){animation-delay:.15s}.otp-input__digit:nth-child(4){animation-delay:.2s}.otp-input__digit:nth-child(5){animation-delay:.25s}.otp-input__digit:nth-child(6){animation-delay:.3s}@keyframes otpDigitFadeIn{0%{opacity:0;transform:translateY(8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}}.auth-notice{display:flex;align-items:flex-start;gap:var(--space-3);width:100%;padding:var(--space-4);border-radius:var(--radius-lg);border:var(--border-width) solid;animation:authNoticeFadeIn .3s ease}@keyframes authNoticeFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.auth-notice__icon{flex-shrink:0;width:20px;height:20px;margin-top:1px}.auth-notice__icon svg{width:100%;height:100%}.auth-notice__content{flex:1;min-width:0}.auth-notice__title{font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);margin:0 0 var(--space-1) 0;line-height:1.4}.auth-notice__message{font-size:var(--font-size-small);margin:0;line-height:1.5;opacity:.9}.auth-notice__title+.auth-notice__message{margin-top:var(--space-1)}.auth-notice__dismiss{flex-shrink:0;width:24px;height:24px;padding:var(--space-1);background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;opacity:.6;transition:opacity var(--transition-base),background-color var(--transition-base);margin:-2px -4px -2px 0}.auth-notice__dismiss:hover{opacity:1;background-color:#0000000d}.auth-notice__dismiss:focus-visible{outline:2px solid currentColor;outline-offset:2px;opacity:1}.auth-notice__dismiss svg{width:100%;height:100%}.auth-notice--success{background-color:#2f5d4614;border-color:#2f5d4633;color:var(--color-success)}.auth-notice--success .auth-notice__title,.auth-notice--success .auth-notice__message{color:#1e4d35}.auth-notice--warning{background-color:#b7791f14;border-color:#b7791f33;color:var(--color-warning)}.auth-notice--warning .auth-notice__title,.auth-notice--warning .auth-notice__message{color:#744210}.auth-notice--error{background-color:#c5303014;border-color:#c5303033;color:var(--color-error)}.auth-notice--error .auth-notice__title,.auth-notice--error .auth-notice__message{color:#742a2a}.auth-notice--info{background-color:#2b6cb014;border-color:#2b6cb033;color:var(--color-info)}.auth-notice--info .auth-notice__title,.auth-notice--info .auth-notice__message{color:#2a4365}@media(max-width:480px){.auth-notice{padding:var(--space-3);gap:var(--space-2)}.auth-notice__icon{width:18px;height:18px}.auth-notice__title{font-size:15px}.auth-notice__message{font-size:13px}}.ifm-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;animation:fadeIn .3s ease-out}.ifm-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;max-width:600px;background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-2xl);z-index:1001;display:flex;flex-direction:column;max-height:90vh;animation:modalEnter .4s cubic-bezier(.16,1,.3,1)}@keyframes modalEnter{0%{opacity:0;transform:translate(-50%,-45%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.ifm-header{padding:var(--space-6);border-bottom:1px solid var(--color-border-subtle);display:flex;align-items:flex-start;justify-content:space-between}.ifm-header__content{flex:1}.ifm-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-full);color:var(--color-text-tertiary);cursor:pointer;transition:all .2s}.ifm-close:hover{background:var(--color-background-subtle);color:var(--color-text-primary)}.ifm-close svg{width:20px;height:20px}.ifm-tabs{display:flex;padding:var(--space-4) var(--space-6);gap:var(--space-2);background:var(--color-background-subtle);border-bottom:1px solid var(--color-border-subtle)}.ifm-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-3);background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);cursor:pointer;transition:all .2s}.ifm-tab:hover{border-color:var(--color-primary);background:var(--color-background-warm)}.ifm-tab--active{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.ifm-tab__icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center}.ifm-tab__icon svg{width:20px;height:20px}.ifm-tab__label{font-size:12px;font-weight:var(--font-weight-semibold)}.ifm-content{padding:var(--space-6);overflow-y:auto;flex:1}.ifm-form{display:flex;flex-direction:column;gap:var(--space-4)}.ifm-form__row{display:flex;gap:var(--space-4)}.ifm-form__field{flex:1}.ifm-label{display:block;font-size:14px;font-weight:var(--font-weight-medium);margin-bottom:var(--space-2);color:var(--color-text-primary)}.ifm-textarea{width:100%;padding:var(--space-4);background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-family:inherit;font-size:14px;color:var(--color-text-primary);resize:vertical;line-height:1.5}.ifm-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.ifm-hint{margin-top:var(--space-1)}.ifm-success{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8) 0;text-align:center;gap:var(--space-4)}.ifm-success__icon{width:64px;height:64px;background:var(--color-primary-light);color:var(--color-primary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.ifm-success__icon svg{width:32px;height:32px}.ifm-footer{padding:var(--space-6);border-top:1px solid var(--color-border-subtle);display:flex;justify-content:space-between;align-items:center;gap:var(--space-4)}.ifm-footer__actions{display:flex;gap:var(--space-3)}.ifm-toast{position:absolute;bottom:var(--space-6);left:50%;transform:translate(-50%);background:var(--color-text-primary);color:var(--color-background-elevated);padding:var(--space-3) var(--space-6);border-radius:var(--radius-full);box-shadow:var(--shadow-lg);z-index:1002;animation:toastEnter .3s ease-out}@keyframes toastEnter{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}.ifm-toast--error{background:var(--color-danger)}@media(max-width:640px){.ifm-modal{inset:auto 0 0;transform:none;max-width:none;border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;max-height:95vh;animation:slideUp .4s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.ifm-form__row{flex-direction:column}.ifm-footer{flex-direction:column-reverse}.ifm-footer__actions{width:100%;flex-direction:column}}.keepsake-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.keepsake-modal{background:#fff;border-radius:20px;width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 40px #0003;overflow:hidden;animation:modalSlideUp .3s ease-out}@keyframes modalSlideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.keepsake-modal-header{padding:24px 32px;border-bottom:1px solid #f0f0f0;display:flex;align-items:center;justify-content:space-between}.keepsake-modal-header h2{margin:0;font-size:1.5rem;color:#1a1a1a}.close-btn{background:none;border:none;color:#999;cursor:pointer;padding:8px;border-radius:50%;transition:all .2s;display:flex;align-items:center;justify-content:center}.close-btn:hover{background:#f5f5f5;color:#333}.close-btn svg{width:24px;height:24px}.keepsake-modal-stepper{display:flex;justify-content:center;gap:12px;padding:16px 0;background:#fafafa}.step-dot{width:10px;height:10px;border-radius:50%;background:#e0e0e0;transition:all .3s}.step-dot.active{background:#0d9488;transform:scale(1.2)}.step-dot.completed{background:#5eead4}.keepsake-modal-content{padding:32px;overflow-y:auto;flex:1}.keepsake-step-title{margin-bottom:24px;text-align:center}.template-grid{display:grid;grid-template-columns:1fr;gap:12px}.template-option{display:flex;align-items:center;gap:16px;padding:16px;background:#fff;border:2px solid #f0f0f0;border-radius:12px;cursor:pointer;text-align:left;transition:all .2s}.template-option:hover{border-color:#0d9488;background:#f0fdfa}.template-option.active{border-color:#0d9488;background:#f0fdfa;box-shadow:0 4px 12px #0d94881a}.template-icon{width:48px;height:48px;background:#f0fdfa;color:#0d9488;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.template-icon svg{width:24px;height:24px}.template-info{flex:1}.privacy-options{display:flex;flex-direction:column;gap:16px}.privacy-option{padding:20px;background:#fff;border:2px solid #f0f0f0;border-radius:12px;cursor:pointer;text-align:left;transition:all .2s;position:relative}.privacy-option:hover{border-color:#0d9488}.privacy-option.active{border-color:#0d9488;background:#f0fdfa}.privacy-option-content{display:flex;justify-content:space-between;align-items:center;gap:16px;width:100%}.privacy-option-title{display:flex;flex-direction:column;gap:4px;flex:1}.radio-dot{width:20px;height:20px;border:2px solid #ddd;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}.radio-dot.checked{border-color:#0d9488}.radio-dot.checked:after{content:"";width:10px;height:10px;background:#0d9488;border-radius:50%;animation:scaleIn .2s ease-out}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.keepsake-preview-card{background:#f9fafb;border-radius:16px;padding:16px;margin-bottom:24px;box-shadow:inset 0 2px 4px #0000000d}.preview-image-container{position:relative;border-radius:12px;overflow:hidden;aspect-ratio:16/9}.preview-image{width:100%;height:100%;object-fit:cover}.preview-overlay{position:absolute;bottom:0;left:0;right:0;padding:24px;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);color:#fff}.preview-title{color:#fff!important;margin:0 0 4px;font-size:1.25rem}.preview-subtitle{color:#fffc!important;margin:0;font-size:.875rem}.keepsake-actions{display:flex;flex-direction:column;gap:12px}.action-btn-wide{width:100%;justify-content:center!important;gap:8px}.saved-badge{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:#f0fdf4;color:#166534;border-radius:12px;font-weight:600}.keepsake-modal-footer{padding:24px 32px;border-top:1px solid #f0f0f0;display:flex;align-items:center;background:#fafafa}@media(min-width:640px){.template-grid{grid-template-columns:1fr}}.csm-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:var(--z-modal-backdrop);animation:csmFadeIn .3s ease-out}.csm-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:500px;background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);z-index:var(--z-modal);animation:csmModalEnter .4s cubic-bezier(.16,1,.3,1)}@keyframes csmFadeIn{0%{opacity:0}to{opacity:1}}@keyframes csmModalEnter{0%{opacity:0;transform:translate(-50%,-45%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.csm-close{position:absolute;top:var(--space-4);right:var(--space-4);width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-full);color:var(--color-text-tertiary);cursor:pointer;transition:all var(--transition-base);z-index:10}.csm-close:hover{background:var(--color-background-subtle);color:var(--color-text-primary)}.csm-close svg{width:20px;height:20px}.csm-content{padding:var(--space-8) var(--space-6) var(--space-6);display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-6)}.csm-illustration{position:relative;width:180px;height:180px;display:flex;align-items:center;justify-content:center}.csm-phone{position:relative;width:100px;height:160px;background:linear-gradient(135deg,var(--color-primary) 0%,#1E3C2D 100%);border-radius:16px;box-shadow:var(--shadow-lg);animation:csmPhoneFloat 3s ease-in-out infinite}@keyframes csmPhoneFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.csm-phone-notch{position:absolute;top:8px;left:50%;transform:translate(-50%);width:40px;height:4px;background:#ffffff4d;border-radius:var(--radius-full)}.csm-phone-screen{position:absolute;inset:12px;background:#ffffff1a;border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;overflow:hidden}.csm-phone-logo{width:44px;height:44px;background:#fffffff2;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:#fff;animation:csmLogoPulse 2s ease-in-out infinite;padding:8px;box-shadow:0 2px 8px #0000001a}@keyframes csmLogoPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.9}}.csm-phone-logo img{width:100%;height:100%;object-fit:contain}.csm-phone-dots{display:flex;gap:6px}.csm-phone-dots span{width:8px;height:8px;background:#fff6;border-radius:var(--radius-full);animation:csmDotBounce 1.4s ease-in-out infinite}.csm-phone-dots span:nth-child(1){animation-delay:0s}.csm-phone-dots span:nth-child(2){animation-delay:.2s}.csm-phone-dots span:nth-child(3){animation-delay:.4s}@keyframes csmDotBounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-8px);opacity:1}}.csm-decoration{position:absolute;border-radius:var(--radius-full);opacity:.6}.csm-decoration-1{width:60px;height:60px;background:linear-gradient(135deg,var(--color-primary-light) 0%,transparent 100%);top:0;left:0;animation:csmDecorationFloat1 4s ease-in-out infinite}.csm-decoration-2{width:80px;height:80px;background:linear-gradient(135deg,rgba(47,93,70,.05) 0%,transparent 100%);bottom:10px;right:0;animation:csmDecorationFloat2 5s ease-in-out infinite}.csm-decoration-3{width:40px;height:40px;background:linear-gradient(135deg,var(--color-primary-light) 0%,transparent 100%);top:50%;right:10px;animation:csmDecorationFloat3 3.5s ease-in-out infinite}@keyframes csmDecorationFloat1{0%,to{transform:translate(0) scale(1)}50%{transform:translate(10px,-10px) scale(1.1)}}@keyframes csmDecorationFloat2{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-15px,10px) scale(1.15)}}@keyframes csmDecorationFloat3{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-10px,-15px) scale(1.2)}}.csm-text{display:flex;flex-direction:column;gap:var(--space-3);max-width:400px}.csm-title{margin:0;color:var(--color-text-primary)}.csm-description{margin:0;line-height:var(--line-height-body)}.csm-button{width:100%;max-width:200px}@media(max-width:640px){.csm-modal{width:95%;max-width:none;inset:auto 0 0;transform:none;border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;animation:csmSlideUp .4s cubic-bezier(.16,1,.3,1)}@keyframes csmSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.csm-content{padding:var(--space-6) var(--space-5) var(--space-5)}.csm-illustration{width:150px;height:150px}.csm-phone{width:85px;height:140px}.csm-decoration-1,.csm-decoration-2,.csm-decoration-3{opacity:.4}}.eam-overlay{position:fixed;inset:0;background:#00000080;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:var(--z-modal-backdrop);animation:eamFadeIn .3s ease-out}.eam-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:440px;background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);z-index:var(--z-modal);animation:eamModalEnter .4s cubic-bezier(.16,1,.3,1)}@keyframes eamFadeIn{0%{opacity:0}to{opacity:1}}@keyframes eamModalEnter{0%{opacity:0;transform:translate(-50%,-45%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.eam-close{position:absolute;top:16px;right:16px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:50%;cursor:pointer;color:var(--color-text-tertiary);transition:background-color var(--transition-fast),color var(--transition-fast);padding:0;z-index:10}.eam-close:hover{background:#0000000f;color:var(--color-text-primary)}.eam-close:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.eam-close svg{width:20px;height:20px;display:block}.eam-content{padding:40px 32px 32px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:20px}.eam-title{font-size:var(--font-size-modal-title);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0;line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight);font-family:var(--font-family)}.eam-subtitle{font-size:var(--font-size-body);color:var(--color-text-secondary);margin:0;line-height:var(--line-height-body);font-family:var(--font-family)}.eam-form{width:100%;display:flex;flex-direction:column;gap:16px}.eam-input-wrapper{position:relative;width:100%}.eam-input-wrapper svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--color-text-tertiary);pointer-events:none;flex-shrink:0}.eam-input{width:100%;height:48px;padding:0 16px 0 42px;border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--font-size-body);font-family:var(--font-family);background:var(--color-background-elevated);color:var(--color-text-primary);transition:border-color var(--transition-base),box-shadow var(--transition-base);outline:none;box-sizing:border-box;-webkit-appearance:none;appearance:none}.eam-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-focus-ring)}.eam-input:disabled{opacity:.6;cursor:not-allowed}.eam-input::placeholder{color:var(--color-text-tertiary)}.eam-input[aria-invalid=true]{border-color:var(--color-error)}.eam-input[aria-invalid=true]:focus{box-shadow:0 0 0 3px #c5303033}.eam-checkbox{display:flex;align-items:center;gap:10px;font-size:var(--font-size-small);color:var(--color-text-secondary);cursor:pointer;text-align:left;font-family:var(--font-family);line-height:var(--line-height-body);align-self:flex-start}.eam-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary);flex-shrink:0;cursor:pointer;margin:0}.eam-checkbox__mark{display:none}.eam-error{font-size:var(--font-size-small);color:var(--color-error);margin:0;text-align:left;font-family:var(--font-family);line-height:var(--line-height-tight)}.eam-submit{width:100%;height:48px;background:var(--color-primary-active);color:var(--color-text-inverse);border:none;border-radius:var(--radius-lg);font-size:16px;font-weight:var(--font-weight-semibold);font-family:var(--font-family);cursor:pointer;transition:background-color var(--transition-base),transform var(--transition-base);outline:none}.eam-submit:hover:not(:disabled){background:var(--color-primary);transform:translateY(-1px)}.eam-submit:active:not(:disabled){transform:translateY(0);background:var(--color-primary-active)}.eam-submit:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.eam-submit:disabled{opacity:.7;cursor:not-allowed}.eam-content--success{gap:16px;padding-top:48px}.eam-success-icon{width:64px;height:64px;border-radius:50%;background:var(--color-background-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.eam-success-icon svg{width:32px;height:32px;color:var(--color-primary);display:block}.eam-success-text{font-size:var(--font-size-body);color:var(--color-text-secondary);line-height:1.6;margin:0;font-family:var(--font-family)}@media(max-width:640px){.eam-modal{width:100%;max-width:none;inset:auto 0 0;transform:none;border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;animation:eamSlideUp .4s cubic-bezier(.16,1,.3,1)}@keyframes eamSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.eam-content{padding:32px 24px 24px}.eam-content{padding-bottom:calc(24px + env(safe-area-inset-bottom,0px))}}@keyframes drawLine{to{stroke-dashoffset:0}}@keyframes nodePulse{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}@keyframes thumbFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.living-network{position:relative;width:100%;max-width:400px;margin:0 0 0 auto}.living-network__glass{position:relative;background:#ffffffa6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:16px;border:1px solid rgba(255,255,255,.5);box-shadow:0 4px 24px #0000000f;padding:24px}.living-network__svg{width:100%;display:block}.living-network__line{stroke:#a8d5b0;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round}.living-network__svg--drawn .living-network__line{animation:drawLine .7s ease forwards}.living-network__label{font-family:var(--font-family);font-size:10px;font-weight:500;fill:var(--color-text-tertiary);pointer-events:none}.living-network__thumb{position:absolute;z-index:3;width:76px;background:#fff;border-radius:8px;padding:5px;box-shadow:0 2px 10px #00000014;border:1px solid rgba(0,0,0,.06);animation:thumbFloat 4s ease-in-out infinite;pointer-events:none}.living-network__thumb--tr{top:-14px;right:-24px;animation-delay:0s}.living-network__thumb--br{bottom:-10px;right:-20px;animation-delay:2s}.living-network__thumb-swatch{width:100%;height:32px;border-radius:4px;margin-bottom:3px}.living-network__thumb-swatch--beige{background:#e8ddd2}.living-network__thumb-swatch--mint{background:#d4e8d7}.living-network__thumb-label{display:block;font-family:var(--font-family);font-size:8px;color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(prefers-reduced-motion:reduce){.living-network__svg--drawn .living-network__line{animation:none;stroke-dashoffset:0}.living-network__node--pulse,.living-network__thumb{animation:none}}@media(max-width:640px){.living-network{max-width:300px}.living-network__thumb--tr{right:-12px}.living-network__thumb--bl{left:-12px}}@keyframes hero-fade-up{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes hero-visual-in{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.hero-section{background:linear-gradient(180deg,#e9f5ec,#fafbfa);padding-top:var(--space-20);padding-bottom:var(--space-20);overflow:visible}.hero-section__container{max-width:var(--container-max-width);margin:0 auto;padding:0 var(--container-padding-x)}@media(min-width:1024px){.hero-section__container{padding:0 var(--container-padding-x-lg)}}.hero-section__grid{display:grid;grid-template-columns:1fr;gap:var(--space-12);align-items:center}@media(min-width:1024px){.hero-section__grid{grid-template-columns:1fr 1fr;gap:var(--space-16)}}.hero-section__content{display:flex;flex-direction:column}@media(max-width:1023px){.hero-section__content{align-items:center;text-align:center}}.hero-section__animate{opacity:0;animation:hero-fade-up .65s ease forwards}.hero-section__animate--1{animation-delay:.05s}.hero-section__animate--2{animation-delay:.2s}.hero-section__animate--3{animation-delay:.35s}.hero-section__animate--4{animation-delay:.5s}.hero-section__animate--visual{animation:hero-visual-in .8s ease forwards;animation-delay:.3s}@media(prefers-reduced-motion:reduce){.hero-section__animate,.hero-section__animate--visual{animation:none;opacity:1;transform:none}}.hero-section__headline{font-size:48px;font-weight:800;line-height:1.1;letter-spacing:-.03em;color:var(--color-text-primary);margin:0;max-width:560px}.hero-section__headline-accent{color:var(--color-primary-text)}@media(max-width:1023px){.hero-section__headline{font-size:36px;max-width:100%}}@media(max-width:639px){.hero-section__headline{font-size:28px}}.hero-section__subtext{font-size:18px;color:var(--color-text-secondary);max-width:480px;margin:24px 0 32px;line-height:var(--line-height-body)}@media(max-width:1023px){.hero-section__subtext{max-width:480px}}@media(max-width:639px){.hero-section__subtext{font-size:16px}}.hero-section__actions{display:flex;gap:16px;flex-wrap:wrap;align-items:center}@media(max-width:1023px){.hero-section__actions{justify-content:center}}.hero-section__btn-primary{display:inline-flex;align-items:center;justify-content:center;padding:14px 32px;background-color:#2f7a3c;color:#fff;border-radius:12px;font-weight:600;font-size:16px;border:none;cursor:pointer;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease;white-space:nowrap}.hero-section__btn-primary:hover{background-color:#265f30;transform:translateY(-2px);box-shadow:0 6px 20px #2f7a3c4d}.hero-section__btn-primary:active{transform:translateY(0);box-shadow:none}.hero-section__btn-secondary{display:inline-flex;align-items:center;justify-content:center;padding:14px 32px;background:transparent;border:2px solid #45B35B;color:#2f7a3c;border-radius:12px;font-weight:600;font-size:16px;cursor:pointer;text-decoration:none;transition:transform .2s ease,background-color .2s ease,box-shadow .2s ease;white-space:nowrap}.hero-section__btn-secondary:hover{background-color:#45b35b14;transform:translateY(-2px);box-shadow:0 4px 12px #45b35b26}.hero-section__btn-secondary:active{transform:translateY(0);box-shadow:none}.hero-section__trust{display:flex;gap:12px;margin-top:32px;flex-wrap:wrap;align-items:center}@media(max-width:1023px){.hero-section__trust{justify-content:center}}.hero-section__chip{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:#45b35b14;border-radius:9999px;font-size:13px;color:var(--color-text-secondary);white-space:nowrap;line-height:1.4}.hero-section__chip svg{width:14px;height:14px;color:var(--color-primary);flex-shrink:0}.hero-section__visual{display:flex;align-items:center;justify-content:center}@media(max-width:1023px){.hero-section__visual{max-width:380px;margin:0 auto}}.stats-strip{background:var(--color-background-elevated);border-top:1px solid var(--color-border-subtle);border-bottom:1px solid var(--color-border-subtle);padding:48px 0}.stats-strip__inner{max-width:var(--container-max-width);margin:0 auto;padding:0 var(--container-padding-x);display:flex;justify-content:center;align-items:center;gap:64px;flex-wrap:wrap}@media(min-width:1024px){.stats-strip__inner{padding:0 var(--container-padding-x-lg);flex-wrap:nowrap}}@media(max-width:639px){.stats-strip__inner{display:grid;grid-template-columns:1fr 1fr;gap:32px;padding:0 var(--container-padding-x)}}.stats-strip__item{text-align:center;min-width:140px}.stats-strip__value{font-size:32px;font-weight:700;color:var(--color-primary-text);line-height:1.15;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.stats-strip__label{font-size:13px;color:var(--color-text-tertiary);margin-top:6px;line-height:1.4}.reveal.revealed,.activity-feed.revealed .activity-feed__card{opacity:1;transform:translateY(0)}@media(prefers-reduced-motion:reduce){.reveal,.activity-feed__card{opacity:1;transform:none;transition:none}}.activity-feed{padding:var(--section-padding-y) 0;background:var(--color-background)}.activity-feed__container{max-width:var(--container-max-width);margin:0 auto;padding:0 var(--container-padding-x)}@media(min-width:1024px){.activity-feed__container{padding:0 var(--container-padding-x-lg)}}.activity-feed__header{text-align:center;margin-bottom:32px}.activity-feed__heading{font-size:var(--font-size-h2);font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:var(--letter-spacing-tight);line-height:var(--line-height-heading);margin:0 0 12px}.activity-feed__subtitle{font-size:var(--font-size-body);color:var(--color-text-secondary);margin:0;line-height:var(--line-height-body)}.activity-feed__list{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:12px}.activity-feed__card{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--color-background-elevated);border-radius:12px;border:1px solid var(--color-border);transition:transform .2s ease,box-shadow .2s ease,opacity .6s ease}.activity-feed__card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.activity-feed__avatar{width:40px;height:40px;border-radius:50%;background:var(--color-primary-light);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:var(--color-primary-text);flex-shrink:0;overflow:hidden;position:relative}.activity-feed__avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%;position:absolute;inset:0}.activity-feed__avatar-fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:14px;font-weight:600;color:var(--color-primary-text)}.activity-feed__body{flex:1;min-width:0}.activity-feed__message{font-size:14px;color:var(--color-text-primary);line-height:1.4;margin:0;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.activity-feed__time{display:block;font-size:12px;color:var(--color-text-tertiary);margin-top:4px}.activity-feed__action{display:flex;align-items:center;gap:8px;flex-shrink:0}.activity-feed__icon{display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);line-height:0}.activity-feed__icon svg{width:16px;height:16px}.activity-feed__view{font-size:13px;color:var(--color-primary-text);font-weight:600;text-decoration:none;white-space:nowrap;transition:color .15s ease}.activity-feed__view:hover{text-decoration:underline;color:var(--color-primary)}@media(max-width:639px){.activity-feed__card{padding:12px 14px;gap:12px}.activity-feed__view{display:none}}.public-families{padding:80px 0;background:#f6f1e8}.public-families__header{text-align:center;margin-bottom:48px;padding:0 24px}.public-families__title{font-size:clamp(24px,4vw,34px);font-weight:700;color:var(--color-text-primary);margin:0 0 12px;letter-spacing:-.02em;line-height:1.15}.public-families__subtitle{font-size:16px;color:var(--color-text-secondary);max-width:520px;margin:0 auto;line-height:1.6}.public-families__grid{display:grid;grid-template-columns:1fr;gap:24px;max-width:1200px;margin:0 auto;padding:0 24px}@media(min-width:640px){.public-families__grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.public-families__grid{grid-template-columns:repeat(3,1fr)}}.public-families__card{background:var(--color-background-elevated);border-radius:12px;border:1px solid var(--color-border);overflow:hidden;transition:transform .2s ease,box-shadow .2s ease;height:100%;display:flex;flex-direction:column}.public-families__card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.public-families__cover{aspect-ratio:16 / 10;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;border-radius:12px 12px 0 0;overflow:hidden;flex-shrink:0;opacity:.85}.public-families__cover-img{width:100%;height:100%;object-fit:cover}.public-families__body{padding:20px;display:flex;flex-direction:column;flex:1}.public-families__name{font-size:16px;font-weight:600;color:var(--color-text-primary);margin:0 0 4px;line-height:1.3}.public-families__country{display:inline-block;font-size:11px;color:var(--color-text-tertiary);background:var(--color-background-subtle);padding:2px 8px;border-radius:9999px;margin-bottom:12px}.public-families__stats{display:flex;gap:16px;font-size:12px;color:var(--color-text-tertiary);margin-bottom:16px}.public-families__stat{display:flex;align-items:center;gap:4px}.public-families__stat svg{width:12px;height:12px;flex-shrink:0}.public-families__link{font-size:14px;font-weight:600;color:var(--color-primary-text);text-decoration:none;display:inline-flex;align-items:center;gap:4px;margin-top:auto;transition:color .2s ease}.public-families__link:hover{text-decoration:underline;color:var(--color-primary-hover)}.public-families__link svg{width:14px;height:14px;flex-shrink:0;transition:transform .2s ease}.public-families__link:hover svg{transform:translate(2px)}.public-families__coming-soon{display:inline-block;margin-top:6px;padding:4px 12px;font-size:13px;font-weight:600;color:#7a4a2f;background:#fef3c7;border-radius:20px;animation:comingSoonFadeIn .2s ease}@keyframes comingSoonFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.history-signals{padding:80px 0;background:var(--color-background-subtle)}.history-signals__header{text-align:center;margin-bottom:48px;padding:0 24px}.history-signals__title{font-size:clamp(24px,4vw,34px);font-weight:700;color:var(--color-text-primary);margin:0 0 12px;letter-spacing:-.02em;line-height:1.15}.history-signals__subtitle{font-size:16px;color:var(--color-text-secondary);max-width:520px;margin:0 auto;line-height:1.6}.history-signals__grid{display:grid;grid-template-columns:1fr;gap:48px;max-width:1100px;margin:0 auto;padding:0 24px;align-items:start}@media(min-width:768px){.history-signals__grid{grid-template-columns:1fr 1fr;gap:60px;align-items:start}}.history-signals .history-timeline{position:relative;padding:28px 24px 28px 48px;background:#f4f6f5;border-radius:12px;overflow:visible}.history-signals .history-timeline__line{position:absolute;left:23px;top:40px;bottom:40px;width:2px;background:linear-gradient(to bottom,#2e7a3c,#8fbf9c);border-radius:1px}.history-signals .history-timeline__item{position:relative;margin-bottom:50px;padding:10px 10px 10px 0;border-radius:8px;transition:background .2s ease;opacity:0;transform:translate(-10px)}.history-signals .history-timeline__item:last-child{margin-bottom:0}.history-signals .history-timeline__item:hover{background:#2e7a3c0a}.history-signals .history-timeline--visible .history-timeline__item{animation:timelineItemIn .45s ease forwards;animation-delay:calc(var(--i, 0) * .12s)}.history-signals .history-timeline--visible.history-timeline--instant .history-timeline__item{opacity:1;transform:none;animation:none}.history-signals .history-timeline__dot{position:absolute;left:-36px;top:0;width:22px;height:22px;border-radius:50%;background:var(--color-background-elevated);border:2px solid var(--color-primary);display:flex;align-items:center;justify-content:center;color:var(--color-primary-text);z-index:1;box-shadow:0 0 0 3px #f4f6f5}.history-signals .history-timeline__dot svg{width:10px;height:10px}.history-signals .history-timeline__year{font-size:13px;font-weight:700;color:var(--color-primary-text);margin:0 0 4px}.history-signals .history-timeline__event{font-size:15px;color:var(--color-text-primary);margin:0 0 2px;line-height:1.4}.history-signals .history-timeline__location{font-size:12px;color:var(--color-text-tertiary);margin:0}.history-records__title{font-size:18px;font-weight:600;color:var(--color-text-primary);margin:0 0 20px}.history-records__card{padding:16px 20px;background:var(--color-background-elevated);border-radius:10px;border:1px solid var(--color-border);border-left:3px solid var(--color-primary);margin-bottom:12px;transition:box-shadow .2s ease}.history-records__card:last-child{margin-bottom:0}.history-records__card:hover{box-shadow:var(--shadow-sm)}.history-records__type{font-size:12px;font-weight:600;color:var(--color-primary-text);text-transform:uppercase;letter-spacing:.05em;margin:0 0 4px}.history-records__name{font-size:15px;color:var(--color-text-primary);margin:0 0 8px;line-height:1.4}.history-records__meta{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--color-text-tertiary);flex-wrap:wrap}.history-records__badge{padding:2px 8px;border-radius:9999px;font-size:11px;font-weight:600;white-space:nowrap}.history-records__badge--verified{background:#dcfce7;color:#166534}.history-records__badge--probable{background:#fef9c3;color:#854d0e}@keyframes timelineItemIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@media(max-width:767px){.history-signals .history-timeline{padding:20px 16px 20px 44px}.history-signals .history-timeline__item{margin-bottom:36px}}.memory-strip{padding:80px 0;background:var(--color-background-elevated)}.memory-strip__header{text-align:center;margin-bottom:40px;padding:0 24px}.memory-strip__title-main{font-size:clamp(24px,4vw,34px);font-weight:700;color:var(--color-text-primary);margin:0 0 12px;letter-spacing:-.02em;line-height:1.15}.memory-strip__subtitle{font-size:16px;color:var(--color-text-secondary);max-width:520px;margin:0 auto;line-height:1.6}.memory-strip__wrapper{position:relative;max-width:1200px;margin:0 auto;padding:0 24px}.memory-strip__scroll{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;padding:8px 0 16px;scrollbar-width:none;-ms-overflow-style:none}.memory-strip__scroll::-webkit-scrollbar{display:none}.memory-strip__card{flex:0 0 180px;width:180px;min-width:180px;scroll-snap-align:start;background:var(--color-background-elevated);border-radius:12px;border:1px solid var(--color-border);overflow:hidden;transition:transform .2s ease,box-shadow .2s ease;cursor:pointer;display:flex;flex-direction:column;height:320px}.memory-strip__card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.memory-strip__thumb{position:relative;aspect-ratio:4 / 3;background:var(--color-background-subtle);flex-shrink:0}.memory-strip__thumb-img{width:100%;height:100%;object-fit:cover;position:absolute;top:0;left:0}.memory-strip__year{position:absolute;top:0;left:0;padding:4px 12px;background:#000000b3;color:#fff;font-size:12px;font-weight:700;border-radius:0 0 8px;line-height:1.4}.memory-strip__body{padding:14px;display:flex;flex-direction:column;flex:1}.memory-strip__title{font-size:14px;font-weight:600;color:var(--color-text-primary);margin:0 0 6px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.memory-strip__type{display:inline-block;font-size:11px;padding:2px 8px;border-radius:9999px;font-weight:600;margin-bottom:6px;width:fit-content}.memory-strip__type--Photo{background:#dcfce7;color:#166534}.memory-strip__type--Video{background:#dbeafe;color:#1e40af}.memory-strip__type--Document{background:#fef3c7;color:#92400e}.memory-strip__type--Story{background:#f3e8ff;color:#6b21a8}.memory-strip__excerpt{font-size:12px;color:var(--color-text-tertiary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin:0}.memory-strip__nav{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;background:var(--color-background-elevated);box-shadow:0 2px 8px #0000001f;border:1px solid var(--color-border);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:5;transition:background-color .2s ease,color .2s ease,box-shadow .2s ease;color:var(--color-text-primary);padding:0}.memory-strip__nav:hover{background:var(--color-primary);color:var(--color-text-inverse);box-shadow:0 4px 12px #00000029}.memory-strip__nav svg{width:16px;height:16px;flex-shrink:0}.memory-strip__nav--prev{left:0}.memory-strip__nav--next{right:0}@media(max-width:639px){.memory-strip__nav{display:none}.memory-strip__card{flex:0 0 160px;width:160px;min-width:160px;height:300px}}.connections-preview{padding:80px 0;background:var(--color-background-elevated)}.connections-preview__header{text-align:center;margin-bottom:48px;padding:0 24px}.connections-preview__title{font-size:clamp(24px,4vw,34px);font-weight:700;color:var(--color-text-primary);margin:0 0 12px;letter-spacing:-.02em;line-height:1.15}.connections-preview__subtitle{font-size:16px;color:var(--color-text-secondary);max-width:520px;margin:0 auto;line-height:1.6}.connections-preview__path{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;padding:32px 24px;background:var(--color-background-subtle);border-radius:16px;margin:0 auto 48px;max-width:700px}.connections-preview__path-segment{display:flex;align-items:center;gap:12px}.connections-preview__arrow-svg{width:20px;height:20px;color:var(--color-border-strong);flex-shrink:0}.connections-preview__node{display:flex;flex-direction:column;align-items:center;gap:6px}.connections-preview__avatar{width:48px;height:48px;border-radius:50%;background:var(--color-primary-light);border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:var(--color-primary-text);flex-shrink:0;overflow:hidden;transition:border-color .2s ease}.connections-preview__avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.connections-preview__avatar--lg{width:56px;height:56px;font-size:18px;margin:0 auto 10px}.connections-preview__avatar--highlight{background:var(--color-primary);color:var(--color-text-inverse);border-color:var(--color-primary)}.connections-preview__name{font-size:13px;font-weight:600;color:var(--color-text-primary);text-align:center;white-space:nowrap}.connections-preview__relation{font-size:11px;color:var(--color-text-tertiary);text-align:center}.connections-preview__relatives-title{font-size:18px;font-weight:600;color:var(--color-text-primary);text-align:center;margin:0 0 24px;padding:0 24px}.connections-preview__relatives{display:grid;grid-template-columns:1fr;gap:20px;max-width:900px;margin:0 auto;padding:0 24px}@media(min-width:640px){.connections-preview__relatives{grid-template-columns:repeat(3,1fr)}}.connections-preview__relative-card{padding:20px;background:var(--color-background-elevated);border-radius:12px;border:1px solid var(--color-border);text-align:center;transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column;align-items:center}.connections-preview__relative-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.connections-preview__relative-name{font-size:15px;font-weight:600;color:var(--color-text-primary);margin:0 0 4px}.connections-preview__hints{display:inline-block;padding:2px 10px;background:#dcfce7;color:#166534;border-radius:9999px;font-size:11px;font-weight:600;margin:8px 0}.connections-preview__reason{font-size:13px;color:var(--color-text-secondary);margin:0 0 4px;line-height:1.4}.connections-preview__location{font-size:12px;color:var(--color-text-tertiary);margin:0 0 12px;display:flex;align-items:center;justify-content:center;gap:4px}.connections-preview__location svg{width:12px;height:12px;flex-shrink:0}.connections-preview__explore-link{font-size:13px;font-weight:600;color:var(--color-primary-text);text-decoration:none;display:inline-flex;align-items:center;gap:3px;margin-top:auto;transition:color .2s ease}.connections-preview__explore-link:hover{text-decoration:underline;color:var(--color-primary-hover)}.connections-preview__explore-link svg{width:13px;height:13px;transition:transform .2s ease}.connections-preview__explore-link:hover svg{transform:translate(2px)}.connections-preview__cta{text-align:center;margin-top:40px;padding:0 24px}.connections-preview__cta-btn{display:inline-block;padding:14px 32px;background:var(--color-primary);color:var(--color-text-inverse);font-size:15px;font-weight:600;border-radius:var(--radius-lg);text-decoration:none;transition:background-color .2s ease,transform .2s ease,box-shadow .2s ease;box-shadow:var(--shadow-sm)}.connections-preview__cta-btn:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}@media(max-width:639px){.connections-preview__path{gap:8px;padding:24px 16px}.connections-preview__path-segment{gap:8px}.connections-preview__name{font-size:12px}}.feature-stories{padding:80px 0;background:var(--color-background)}.feature-stories__header{text-align:center;margin-bottom:64px;padding:0 24px}.feature-stories__eyebrow{font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-primary-text);margin-bottom:12px}.feature-stories__heading{font-size:32px;font-weight:800;color:var(--color-text-primary);line-height:1.15;margin-bottom:16px}.feature-stories__subtext{font-size:17px;color:var(--color-text-secondary);line-height:1.6;max-width:560px;margin:0 auto}.feature-stories__block{display:grid;grid-template-columns:1fr;gap:40px;align-items:center;margin-bottom:64px;max-width:1100px;margin-left:auto;margin-right:auto;padding:0 24px}.feature-stories__block:last-child{margin-bottom:0}@media(min-width:768px){.feature-stories__block{grid-template-columns:1fr 1fr;gap:48px;margin-bottom:80px}}.feature-stories__block--reversed .feature-stories__visual{order:1}.feature-stories__block--reversed .feature-stories__content{order:-1}@media(min-width:768px){.feature-stories__block--reversed .feature-stories__visual{order:2}.feature-stories__block--reversed .feature-stories__content{order:1}}.feature-stories__visual{aspect-ratio:4 / 3;border-radius:16px;overflow:hidden;position:relative}.feature-stories__visual-img{width:100%;height:100%;object-fit:cover;display:block}.feature-stories__content{max-width:480px}@media(max-width:767px){.feature-stories__content{max-width:100%}}.feature-stories__title{font-size:28px;font-weight:700;margin-bottom:12px;line-height:1.2;color:var(--color-text-primary)}.feature-stories__text{font-size:16px;color:var(--color-text-secondary);line-height:1.65;margin-bottom:24px}.feature-stories__bullets{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.feature-stories__bullet{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500;color:var(--color-text-secondary)}.feature-stories__bullet svg{width:18px;height:18px;color:var(--color-primary);flex-shrink:0}.mobile-teaser{padding:100px 0;background:#f4f6f5;position:relative;overflow:hidden}.mobile-teaser:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 70% 30%,rgba(69,179,91,.04) 0%,transparent 60%);pointer-events:none}.mobile-teaser__header{text-align:center;margin-bottom:64px;padding:0 24px;position:relative;z-index:1}.mobile-teaser__eyebrow{font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-primary-text);margin-bottom:12px}.mobile-teaser__heading{font-size:32px;font-weight:800;color:var(--color-text-primary);line-height:1.15;margin-bottom:16px}.mobile-teaser__subtext{font-size:17px;color:var(--color-text-secondary);line-height:1.6;max-width:560px;margin:0 auto}.mobile-teaser__grid{display:grid;grid-template-columns:1fr;gap:48px;max-width:1200px;margin:0 auto;padding:0 24px;align-items:center;position:relative;z-index:1}@media(min-width:768px){.mobile-teaser__grid{grid-template-columns:1fr 1fr;gap:60px}}.mobile-teaser__content{max-width:480px}@media(max-width:767px){.mobile-teaser__content{max-width:100%}}.mobile-teaser__features{list-style:none;margin:0 0 32px;padding:0;display:flex;flex-direction:column;gap:14px}.mobile-teaser__feature{display:flex;align-items:center;gap:12px;font-size:15px;font-weight:500;color:var(--color-text-secondary)}.mobile-teaser__feature svg{width:20px;height:20px;color:var(--color-primary);flex-shrink:0}.mobile-teaser__stores{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.mobile-teaser__store-btn{display:flex;align-items:center;gap:10px;padding:10px 20px;border-radius:10px;background:#1a1a1a;color:#fff;cursor:default;min-width:150px;border:none}.mobile-teaser__store-btn--disabled{opacity:.5}.mobile-teaser__store-btn svg{width:22px;height:22px;flex-shrink:0}.mobile-teaser__store-label{display:flex;flex-direction:column}.mobile-teaser__store-soon{font-size:10px;font-weight:500;letter-spacing:.04em;opacity:.8;text-transform:uppercase;line-height:1.3}.mobile-teaser__store-name{font-size:16px;font-weight:600;line-height:1.2}.mobile-teaser__notify-btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 36px;background:#2f7a3c;color:#fff;font-size:16px;font-weight:600;font-family:Inter,sans-serif;border:none;border-radius:10px;cursor:pointer;transition:background-color .2s ease,transform .2s ease}.mobile-teaser__notify-btn:hover{background:#45b35b;transform:translateY(-1px)}.mobile-teaser__notify-btn:active{transform:translateY(0)}.mobile-teaser__microcopy{font-size:13px;color:var(--color-text-tertiary);margin-top:12px}.mobile-teaser__visual{display:flex;justify-content:center;align-items:center}.mobile-teaser__phone{position:relative;width:260px;filter:drop-shadow(0 20px 40px rgba(0,0,0,.12));animation:mobilePhoneFloat 4s ease-in-out infinite}@keyframes mobilePhoneFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.mobile-teaser__phone-frame{width:260px;height:520px;background:#1a1a1a;border-radius:36px;padding:12px;position:relative;overflow:hidden}.mobile-teaser__phone-notch{position:absolute;top:12px;left:50%;transform:translate(-50%);width:100px;height:28px;background:#1a1a1a;border-radius:0 0 18px 18px;z-index:2}.mobile-teaser__phone-screen{width:100%;height:100%;background:#fff;border-radius:26px;overflow:hidden;display:flex;flex-direction:column}.mobile-teaser__phone-statusbar{display:flex;justify-content:space-between;align-items:center;padding:12px 20px 4px;font-size:13px;font-weight:600;color:#1a1a1a}.mobile-teaser__phone-statusbar-icons{display:flex;align-items:center;gap:5px}.mobile-teaser__signal{display:flex;align-items:flex-end;gap:1px;height:10px}.mobile-teaser__signal:before,.mobile-teaser__signal:after{content:"";display:block;width:2px;background:#1a1a1a;border-radius:1px}.mobile-teaser__signal:before{height:4px}.mobile-teaser__signal:after{height:7px}.mobile-teaser__wifi{width:10px;height:8px;border:2px solid #1A1A1A;border-radius:50% 50% 0 0;border-bottom:none}.mobile-teaser__battery{width:18px;height:9px;border:1.5px solid #1A1A1A;border-radius:2px;position:relative}.mobile-teaser__battery:before{content:"";position:absolute;inset:2px;background:#1a1a1a;border-radius:1px}.mobile-teaser__battery:after{content:"";position:absolute;right:-4px;top:2px;width:2px;height:4px;background:#1a1a1a;border-radius:0 1px 1px 0}.mobile-teaser__phone-app-header{padding:8px 20px 12px;font-size:18px;font-weight:700;color:#1a1a1a;border-bottom:1px solid #f0f0f0}.mobile-teaser__feed-item{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-bottom:1px solid #f5f5f5}.mobile-teaser__feed-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:600;flex-shrink:0}.mobile-teaser__feed-content{flex:1;min-width:0}.mobile-teaser__feed-text{font-size:12px;color:#4a4a4a;line-height:1.4;margin:0}.mobile-teaser__feed-text strong{color:#1a1a1a;font-weight:600}.mobile-teaser__feed-time{font-size:11px;color:#999;margin-top:2px;display:block}.mobile-teaser__beta-badge{position:absolute;top:-8px;right:-8px;background:var(--color-primary);color:#fff;font-size:11px;font-weight:700;padding:4px 12px;border-radius:9999px;letter-spacing:.04em;text-transform:uppercase;z-index:3;box-shadow:0 2px 8px #45b35b4d}.mobile-teaser__tagline{text-align:center;margin-top:56px;padding:0 24px;position:relative;z-index:1}.mobile-teaser__tagline p{font-size:17px;font-weight:500;color:var(--color-text-tertiary);font-style:italic;max-width:600px;margin:0 auto}@media(max-width:767px){.mobile-teaser{padding:72px 0}.mobile-teaser__heading{font-size:28px}.mobile-teaser__grid{gap:40px}.mobile-teaser__visual{order:-1}.mobile-teaser__phone-frame{width:220px;height:440px;border-radius:30px;padding:10px}.mobile-teaser__phone{width:220px}.mobile-teaser__phone-notch{width:80px;height:24px;top:10px;border-radius:0 0 14px 14px}.mobile-teaser__phone-screen{border-radius:22px}}@media(max-width:480px){.mobile-teaser__stores{flex-direction:column}.mobile-teaser__store-btn{min-width:auto}.mobile-teaser__phone-frame{width:200px;height:400px}.mobile-teaser__phone{width:200px}}.pricing-teaser{padding:80px 0;background:var(--color-background-subtle)}.pricing-teaser__header{text-align:center;margin-bottom:48px;padding:0 24px}.pricing-teaser__eyebrow{font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-primary-text);margin-bottom:12px}.pricing-teaser__heading{font-size:32px;font-weight:800;color:var(--color-text-primary);line-height:1.15;margin-bottom:12px}.pricing-teaser__subtext{font-size:16px;color:var(--color-text-secondary);line-height:1.6}.pricing-teaser__grid{display:grid;grid-template-columns:1fr;gap:24px;max-width:700px;margin:0 auto;padding:0 24px}@media(min-width:640px){.pricing-teaser__grid{grid-template-columns:1fr 1fr}}.pricing-teaser__card{background:#fff;border-radius:16px;padding:32px;border:1px solid var(--color-border);position:relative;transition:box-shadow .2s ease,transform .2s ease;display:flex;flex-direction:column}.pricing-teaser__card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.pricing-teaser__card--premium{border-top:3px solid var(--color-primary);box-shadow:0 4px 20px #00000014}.pricing-teaser__badge{position:absolute;top:-14px;left:50%;transform:translate(-50%);background:var(--color-primary);color:#fff;padding:4px 16px;border-radius:9999px;font-size:12px;font-weight:600;white-space:nowrap;letter-spacing:.02em}.pricing-teaser__name{font-size:20px;font-weight:700;color:var(--color-text-primary);margin-bottom:8px}.pricing-teaser__price{font-size:40px;font-weight:800;color:var(--color-text-primary);line-height:1;margin-bottom:0}.pricing-teaser__price span{font-size:16px;font-weight:400;color:var(--color-text-tertiary);margin-left:4px}.pricing-teaser__features{list-style:none;margin:24px 0;padding:0;display:flex;flex-direction:column;gap:10px}.pricing-teaser__features li{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--color-text-secondary);line-height:1.4}.pricing-teaser__features li svg{width:16px;height:16px;color:var(--color-primary);flex-shrink:0}.pricing-teaser__btn-primary,.pricing-teaser__btn-outline{display:block;width:100%;padding:12px 16px;border-radius:10px;margin-top:auto;font-size:15px;font-weight:600;text-align:center;text-decoration:none;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,color .2s ease,transform .2s ease;border:2px solid transparent}.pricing-teaser__btn-primary{background:#2f7a3c;color:#fff;border-color:#2f7a3c}.pricing-teaser__btn-primary:hover{background:#45b35b;border-color:#45b35b;transform:translateY(-1px)}.pricing-teaser__btn-outline{background:transparent;color:var(--color-text-primary);border-color:var(--color-border-strong)}.pricing-teaser__btn-outline:hover{border-color:var(--color-primary);color:var(--color-primary-text)}.pricing-teaser__compare{text-align:center;margin-top:24px;font-size:14px}.pricing-teaser__compare a{color:var(--color-primary-text);font-weight:600;text-decoration:none;transition:opacity .15s ease}.pricing-teaser__compare a:hover{opacity:.75;text-decoration:underline}.final-cta{padding:96px 0;background:linear-gradient(135deg,#2f7a3c,#1a5229);text-align:center;position:relative;overflow:hidden}.final-cta:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 20% 20%,rgba(255,255,255,.07) 0%,transparent 65%);pointer-events:none}.final-cta__bg-glow{position:absolute;bottom:-60px;right:-80px;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.04) 0%,transparent 70%);pointer-events:none}.final-cta__inner{position:relative;z-index:1;max-width:700px;margin:0 auto;padding:0 24px}.final-cta__headline{font-size:36px;font-weight:800;color:#fff;max-width:700px;margin:0 auto 16px;line-height:1.15;letter-spacing:-.01em}.final-cta__subtext{font-size:18px;color:#fffc;margin-bottom:40px;line-height:1.6}.final-cta__benefits{display:flex;justify-content:center;align-items:center;gap:40px;margin-bottom:40px;flex-wrap:wrap}.final-cta__benefit{display:flex;align-items:center;gap:8px;color:#ffffffe6;font-size:14px;font-weight:500}.final-cta__benefit svg{width:18px;height:18px;flex-shrink:0}.final-cta__btn{display:inline-flex;align-items:center;justify-content:center;padding:16px 40px;background:#fff;color:#2f7a3c;font-size:17px;font-weight:700;border-radius:12px;border:none;cursor:pointer;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease;outline-offset:3px;line-height:1}.final-cta__btn:hover{transform:translateY(-2px);box-shadow:0 10px 28px #00000038}.final-cta__btn:active{transform:translateY(0);box-shadow:none}.final-cta__btn:focus-visible{outline:2px solid #ffffff}.final-cta__note{font-size:13px;color:#fff9;margin-top:16px}.final-cta__legal{font-size:12px;color:#fff6;margin-top:32px}@media(max-width:639px){.final-cta{padding:72px 0}.final-cta__headline{font-size:28px}.final-cta__subtext{font-size:16px}.final-cta__benefits{flex-direction:column;align-items:center;gap:16px}.final-cta__btn{padding:14px 32px;font-size:16px}}.reveal-left{opacity:0;transform:translate(-24px);transition:opacity .6s ease,transform .6s ease}.reveal-left.revealed{opacity:1;transform:translate(0)}.reveal-right{opacity:0;transform:translate(24px);transition:opacity .6s ease,transform .6s ease}.reveal-right.revealed{opacity:1;transform:translate(0)}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.features-page{--features-cream: #F6F1E8;--features-beige: #F3EDE3;--features-bg: #F4F6F5;--features-cta-green: #2E7A3C;--features-cta-green-hover: #256B32}.features-hero{background-color:var(--features-cream);padding:var(--section-padding-y-lg) 0 var(--section-padding-y);text-align:center}.features-hero__inner{max-width:720px;margin:0 auto;padding:0 var(--container-padding-x)}.features-hero__headline{font-size:clamp(32px,5vw,48px);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:var(--line-height-heading);letter-spacing:var(--letter-spacing-tight);margin:0 0 var(--space-5)}.features-hero__subtext{font-size:18px;line-height:1.65;color:var(--color-text-secondary);max-width:580px;margin:0 auto var(--space-10)}.features-hero__search{display:flex;align-items:center;max-width:520px;margin:0 auto var(--space-8);background:var(--color-background-elevated);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-full);padding:var(--space-3) var(--space-4) var(--space-3) var(--space-6);box-shadow:var(--shadow-md);gap:var(--space-3)}.features-hero__search-icon{width:20px;height:20px;color:var(--color-text-tertiary);flex-shrink:0;display:flex;align-items:center}.features-hero__search-icon svg{width:20px;height:20px}.features-hero__search-input{flex:1;border:none;outline:none;background:transparent;font-size:16px;font-family:var(--font-family);color:var(--color-text-tertiary);pointer-events:none;text-align:left}.features-hero__trust{display:flex;justify-content:center;gap:var(--space-8);flex-wrap:wrap}.features-hero__trust-badge{display:flex;align-items:center;gap:var(--space-2);font-size:13px;font-weight:var(--font-weight-medium);color:var(--color-text-tertiary)}.features-hero__trust-badge:before{content:"";width:6px;height:6px;border-radius:50%;background-color:var(--color-primary);flex-shrink:0}.features-split{display:grid;grid-template-columns:1fr;gap:var(--space-12);align-items:center}@media(min-width:1024px){.features-split{grid-template-columns:1.1fr 1fr;gap:var(--space-16)}.features-split--reversed{grid-template-columns:1fr 1.1fr}.features-split--reversed .features-split__visual{order:1}}.features-split__visual{position:relative}.features-split__image{width:100%;height:400px;object-fit:cover;border-radius:var(--radius-2xl);display:block}@media(min-width:1024px){.features-split__image{height:480px}}.features-split__content{max-width:480px}.features-split__label{display:inline-block;padding:var(--space-1) var(--space-3);background-color:var(--color-primary-light);border-radius:var(--radius-full);margin-bottom:var(--space-4);letter-spacing:.12em;font-size:11px;font-weight:var(--font-weight-semibold);color:var(--color-primary);text-transform:uppercase}.features-split__title{margin-bottom:var(--space-5);letter-spacing:var(--letter-spacing-tight)}.features-split__body{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-8)}.features-split__body p{font-size:var(--font-size-body);line-height:1.7;color:var(--color-text-secondary)}.features-split__cta{display:flex;gap:var(--space-4);flex-wrap:wrap}.features-tree,.features-timeline{background-color:var(--features-bg)}.features-stories{background-color:var(--features-beige);padding:var(--section-padding-y) 0}.features-stories__header{text-align:center;max-width:600px;margin:0 auto var(--space-12)}.features-stories__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);max-width:1000px;margin:0 auto}.story-card{background:var(--color-background-elevated);border-radius:var(--radius-xl);overflow:hidden;border:var(--border-width) solid var(--color-border);transition:transform var(--transition-slow),box-shadow var(--transition-slow)}.story-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.story-card__image{width:100%;height:200px;object-fit:cover;display:block}.story-card__content{padding:var(--space-5) var(--space-5) var(--space-6)}.story-card__title{font-size:17px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-2);line-height:1.35}.story-card__excerpt{font-size:var(--font-size-small);line-height:1.6;color:var(--color-text-secondary);margin:0 0 var(--space-4)}.story-card__link{font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-primary);text-decoration:none;display:inline-flex;align-items:center;gap:var(--space-1);transition:color var(--transition-base);cursor:pointer}.story-card__link:hover{color:var(--color-primary-hover);text-decoration:underline}.timeline-preview{padding:var(--space-6);background:var(--color-background-elevated);border-radius:var(--radius-2xl);border:var(--border-width) solid var(--color-border);box-shadow:var(--shadow-sm)}.timeline-preview__heading{font-size:12px;font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-5)}.timeline-preview__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;position:relative}.timeline-preview__list:before{content:"";position:absolute;top:8px;bottom:8px;left:7px;width:2px;background-color:var(--color-border)}.timeline-preview__item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-2) 0;position:relative}.timeline-preview__dot{width:16px;height:16px;border-radius:50%;background:var(--color-background-elevated);border:2px solid var(--color-primary);flex-shrink:0;position:relative;z-index:1;margin-top:2px}.timeline-preview__dot--filled{background:var(--color-primary)}.timeline-preview__detail{flex:1}.timeline-preview__year{font-size:12px;font-weight:var(--font-weight-bold);color:var(--color-primary);margin-bottom:1px}.timeline-preview__event{font-size:14px;color:var(--color-text-secondary);line-height:1.4}.features-privacy__list{list-style:none;padding:0;margin:var(--space-2) 0 0;display:flex;flex-direction:column;gap:var(--space-4)}.features-privacy__list-item{display:flex;align-items:flex-start;gap:var(--space-3);font-size:var(--font-size-body);line-height:1.6;color:var(--color-text-secondary)}.features-privacy__list-item:before{content:"";width:8px;height:8px;border-radius:50%;background-color:var(--color-primary);flex-shrink:0;margin-top:7px}.features-growth{padding-top:var(--section-padding-y);padding-bottom:var(--section-padding-y)}.features-growth__header{text-align:center;max-width:600px;margin:0 auto var(--space-12)}.features-growth__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);max-width:900px;margin:0 auto}.growth-tile{background:var(--color-background-elevated);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8) var(--space-6);text-align:center;transition:transform var(--transition-slow),box-shadow var(--transition-slow),border-color var(--transition-slow)}.growth-tile:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--color-primary)}.growth-tile__icon{width:52px;height:52px;margin:0 auto var(--space-4);display:flex;align-items:center;justify-content:center;background:var(--color-primary-light);border-radius:var(--radius-lg);color:var(--color-primary)}.growth-tile__icon svg{width:24px;height:24px}.growth-tile__title{font-size:17px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-2);line-height:1.35}.growth-tile__description{font-size:var(--font-size-small);line-height:1.6;color:var(--color-text-secondary);margin:0}.features-cta{background-color:var(--features-cta-green);padding:var(--section-padding-y-lg) 0;text-align:center;position:relative;overflow:hidden}.features-cta:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 50% 0%,rgba(255,255,255,.06) 0%,transparent 60%);pointer-events:none}.features-cta__inner{position:relative;z-index:1;max-width:640px;margin:0 auto;padding:0 var(--container-padding-x)}.features-cta__headline{font-size:clamp(28px,5vw,36px);font-weight:var(--font-weight-bold);color:#fff;line-height:var(--line-height-heading);margin:0 0 var(--space-8)}.features-cta__actions{display:flex;justify-content:center;gap:var(--space-4);flex-wrap:wrap}.features-cta__btn-primary{display:inline-flex;align-items:center;justify-content:center;padding:16px 36px;background:#fff;color:var(--features-cta-green);font-size:16px;font-weight:var(--font-weight-bold);font-family:var(--font-family);border-radius:var(--radius-lg);border:none;cursor:pointer;text-decoration:none;transition:transform var(--transition-base),box-shadow var(--transition-base)}.features-cta__btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0003}.features-cta__btn-secondary{display:inline-flex;align-items:center;justify-content:center;padding:16px 36px;background:transparent;color:#fff;font-size:16px;font-weight:var(--font-weight-semibold);font-family:var(--font-family);border-radius:var(--radius-lg);border:2px solid rgba(255,255,255,.4);cursor:pointer;text-decoration:none;transition:border-color var(--transition-base),background-color var(--transition-base)}.features-cta__btn-secondary:hover{border-color:#fffc;background:#ffffff14}@media(max-width:1023px){.features-split__content{max-width:100%;text-align:center}.features-split__cta{justify-content:center}.features-split__body{text-align:left}.features-privacy__list{align-items:flex-start;max-width:400px;margin-left:auto;margin-right:auto}}@media(max-width:768px){.features-stories__grid{grid-template-columns:1fr;max-width:400px;margin-left:auto;margin-right:auto}.features-growth__grid{grid-template-columns:1fr;max-width:360px;margin-left:auto;margin-right:auto}.growth-tile{padding:var(--space-6) var(--space-5)}}@media(max-width:640px){.features-hero{padding:var(--space-16) 0 var(--space-12)}.features-hero__headline{font-size:30px}.features-hero__subtext{font-size:16px;margin-bottom:var(--space-8)}.features-hero__search{max-width:100%;padding:var(--space-2) var(--space-3) var(--space-2) var(--space-4)}.features-hero__search-input{font-size:14px}.features-hero__trust{flex-direction:column;align-items:center;gap:var(--space-3)}.features-split{gap:var(--space-8)}.features-split__image{height:260px}.story-card__image{height:160px}.features-cta{padding:var(--space-16) 0}.features-cta__headline{font-size:26px}.features-cta__actions{flex-direction:column;align-items:center}.features-cta__btn-primary,.features-cta__btn-secondary{width:100%;max-width:280px;justify-content:center}}.how-it-works-page{--hiw-primary: #2E7A3C;--hiw-primary-hover: #246832;--hiw-primary-light: #E8F3EC;--hiw-cream: #F6F1E8;--hiw-light-bg: #F4F6F5;--hiw-sage-bg: #EEF2EE;--hiw-text-primary: #1A1A1A;--hiw-text-secondary: #4A4A4A;--hiw-text-tertiary: #757575;--hiw-device-bezel: #1A1A1A;--hiw-device-screen: #111318;--hiw-glow-green: rgba(46, 122, 60, .35);--hiw-float-shadow: 0 8px 32px rgba(0, 0, 0, .12);min-height:100vh}.hiw-hero{background:var(--hiw-cream);padding-top:140px;padding-bottom:100px;position:relative;overflow:hidden}.hiw-hero__bg{position:absolute;inset:0;pointer-events:none;opacity:.06;background:radial-gradient(ellipse 70% 55% at 15% 35%,#2E7A3C 0%,transparent 70%),radial-gradient(ellipse 55% 70% at 85% 65%,#2E7A3C 0%,transparent 70%)}.hiw-hero__content{position:relative;max-width:720px;margin:0 auto;text-align:center}.hiw-hero__title{font-size:clamp(36px,6vw,56px);font-weight:700;line-height:1.15;color:var(--hiw-text-primary);letter-spacing:-.03em;margin:0}.hiw-hero__title-accent{color:var(--hiw-primary);display:block}.hiw-hero__subtitle{font-size:clamp(17px,2.2vw,20px);color:var(--hiw-text-secondary);line-height:1.6;max-width:580px;margin:var(--space-6) auto 0}.hiw-hero__cta-group{display:flex;justify-content:center;gap:var(--space-4);margin-top:var(--space-10);flex-wrap:wrap}.hiw-cta{display:inline-flex;align-items:center;gap:var(--space-2);font-size:15px;font-weight:600;border-radius:var(--radius-full);transition:all var(--transition-base);text-decoration:none;cursor:pointer;border:none;font-family:inherit}.hiw-cta--primary{background:var(--hiw-primary);color:#fff;padding:14px 32px}.hiw-cta--primary:hover{background:var(--hiw-primary-hover);transform:translateY(-2px);box-shadow:0 8px 24px #2e7a3c40}.hiw-cta--secondary{background:transparent;color:var(--hiw-primary);border:1.5px solid var(--hiw-primary);padding:13px 30px}.hiw-cta--secondary:hover{background:var(--hiw-primary-light)}.hiw-cta--large{padding:16px 36px;font-size:16px}.hiw-phase{padding:120px 0}.hiw-phase--cream{background:var(--hiw-cream)}.hiw-phase--light{background:var(--hiw-light-bg)}.hiw-phase__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-16);align-items:center;max-width:1100px;margin:0 auto;padding:0 var(--space-6)}.hiw-phase__image-col{display:flex;justify-content:center;align-items:center}.hiw-phase__text-col{display:flex;flex-direction:column;gap:var(--space-5)}.hiw-phase__label{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--hiw-primary);margin-bottom:var(--space-2)}.hiw-phase__title{font-size:clamp(28px,4vw,40px);font-weight:700;line-height:1.2;color:var(--hiw-text-primary);letter-spacing:-.02em;margin:0}.hiw-phase__description{font-size:16px;line-height:1.7;color:var(--hiw-text-secondary);margin:0}.hiw-phase__bullets{list-style:none;padding:0;margin:var(--space-4) 0 0;display:flex;flex-direction:column;gap:var(--space-4)}.hiw-phase__bullet-item{display:flex;align-items:center;gap:var(--space-3);font-size:15px;color:var(--hiw-text-secondary)}.hiw-phase__bullet-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);background:var(--hiw-primary-light);color:var(--hiw-primary);flex-shrink:0}.hiw-phase1-visual{position:relative;width:100%;max-width:480px;margin:0 auto}.hiw-phase1-visual__frame{position:relative;border-radius:20px;overflow:hidden;box-shadow:0 12px 40px #0000001a;aspect-ratio:4 / 3}.hiw-phase1-visual__image{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.05) brightness(1.02)}.hiw-phase1-visual__gradient{position:absolute;bottom:0;left:0;width:60%;height:50%;background:linear-gradient(135deg,rgba(246,241,232,.3) 0%,transparent 70%);pointer-events:none}.hiw-float-card{display:flex;align-items:center;gap:10px;background:#fff;border-radius:14px;padding:10px 16px;box-shadow:var(--hiw-float-shadow);animation:hiwFloatIn .6s ease-out both}.hiw-float-card__avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--hiw-primary-light)}.hiw-float-card__info{display:flex;flex-direction:column;gap:2px}.hiw-float-card__name{font-size:13px;font-weight:600;color:var(--hiw-text-primary);white-space:nowrap}.hiw-float-card__role{font-size:11px;color:var(--hiw-text-tertiary);white-space:nowrap}.hiw-phase1-visual__card{position:absolute;z-index:2}.hiw-phase1-visual__card:first-of-type{bottom:-16px;right:-12px;animation-delay:.3s}.hiw-phase1-visual__card--secondary{top:-12px;left:-12px;animation-delay:.6s}@keyframes hiwFloatIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.hiw-memory-types{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-4)}.hiw-memory-type{display:flex;align-items:center;gap:var(--space-2);padding:8px 16px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:14px;color:var(--hiw-text-secondary)}.hiw-memory-type svg{color:var(--hiw-primary)}.hiw-phase2-visual{position:relative;max-width:400px;margin:0 auto;padding:20px 0}.hiw-device-mockup{border-radius:24px;overflow:hidden;box-shadow:0 20px 60px #00000026;transform:perspective(800px) rotateY(-3deg);transition:transform .4s ease}.hiw-device-mockup:hover{transform:perspective(800px) rotateY(0)}.hiw-device-mockup__bezel{background:var(--hiw-device-bezel);border-radius:24px;padding:12px 12px 16px;position:relative}.hiw-device-mockup__notch{width:60px;height:4px;background:#333;border-radius:4px;margin:0 auto 10px}.hiw-device-mockup__screen{background:var(--hiw-device-screen);border-radius:12px;overflow:hidden;aspect-ratio:4 / 3}.hiw-device-mockup__gallery-main{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.05)}.hiw-phase2-visual__label{position:absolute;display:flex;align-items:center;gap:6px;background:#fff;border-radius:20px;padding:7px 14px;font-size:12px;font-weight:600;color:var(--hiw-text-secondary);box-shadow:var(--hiw-float-shadow);z-index:2;animation:hiwFloatIn .6s ease-out both}.hiw-phase2-visual__label svg{color:var(--hiw-primary)}.hiw-phase2-visual__label--photo{top:0;right:-20px;animation-delay:.2s}.hiw-phase2-visual__label--memory{bottom:40px;left:-24px;animation-delay:.5s}.hiw-phase2-visual__label--story{bottom:-8px;right:20px;animation-delay:.8s}.hiw-connections{padding:120px 0;text-align:center;background:var(--hiw-sage-bg);position:relative;overflow:hidden}.hiw-connections__content{max-width:640px;margin:0 auto var(--space-12);padding:0 var(--space-6)}.hiw-connections__label{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--hiw-primary);margin-bottom:var(--space-4)}.hiw-connections__title{font-size:clamp(28px,4vw,40px);font-weight:700;line-height:1.2;color:var(--hiw-text-primary);letter-spacing:-.02em;margin:0}.hiw-connections__description{font-size:17px;line-height:1.7;color:var(--hiw-text-secondary);max-width:520px;margin:var(--space-4) auto 0}.hiw-connections__footer{margin-top:var(--space-12);display:flex;justify-content:center}.hiw-phase3-visual{max-width:680px;margin:0 auto;padding:var(--space-8) 0}.hiw-phase3-device{border-radius:28px;overflow:hidden;box-shadow:0 24px 80px #0000002e,0 0 0 1px #ffffff0d inset}.hiw-phase3-device__bezel{background:var(--hiw-device-bezel);border-radius:28px;padding:14px 14px 18px}.hiw-phase3-device__screen{background:var(--hiw-device-screen);border-radius:14px;overflow:hidden;position:relative;aspect-ratio:16 / 10}.hiw-phase3-device__screenshot{width:100%;height:100%;object-fit:cover;display:block}.hiw-phase3-device__glow-overlay{position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle 120px at 30% 40%,var(--hiw-glow-green),transparent),radial-gradient(circle 100px at 70% 60%,var(--hiw-glow-green),transparent);opacity:0;animation:hiwGlowPulse 4s ease-in-out infinite}@keyframes hiwGlowPulse{0%,to{opacity:0}50%{opacity:.4}}.hiw-family-cards-preview{display:flex;gap:var(--space-4);max-width:360px;margin:0 auto}.hiw-family-card-mock{background:#fff;border-radius:16px;padding:24px 20px;box-shadow:0 4px 20px #0000000f;border:1px solid var(--color-border);display:flex;flex-direction:column;align-items:center;gap:12px;min-width:150px}.hiw-family-card-mock--offset{transform:translateY(24px)}.hiw-family-card-mock__avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--hiw-primary-light) 0%,#d4eeda 100%)}.hiw-family-card-mock__name{height:12px;width:80px;background:#e0e0e0;border-radius:6px}.hiw-family-card-mock__members{height:10px;width:60px;background:#eee;border-radius:6px}.hiw-family-card-mock--enhanced{position:relative;transition:transform .4s ease,box-shadow .4s ease}.hiw-family-card-mock--enhanced:hover{transform:translateY(-4px);box-shadow:0 8px 32px #0000001a}.hiw-family-card-mock--enhanced.hiw-family-card-mock--offset:hover{transform:translateY(20px)}.hiw-family-card-mock__badge{display:flex;align-items:center;gap:4px;font-size:10px;font-weight:600;color:var(--hiw-primary);background:var(--hiw-primary-light);border-radius:20px;padding:4px 10px;margin-top:4px}.hiw-family-card-mock__badge svg{width:12px;height:12px}.hiw-family-card-mock__badge--public{color:#6366f1;background:#eef2ff}.hiw-family-card-mock__badge--public svg{color:#6366f1}.hiw-elder{padding:120px 0;background:var(--hiw-light-bg)}.hiw-elder__card{background:var(--hiw-cream);border-radius:var(--radius-2xl);padding:var(--space-16);max-width:1000px;margin:0 auto;box-shadow:0 4px 24px #0000000a}.hiw-elder__content{display:grid;grid-template-columns:1.3fr 1fr;gap:var(--space-12);align-items:center}.hiw-elder__title{font-size:clamp(26px,4vw,36px);font-weight:700;line-height:1.2;color:var(--hiw-text-primary);margin:0 0 var(--space-4) 0}.hiw-elder__description{font-size:16px;line-height:1.7;color:var(--hiw-text-secondary);margin:0 0 var(--space-6) 0}.hiw-elder__bullets{list-style:none;padding:0;margin:0 0 var(--space-8) 0;display:flex;flex-direction:column;gap:var(--space-4)}.hiw-elder__bullets li{display:flex;align-items:center;gap:var(--space-3);font-size:15px;color:var(--hiw-text-secondary)}.hiw-elder__bullets li svg{color:var(--hiw-primary);flex-shrink:0}.hiw-elder__image{position:relative;display:flex;align-items:center;justify-content:center}.hiw-elder__image-frame{width:300px;height:300px;border-radius:24px;overflow:hidden;box-shadow:0 12px 40px #0000001a}.hiw-elder__image-photo{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.05) brightness(1.02) sepia(.05)}.hiw-elder__badge{position:absolute;bottom:-10px;right:-10px;display:flex;align-items:center;gap:6px;background:#fff;border-radius:20px;padding:8px 16px;font-size:12px;font-weight:600;color:var(--hiw-text-secondary);box-shadow:var(--hiw-float-shadow);animation:hiwFloatIn .6s ease-out .4s both}.hiw-elder__badge svg{color:var(--hiw-primary)}.hiw-faq{padding:100px 0;background:#fff}.hiw-faq__header{margin-bottom:var(--space-10);text-align:center}.hiw-faq__title{font-size:clamp(28px,5vw,40px);font-weight:700;color:var(--hiw-text-primary);letter-spacing:-.02em;margin:0}.hiw-faq__list{max-width:700px;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-3);padding:0 var(--space-6)}.hiw-faq__item{background:var(--hiw-light-bg);border:1px solid transparent;border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base)}.hiw-faq__item:hover{border-color:var(--color-border)}.hiw-faq__item--open{border-color:var(--hiw-primary);background:#fff;box-shadow:0 4px 16px #2e7a3c14}.hiw-faq__question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:20px 24px;background:transparent;border:none;cursor:pointer;text-align:left;font-family:inherit;font-size:15px;font-weight:500;color:var(--hiw-text-primary);transition:color var(--transition-base)}.hiw-faq__question:hover{color:var(--hiw-primary)}.hiw-faq__chevron{width:20px;height:20px;flex-shrink:0;color:var(--hiw-text-tertiary);transition:transform var(--transition-base)}.hiw-faq__chevron--open{transform:rotate(180deg);color:var(--hiw-primary)}.hiw-faq__answer{max-height:0;overflow:hidden;transition:max-height .3s ease}.hiw-faq__item--open .hiw-faq__answer{max-height:300px}.hiw-faq__answer p{padding:0 24px 20px;margin:0;color:var(--hiw-text-secondary);font-size:15px;line-height:1.6}.hiw-final-cta{padding:120px 0;background:var(--hiw-cream)}.hiw-final-cta__content{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:560px;margin:0 auto;gap:var(--space-6);padding:0 var(--space-6)}.hiw-final-cta__title{font-size:clamp(28px,5vw,40px);font-weight:700;color:var(--hiw-text-primary);letter-spacing:-.02em;line-height:1.2;margin:0}.hiw-final-cta__subtitle{font-size:clamp(17px,2.5vw,20px);color:var(--hiw-text-secondary);line-height:1.5;margin:0}.hiw-final-cta__microtext{color:var(--hiw-text-tertiary);font-size:13px;margin:0}@media(max-width:900px){.hiw-phase__grid,.hiw-elder__content{grid-template-columns:1fr;gap:var(--space-10)}.hiw-phase__grid--reversed .hiw-phase__image-col{order:-1}.hiw-phase,.hiw-connections,.hiw-elder{padding:80px 0}.hiw-elder__card{padding:var(--space-10)}.hiw-elder__image{order:-1}.hiw-phase1-visual{max-width:380px}.hiw-phase1-visual__card:first-of-type{bottom:-12px;right:0}.hiw-phase1-visual__card--secondary{top:-10px;left:0}.hiw-device-mockup{transform:none}.hiw-phase2-visual__label--photo{right:-8px}.hiw-phase2-visual__label--memory{left:-8px}.hiw-phase3-visual{max-width:520px}.hiw-elder__image-frame{width:220px;height:220px}}@media(max-width:640px){.hiw-hero{padding-top:110px;padding-bottom:60px}.hiw-hero__cta-group{flex-direction:column;align-items:center}.hiw-phase,.hiw-connections,.hiw-elder{padding:60px 0}.hiw-elder__card{padding:var(--space-8);border-radius:var(--radius-xl)}.hiw-faq{padding:60px 0}.hiw-final-cta{padding:80px 0}.hiw-phase1-visual{max-width:320px}.hiw-phase1-visual__card--secondary{display:none}.hiw-float-card{padding:8px 12px}.hiw-float-card__avatar{width:28px;height:28px}.hiw-float-card__name{font-size:12px}.hiw-float-card__role{font-size:10px}.hiw-phase2-visual{max-width:300px}.hiw-phase2-visual__label{font-size:11px;padding:5px 10px}.hiw-phase2-visual__label--photo{right:-6px}.hiw-phase2-visual__label--memory{left:-6px}.hiw-phase2-visual__label--story{right:10px;bottom:-4px}.hiw-device-mockup{border-radius:18px}.hiw-device-mockup__bezel{border-radius:18px;padding:8px 8px 12px}.hiw-phase3-visual{max-width:100%}.hiw-phase3-device{border-radius:18px}.hiw-phase3-device__bezel{border-radius:18px;padding:10px 10px 14px}.hiw-family-cards-preview{flex-direction:column;align-items:center}.hiw-family-card-mock--offset{transform:none}.hiw-family-card-mock--enhanced.hiw-family-card-mock--offset:hover{transform:translateY(-4px)}.hiw-elder__image-frame{width:180px;height:180px;border-radius:18px}.hiw-elder__badge{bottom:-6px;right:-6px;padding:6px 12px;font-size:11px}}.pricing-page{min-height:100vh;background-color:var(--color-background);--pricing-green: #2e7a3c;--pricing-green-light: #e8f3ec;--pricing-green-hover: #256832;--pricing-beige: #f6f1e8;--pricing-beige-dark: #f3ede3;--pricing-cool-bg: #f4f6f5}.pricing-hero,.pricing-intro{background-color:var(--pricing-beige);padding:100px 0 60px;text-align:center}.pricing-hero__content,.pricing-hero__inner,.pricing-intro__content{max-width:600px;margin:0 auto}.pricing-hero__headline,.pricing-hero__title,.pricing-intro__title{font-size:clamp(36px,5vw,52px);font-weight:var(--font-weight-bold);letter-spacing:-.03em;line-height:1.15;color:var(--color-text-primary);margin-bottom:20px}.pricing-hero__subtitle,.pricing-intro__subtitle{font-size:18px;color:var(--color-text-secondary);max-width:500px;margin:0 auto 40px;line-height:1.6}.pricing-hero__toggle{display:flex;justify-content:center;margin-bottom:20px}.pricing-hero__trust{font-size:13px;color:var(--color-text-tertiary);margin-top:16px}.pricing-tiers__toggle-wrapper{display:flex;justify-content:center;margin-bottom:40px}.billing-toggle{display:inline-flex;align-items:center;background:#edeae6;border:none;border-radius:var(--radius-full);padding:4px;gap:0}.billing-toggle__option{position:relative;z-index:2;display:inline-flex;align-items:center;gap:var(--space-2);padding:10px 24px;font-size:15px;font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:transparent;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;line-height:1}.billing-toggle__option:hover{color:var(--color-text-primary)}.billing-toggle__option--active{background:#fff;color:var(--pricing-green);box-shadow:0 2px 8px #00000014;font-weight:var(--font-weight-semibold)}.billing-toggle__option:focus-visible{outline:2px solid var(--pricing-green);outline-offset:2px}.billing-toggle__badge{display:inline-block;background:var(--pricing-green);color:#fff;font-size:11px;font-weight:var(--font-weight-semibold);padding:2px 8px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.02em;margin-left:6px;line-height:1.6}.billing-toggle__slider{display:none}.pricing-cards,.pricing-tiers{padding:80px 0 100px;background:var(--color-background)}.pricing-cards__grid,.pricing-tiers__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;max-width:1060px;margin:0 auto;align-items:start}.pricing-tiers__footnote,.pricing-cards__footnote{margin-top:var(--space-8);font-style:italic;text-align:center}.pricing-card{background:#fff;border:1px solid var(--color-border);border-radius:20px;padding:40px 32px;position:relative;transition:all var(--transition-slow);display:flex;flex-direction:column}.pricing-card:hover{box-shadow:0 12px 40px #00000014;transform:translateY(-4px);border-color:var(--color-border-strong)}.pricing-card--popular,.pricing-card--highlighted{border:2px solid var(--pricing-green);transform:scale(1.04);box-shadow:0 16px 48px #2e7a3c1f;z-index:2}.pricing-card--popular:hover,.pricing-card--highlighted:hover{transform:scale(1.04) translateY(-4px);box-shadow:0 20px 56px #2e7a3c2e;border-color:var(--pricing-green)}.pricing-card__badge{position:absolute;top:-14px;left:50%;transform:translate(-50%);background:var(--pricing-green);color:#fff;font-size:13px;font-weight:var(--font-weight-semibold);padding:6px 20px;border-radius:var(--radius-full);white-space:nowrap;letter-spacing:.02em}.pricing-card__header{padding-bottom:var(--space-6);margin-bottom:var(--space-6)}.pricing-card__name{font-size:22px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:4px;display:block}.pricing-card__tagline,.pricing-card__description{font-size:14px;color:var(--color-text-tertiary);margin-bottom:24px;display:block}.pricing-card__price-wrapper{display:flex;align-items:baseline;gap:2px;margin-bottom:8px}.pricing-card__price{font-size:48px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:-.03em;line-height:1;transition:all .4s ease}.pricing-card__period{font-size:16px;color:var(--color-text-tertiary);font-weight:var(--font-weight-regular)}.pricing-card__savings{font-size:13px;color:var(--pricing-green);font-weight:var(--font-weight-medium);margin-bottom:28px;min-height:20px;opacity:0;transform:translateY(-4px);transition:all .3s ease}.pricing-card__savings--visible{opacity:1;transform:translateY(0)}.pricing-card__divider{width:100%;height:1px;background:var(--color-border);margin:0 0 28px;border:none}.pricing-card__features{list-style:none;padding:0;margin:0 0 32px;display:flex;flex-direction:column;gap:14px;flex:1}.pricing-card__features li,.pricing-card__feature{display:flex;align-items:flex-start;gap:12px}.pricing-card__check,.pricing-card__feature-icon{flex-shrink:0;width:20px;height:20px;color:var(--pricing-green);margin-top:2px}.pricing-card__check svg,.pricing-card__feature-icon svg{width:100%;height:100%}.pricing-card__features li p,.pricing-card__feature-text{font-size:15px;color:var(--color-text-secondary);line-height:1.4;margin:0}.pricing-card__cta,.pricing-card__footer{margin-top:auto}.pricing-card__cta .button--secondary,.pricing-card__footer .button--secondary{border-color:var(--pricing-green);color:var(--pricing-green)}.pricing-card__cta .button--secondary:hover,.pricing-card__footer .button--secondary:hover{background:var(--pricing-green-light);border-color:var(--pricing-green);color:var(--pricing-green)}.pricing-card__cta .button--primary,.pricing-card__footer .button--primary{background:var(--pricing-green);border-color:var(--pricing-green);color:#fff}.pricing-card__cta .button--primary:hover,.pricing-card__footer .button--primary:hover{background:var(--pricing-green-hover);border-color:var(--pricing-green-hover);transform:translateY(-2px)}.pricing-compare,.pricing-comparison{padding:100px 0;background:var(--color-background)}.pricing-compare h2,.pricing-comparison h2{margin-bottom:48px}.pricing-compare__table-wrapper,.comparison-table-wrapper{overflow-x:auto;border-radius:16px;border:1px solid var(--color-border);background:#fff;margin-top:32px}.pricing-compare__table,.comparison-table{width:100%;border-collapse:collapse;min-width:640px}.pricing-compare__table thead th,.comparison-table th{padding:18px 24px;font-size:14px;font-weight:var(--font-weight-semibold);text-align:center;background:var(--color-background-subtle);border-bottom:2px solid var(--color-border);position:sticky;top:0;z-index:1}.pricing-compare__table thead th:first-child,.comparison-table th:first-child{text-align:left}.pricing-compare__col--popular,.comparison-table__popular{color:var(--pricing-green)!important;background:var(--pricing-green-light)!important}.pricing-compare__table tbody td,.comparison-table td{padding:16px 24px;text-align:center;font-size:14px;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border-subtle)}.pricing-compare__table tbody td:first-child,.comparison-table td:first-child{text-align:left;font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.pricing-compare__table tbody tr:last-child td,.comparison-table tbody tr:last-child td{border-bottom:none}.pricing-compare__table tbody td:nth-child(3),.comparison-table tbody td:nth-child(3){background:#e8f3ec66}.pricing-compare__table tbody tr:nth-child(2n) td,.comparison-table tbody tr:nth-child(2n) td{background-color:var(--color-background-subtle)}.pricing-compare__table tbody tr:nth-child(2n) td:nth-child(3),.comparison-table tbody tr:nth-child(2n) td:nth-child(3){background-color:#e8f3ec80}.pricing-compare__table tbody tr:hover td,.comparison-table tbody tr:hover td{background-color:var(--color-background-muted)}.pricing-compare__table tbody tr:hover td:nth-child(3),.comparison-table tbody tr:hover td:nth-child(3){background-color:#e8f3ecb3}.comparison-check,.check-icon{color:var(--pricing-green);width:20px;height:20px;display:block;margin:0 auto}.comparison-x,.x-icon{color:var(--color-text-tertiary);width:20px;height:20px;display:block;margin:0 auto;opacity:.4}.comparison-table svg{width:18px;height:18px;display:block;margin:0 auto}.pricing-gift-section,.pricing-gift{padding:100px 0;background:var(--pricing-beige-dark)}.pricing-gift-section__content,.pricing-gift__inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;max-width:1000px;margin:0 auto}.pricing-gift-section__image,.pricing-gift__image{aspect-ratio:4 / 3;border-radius:20px;background:linear-gradient(135deg,#e8dfd3,#d4c9bb);display:flex;align-items:center;justify-content:center;overflow:hidden}.pricing-gift-section__image svg,.pricing-gift-section__image-icon,.pricing-gift__image svg,.pricing-gift__image-icon{color:#0000001a;width:80px;height:80px}.pricing-gift-section__text,.pricing-gift__content{padding:0}.pricing-gift-section__headline,.pricing-gift__title{font-size:clamp(28px,4vw,36px);font-weight:var(--font-weight-bold);line-height:1.2;color:var(--color-text-primary);margin-bottom:16px}.pricing-gift-section__body,.pricing-gift__body{font-size:16px;color:var(--color-text-secondary);line-height:1.7;margin-bottom:32px}.pricing-gift-section__benefits,.pricing-gift__benefits{display:flex;flex-direction:column;gap:16px;margin-bottom:36px}.pricing-gift-section__benefit,.pricing-gift__benefit{display:flex;align-items:center;gap:12px}.pricing-gift-section__benefit-icon,.pricing-gift__benefit-icon{width:36px;height:36px;border-radius:50%;background:var(--pricing-green-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}.pricing-gift-section__benefit-icon svg,.pricing-gift__benefit-icon svg{width:18px;height:18px;color:var(--pricing-green)}.pricing-gift-section__benefit-text{font-size:15px;color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.pricing-gift-section__cta .button--secondary,.pricing-gift-section .button--secondary,.pricing-gift__content .button--secondary{border-color:var(--pricing-green);color:var(--pricing-green)}.pricing-gift-section__cta .button--secondary:hover,.pricing-gift-section .button--secondary:hover,.pricing-gift__content .button--secondary:hover{background:var(--pricing-green-light);border-color:var(--pricing-green)}.gift-plan-section{max-width:900px;margin:0 auto}.gift-plan-section__content{display:grid;grid-template-columns:auto 1fr auto;gap:var(--space-8);align-items:center;background:linear-gradient(135deg,rgba(46,122,60,.04) 0%,var(--color-background-elevated) 50%,rgba(46,122,60,.02) 100%);border:2px solid var(--pricing-green-light);border-radius:var(--radius-2xl);padding:var(--space-10);position:relative;overflow:hidden}.gift-plan-section__content:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--pricing-green) 0%,#6abf7a 50%,var(--pricing-green) 100%)}.gift-plan-section__icon-wrapper{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:var(--pricing-green);border-radius:var(--radius-xl);color:#fff;flex-shrink:0}.gift-plan-section__icon-wrapper svg{width:40px;height:40px}.gift-plan-section__text{min-width:0}.gift-plan-section__title{font-size:clamp(20px,3vw,26px);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-3) 0}.gift-plan-section__description{color:var(--color-text-secondary);line-height:1.6;margin:0 0 var(--space-5) 0}.gift-plan-section__features{display:flex;flex-wrap:wrap;gap:var(--space-4)}.gift-plan-section__feature{display:flex;align-items:center;gap:var(--space-2)}.gift-plan-section__feature-icon{width:20px;height:20px;color:var(--pricing-green);display:flex;align-items:center;justify-content:center}.gift-plan-section__feature-icon svg{width:100%;height:100%}.gift-plan-section__feature p{color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.gift-plan-section__action{flex-shrink:0}.gift-plan-section__action button,.gift-plan-section__action a{display:inline-flex;align-items:center;gap:var(--space-2);white-space:nowrap}.gift-plan-section__action svg{width:20px;height:20px}.pricing-referrals-section,.pricing-referrals{padding:100px 0;background:var(--pricing-cool-bg)}.pricing-referrals-section__content,.pricing-referrals__inner{display:flex;align-items:center;gap:60px;max-width:900px;margin:0 auto}.pricing-referrals-section__illustration,.pricing-referrals__illustration{width:200px;height:200px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.pricing-referrals-section__illustration svg,.pricing-referrals__illustration svg,.pricing-referrals__svg{width:100%;height:100%}.pricing-referrals-section__text,.pricing-referrals__content{flex:1}.pricing-referrals-section__headline,.pricing-referrals__title{font-size:28px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:8px}.pricing-referrals-section__subtitle,.pricing-referrals__body{font-size:16px;color:var(--color-text-secondary);line-height:1.6;margin-bottom:24px}.pricing-referrals-section__note,.pricing-referrals__note{font-size:13px;color:var(--color-text-tertiary);margin-top:12px}.pricing-referrals-section__cta .button--secondary,.pricing-referrals .button--secondary,.pricing-referrals__content .button--secondary{border-color:var(--pricing-green);color:var(--pricing-green)}.pricing-referrals-section__cta .button--secondary:hover,.pricing-referrals .button--secondary:hover,.pricing-referrals__content .button--secondary:hover{background:var(--pricing-green-light);border-color:var(--pricing-green)}.referrals-callout__content{background:var(--color-background-elevated);border:2px dashed var(--pricing-green-light);border-radius:var(--radius-2xl);padding:var(--space-8) var(--space-10);display:flex;align-items:center;justify-content:space-between;gap:var(--space-8);transition:all var(--transition-base)}.referrals-callout__content:hover{border-color:var(--pricing-green);background:linear-gradient(135deg,rgba(46,122,60,.03) 0%,var(--color-background-elevated) 100%)}.referrals-callout__text{flex:1}.referrals-callout__label{margin-bottom:var(--space-1);display:block;font-size:12px;font-weight:var(--font-weight-semibold);letter-spacing:.06em;text-transform:uppercase;color:var(--pricing-green)}.referrals-callout__title{margin-bottom:var(--space-2);font-size:20px;font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.referrals-callout__description{color:var(--color-text-secondary);line-height:1.6}.referrals-callout__action{flex-shrink:0}.referrals-callout__action .button--secondary{border-color:var(--pricing-green);color:var(--pricing-green)}.referrals-callout__action .button--secondary:hover{background:var(--pricing-green-light)}.pricing-faq{padding:100px 0;background:var(--color-background-subtle)}.pricing-faq__header{margin-bottom:48px}.pricing-faq__subtitle{margin-top:12px;color:var(--color-text-secondary)}.pricing-faq__list{max-width:700px;margin:0 auto;display:flex;flex-direction:column;gap:12px;list-style:none;padding:0}.faq-item{background:#fff;border:1px solid var(--color-border);border-radius:12px;overflow:hidden;transition:all var(--transition-base)}.faq-item:hover{border-color:var(--color-border-strong)}.faq-item--open{border-color:var(--pricing-green)}.faq-item__question{width:100%;display:flex;align-items:center;justify-content:space-between;padding:20px 24px;text-align:left;font-size:15px;font-weight:var(--font-weight-medium);color:var(--color-text-primary);cursor:pointer;border:none;background:transparent;transition:background-color var(--transition-base);line-height:1.4}.faq-item__question:hover{background-color:var(--color-background-subtle)}.faq-item__icon{flex-shrink:0;width:24px;height:24px;color:var(--color-text-tertiary);transition:transform var(--transition-base);margin-left:var(--space-4)}.faq-item__icon svg{width:100%;height:100%}.faq-item--open .faq-item__icon{transform:rotate(180deg);color:var(--pricing-green)}.faq-item__answer{max-height:0;overflow:hidden;transition:max-height .3s ease}.faq-item--open .faq-item__answer{max-height:300px}.faq-item__answer p,.faq-item__answer>*{padding:0 24px 20px;margin:0;color:var(--color-text-secondary);font-size:15px;line-height:1.6}.pricing-final-cta,.pricing-cta{padding:100px 0;background:var(--pricing-green);text-align:center}.pricing-final-cta__headline,.pricing-final-cta__heading,.pricing-cta__content h2{color:#fff;font-size:clamp(28px,4vw,40px);font-weight:var(--font-weight-bold);line-height:1.2;max-width:600px;margin:0 auto 40px}.pricing-final-cta__inner{text-align:center;max-width:600px;margin:0 auto}.pricing-final-cta__btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 32px;font-size:15px;font-weight:var(--font-weight-semibold);border-radius:var(--radius-lg);border:2px solid transparent;cursor:pointer;text-decoration:none;transition:all var(--transition-base);line-height:1}.pricing-final-cta__btn--primary{background:#fff;color:var(--pricing-green);border-color:#fff}.pricing-final-cta__btn--primary:hover{background:#ffffffe6;border-color:#ffffffe6;transform:translateY(-2px)}.pricing-final-cta__btn--ghost{background:transparent;color:#fff;border-color:#fff6}.pricing-final-cta__btn--ghost:hover{background:#ffffff1a;border-color:#fff;transform:translateY(-2px)}.pricing-final-cta__btn-icon{display:inline-flex;width:20px;height:20px}.pricing-final-cta__btn-icon svg{width:100%;height:100%}.pricing-cta__content{text-align:center;max-width:550px;margin:0 auto}.pricing-cta__text{color:#ffffffd9;margin-bottom:var(--space-8)}.pricing-final-cta__actions,.pricing-cta__actions{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-bottom:var(--space-6)}.pricing-cta__actions button,.pricing-cta__actions a{display:inline-flex;align-items:center;gap:var(--space-2)}.pricing-cta__actions svg{width:20px;height:20px}.pricing-cta__note{color:#ffffffb3;font-size:13px}.pricing-final-cta .button--primary,.pricing-cta .button--primary{background:#fff;color:var(--pricing-green);border-color:#fff}.pricing-final-cta .button--primary:hover,.pricing-cta .button--primary:hover{background:#ffffffe6;border-color:#ffffffe6;transform:translateY(-2px)}.pricing-final-cta .button--secondary,.pricing-final-cta .button--ghost,.pricing-cta .button--secondary,.pricing-cta .button--ghost{color:#fff;border-color:#fff6;background:transparent}.pricing-final-cta .button--secondary:hover,.pricing-final-cta .button--ghost:hover,.pricing-cta .button--secondary:hover,.pricing-cta .button--ghost:hover{background:#ffffff1a;border-color:#fff;color:#fff;transform:translateY(-2px)}.pricing-cards__loading,.pricing-tiers__loading,.pricing-tiers__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 0;gap:16px;text-align:center}.pricing-tiers__empty-text{max-width:500px;margin:0 auto var(--space-4);color:var(--color-text-secondary);line-height:1.6}.pricing-loader{width:32px;height:32px;color:var(--pricing-green);animation:pricing-spin 1s linear infinite}@keyframes pricing-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:1024px){.pricing-cards__grid,.pricing-tiers__grid{gap:20px}.pricing-card{padding:32px 24px}.pricing-card--popular,.pricing-card--highlighted{transform:scale(1)}.pricing-card--popular:hover,.pricing-card--highlighted:hover{transform:translateY(-4px)}.pricing-gift-section__content,.pricing-referrals-section__content{gap:40px}.gift-plan-section__content{grid-template-columns:1fr;text-align:center;gap:var(--space-6);padding:var(--space-8)}.gift-plan-section__icon-wrapper{margin:0 auto;width:72px;height:72px}.gift-plan-section__icon-wrapper svg{width:36px;height:36px}.gift-plan-section__features{justify-content:center}}@media(max-width:768px){.pricing-hero,.pricing-intro{padding:80px 0 48px}.pricing-hero__headline,.pricing-intro__title{font-size:32px}.pricing-cards,.pricing-tiers{padding:60px 0 80px}.pricing-cards__grid,.pricing-tiers__grid{grid-template-columns:1fr;max-width:400px;margin:0 auto;gap:24px}.pricing-card--popular,.pricing-card--highlighted{order:-1}.pricing-card{padding:32px 24px}.pricing-card__price{font-size:42px}.pricing-compare,.pricing-comparison,.pricing-gift-section,.pricing-gift{padding:60px 0}.pricing-gift-section__content{grid-template-columns:1fr;text-align:center}.pricing-gift-section__image{max-width:400px;margin:0 auto}.pricing-gift-section__benefits{align-items:center}.gift-plan-section__content{padding:var(--space-6)}.gift-plan-section__icon-wrapper{width:64px;height:64px}.gift-plan-section__icon-wrapper svg{width:32px;height:32px}.gift-plan-section__title{font-size:20px}.gift-plan-section__features{flex-direction:column;gap:var(--space-3)}.pricing-referrals-section,.pricing-referrals{padding:60px 0}.pricing-referrals-section__content,.pricing-referrals__inner{flex-direction:column;text-align:center}.pricing-referrals-section__illustration,.pricing-referrals__illustration{width:160px;height:160px}.referrals-callout__content{flex-direction:column;text-align:center;padding:var(--space-8);gap:var(--space-6)}.referrals-callout__content br{display:none}.pricing-faq{padding:60px 0}.faq-item__question{padding:var(--space-4) var(--space-5);font-size:16px}.faq-item__answer p,.faq-item__answer>*{padding:0 var(--space-5) var(--space-4);font-size:var(--font-size-small)}.pricing-final-cta,.pricing-cta{padding:60px 0}.pricing-final-cta__actions,.pricing-cta__actions{flex-direction:column;align-items:center}}@media(max-width:480px){.pricing-hero__headline,.pricing-intro__title{font-size:28px}.pricing-hero__subtitle,.pricing-intro__subtitle{font-size:16px}.billing-toggle__option{padding:8px 16px;font-size:14px}.billing-toggle__badge{font-size:9px;padding:2px 6px}.pricing-card__price{font-size:36px}.pricing-card__features{gap:10px}.gift-plan-section__description{font-size:var(--font-size-small)}.pricing-referrals-section__headline{font-size:22px}.pricing-final-cta__headline,.pricing-final-cta__heading,.pricing-cta__content h2{font-size:26px}}@media(max-width:640px){.pricing-compare,.pricing-comparison{padding:40px 0}}.blog-page{min-height:100vh;background-color:var(--color-background)}.blog-header{padding-top:var(--space-16);padding-bottom:var(--space-12);border-bottom:1px solid var(--color-border)}.blog-header__content{max-width:700px}.blog-header__label{font-size:13px;letter-spacing:.1em;margin-bottom:var(--space-4);display:block}.blog-header__title{font-size:clamp(36px,6vw,52px);font-weight:var(--font-weight-bold);line-height:1.15;letter-spacing:-.03em}.blog-header__title-light{color:var(--color-text-tertiary);font-weight:var(--font-weight-regular)}.blog-featured{padding-top:var(--space-12);padding-bottom:var(--space-12);border-bottom:1px solid var(--color-border)}.blog-featured__wrapper{max-width:900px}.blog-featured__label{font-size:12px;letter-spacing:.1em;color:var(--color-text-tertiary);margin-bottom:var(--space-4);display:block}.post-card--featured{display:grid;grid-template-columns:1.2fr 1fr;gap:var(--space-8);align-items:center}.post-card--featured .post-card__image-wrapper{aspect-ratio:4/3;border-radius:var(--radius-xl);overflow:hidden}.post-card--featured .post-card__image{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.post-card--featured:hover .post-card__image{transform:scale(1.03)}.post-card--featured .post-card__title{font-size:clamp(24px,4vw,32px);font-weight:var(--font-weight-semibold);line-height:1.25;letter-spacing:-.02em;margin-bottom:var(--space-4);color:var(--color-text-primary)}.post-card--featured .post-card__excerpt{font-size:var(--font-size-body);line-height:1.6;color:var(--color-text-secondary);margin-bottom:var(--space-5)}.post-card--featured .post-card__meta{display:flex;align-items:center;gap:var(--space-4);color:var(--color-text-tertiary);font-size:var(--font-size-small)}.post-card--featured .post-card__category{position:absolute;top:var(--space-4);left:var(--space-4);background:var(--color-background-elevated);color:var(--color-primary);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:12px;font-weight:var(--font-weight-semibold);text-transform:capitalize}.blog-filters{display:flex;gap:var(--space-2);margin-bottom:var(--space-10);flex-wrap:wrap}.blog-filter{padding:var(--space-3) var(--space-5);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base)}.blog-filter:hover{border-color:var(--color-border-strong);color:var(--color-text-primary)}.blog-filter--active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-inverse)}.blog-filter--active:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);color:var(--color-text-inverse)}.blog-grid-section{padding-top:var(--space-12);padding-bottom:var(--space-20)}.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-8) var(--space-6)}.post-card{position:relative}.post-card__link{display:block;text-decoration:none;color:inherit}.post-card__image-wrapper{position:relative;aspect-ratio:3/2;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--space-4);background:var(--color-background-subtle)}.post-card__image{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.post-card:hover .post-card__image{transform:scale(1.05)}.post-card__category{position:absolute;top:var(--space-3);left:var(--space-3);background:var(--color-background-elevated);color:var(--color-primary);padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);font-size:11px;font-weight:var(--font-weight-semibold);text-transform:capitalize;letter-spacing:.02em}.post-card__content{padding:0 var(--space-1)}.post-card__title{font-size:clamp(17px,2vw,20px);font-weight:var(--font-weight-semibold);line-height:1.35;letter-spacing:-.01em;color:var(--color-text-primary);margin-bottom:var(--space-3);transition:color var(--transition-base);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.post-card:hover .post-card__title{color:var(--color-primary)}.post-card__meta{display:flex;align-items:center;gap:var(--space-2);color:var(--color-text-tertiary);font-size:13px}.post-card__read-time{display:flex;align-items:center;gap:var(--space-1)}.post-card__read-time svg{width:14px;height:14px}.post-card__author{color:var(--color-text-secondary)}.blog-empty{padding:var(--space-16) 0;text-align:center}.blog-load-more{display:flex;justify-content:center;margin-top:var(--space-12)}.blog-load-more__button{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-6);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-body);font-weight:var(--font-weight-medium);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-base)}.blog-load-more__button svg{width:18px;height:18px;transition:transform var(--transition-base)}.blog-load-more__button:hover{border-color:var(--color-primary);color:var(--color-primary)}.blog-load-more__button:hover svg{transform:translate(4px)}@media(max-width:1024px){.blog-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-6)}.post-card--featured{gap:var(--space-6)}.post-card--featured .post-card__title{font-size:26px}}@media(max-width:768px){.blog-header{padding-top:var(--space-12);padding-bottom:var(--space-8)}.blog-header__title{font-size:32px}.blog-featured{padding-top:var(--space-8);padding-bottom:var(--space-8)}.post-card--featured{grid-template-columns:1fr;gap:var(--space-5)}.post-card--featured .post-card__image-wrapper{aspect-ratio:16/10}.post-card--featured .post-card__title{font-size:24px}.blog-grid-section{padding-top:var(--space-8);padding-bottom:var(--space-16)}.blog-filters{margin-bottom:var(--space-8)}.blog-grid{grid-template-columns:1fr;gap:var(--space-8)}.post-card__image-wrapper{aspect-ratio:16/10}.post-card__title{font-size:19px}}@media(max-width:480px){.blog-header__title{font-size:28px}.blog-filters{gap:var(--space-2)}.blog-filter{padding:var(--space-2) var(--space-4);font-size:14px}.post-card--featured .post-card__title{font-size:22px}}.blog-search{position:relative;margin-bottom:var(--space-6);max-width:480px}.blog-search__icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--color-text-tertiary);display:flex;align-items:center;pointer-events:none}.blog-search__input{width:100%;padding:11px 16px 11px 42px;border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-small);background:var(--color-background-elevated);color:var(--color-text-primary);transition:border-color var(--transition-base),box-shadow var(--transition-base);outline:none}.blog-search__input::placeholder{color:var(--color-text-tertiary)}.blog-search__input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.12)}.blog-layout{display:grid;grid-template-columns:1fr;gap:48px}@media(min-width:1024px){.blog-layout{grid-template-columns:2fr 1fr}}.blog-layout__main{min-width:0}.blog-sidebar{display:flex;flex-direction:column;gap:32px}.blog-sidebar__widget{background:#fff;border-radius:12px;padding:24px;border:1px solid var(--color-border)}.blog-sidebar__title{font-size:16px;font-weight:600;margin-bottom:16px;color:var(--color-text-primary)}.blog-sidebar__post{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--color-border-subtle);text-decoration:none;color:inherit;transition:color var(--transition-base)}.blog-sidebar__post:last-child{border-bottom:none;padding-bottom:0}.blog-sidebar__post:hover .blog-sidebar__post-title{color:var(--color-primary)}.blog-sidebar__post-title{font-size:14px;font-weight:500;color:var(--color-text-primary);line-height:1.4;transition:color var(--transition-base);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.blog-sidebar__post-date{font-size:12px;color:var(--color-text-tertiary);margin-top:4px}.blog-sidebar__newsletter p{font-size:14px;color:var(--color-text-secondary);margin-bottom:16px;line-height:1.5}.blog-sidebar__input{width:100%;padding:12px;border:1px solid var(--color-border);border-radius:8px;font-size:14px;margin-bottom:12px;outline:none;transition:border-color var(--transition-base);box-sizing:border-box}.blog-sidebar__input:focus{border-color:var(--color-primary)}.blog-sidebar__subscribe{width:100%;padding:12px;background:var(--color-primary);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;font-size:14px;transition:all .2s}.blog-sidebar__subscribe:hover{background:var(--color-primary-hover)}.blog-post__back{display:inline-flex;align-items:center;gap:var(--space-2);text-decoration:none;color:var(--color-text-secondary);font-size:var(--font-size-small);font-weight:var(--font-weight-medium);transition:color var(--transition-base);margin-bottom:var(--space-6)}.blog-post__back svg{width:16px;height:16px}.blog-post__back:hover{color:var(--color-primary)}.blog-post__hero{padding-top:0;padding-bottom:var(--space-8)}.blog-post__hero-image{width:100%;max-height:500px;object-fit:cover;border-radius:var(--radius-xl)}.blog-post__article{padding-bottom:var(--space-16)}.blog-post__content{max-width:720px;margin:0 auto}.blog-post__meta{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-5)}.blog-post__category{display:inline-block;background:var(--color-background-subtle);color:var(--color-primary);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:12px;font-weight:var(--font-weight-semibold);text-transform:capitalize;letter-spacing:.02em}.blog-post__date{font-size:var(--font-size-small);color:var(--color-text-tertiary)}.blog-post__title{font-size:clamp(32px,5vw,48px);font-weight:var(--font-weight-bold);line-height:1.2;letter-spacing:-.03em;margin-bottom:var(--space-5)}.blog-post__author-info{display:flex;align-items:center;gap:var(--space-3);padding-bottom:var(--space-6);margin-bottom:var(--space-6);border-bottom:1px solid var(--color-border);font-size:var(--font-size-small);color:var(--color-text-secondary)}.blog-post__separator{color:var(--color-border-strong)}.blog-post__read-time{display:flex;align-items:center;gap:var(--space-1)}.blog-post__read-time svg{width:14px;height:14px}.blog-post__excerpt{font-size:clamp(18px,2.5vw,22px);line-height:1.6;color:var(--color-text-secondary);margin-bottom:var(--space-8);padding-bottom:var(--space-8);border-bottom:1px solid var(--color-border)}.blog-post__body{font-size:var(--font-size-body);line-height:1.7;color:var(--color-text-primary)}.blog-post__body h2{font-size:clamp(24px,3vw,32px);font-weight:var(--font-weight-semibold);line-height:1.3;letter-spacing:-.02em;margin-top:var(--space-10);margin-bottom:var(--space-4)}.blog-post__body h3{font-size:clamp(20px,2.5vw,24px);font-weight:var(--font-weight-semibold);line-height:1.4;margin-top:var(--space-8);margin-bottom:var(--space-3)}.blog-post__body p{margin-bottom:var(--space-5)}.blog-post__body ul,.blog-post__body ol{margin-bottom:var(--space-5);padding-left:var(--space-6)}.blog-post__body li{margin-bottom:var(--space-2)}.blog-post__body blockquote{border-left:4px solid var(--color-primary);padding-left:var(--space-5);margin:var(--space-8) 0;font-size:var(--font-size-large);font-style:italic;color:var(--color-text-secondary)}.blog-post__body img{width:100%;border-radius:var(--radius-lg);margin:var(--space-8) 0}.blog-post__cta{background:var(--color-background-subtle);padding-top:var(--space-16);padding-bottom:var(--space-16)}.blog-post__cta-box{max-width:600px;margin:0 auto;text-align:center}.blog-post__cta-box h2{font-size:clamp(28px,4vw,36px);font-weight:var(--font-weight-semibold);line-height:1.3}@media(max-width:768px){.blog-post__hero-image{max-height:300px;border-radius:var(--radius-lg)}.blog-post__title{font-size:28px}.blog-post__excerpt{font-size:18px}.blog-post__body h2{font-size:24px}.blog-post__body h3{font-size:20px}.blog-post__cta{padding-top:var(--space-12);padding-bottom:var(--space-12)}}.blog-post__share{display:flex;gap:8px;margin:16px 0 32px;flex-wrap:wrap}.blog-post__share-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--color-border);border-radius:8px;background:#fff;font-size:13px;color:var(--color-text-secondary);cursor:pointer;transition:all .2s}.blog-post__share-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.blog-post__share-btn svg{width:14px;height:14px}.blog-post__reading-time{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:var(--color-text-tertiary);margin-left:16px}.blog-post__reading-time svg{width:14px;height:14px}.blog-post__toc{background:var(--color-background-subtle);border:1px solid var(--color-border);border-radius:10px;padding:20px 24px;margin-bottom:32px}.blog-post__toc-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);margin-bottom:12px}.blog-post__toc-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.blog-post__toc-item{font-size:14px;color:var(--color-text-secondary);line-height:1.4;cursor:default}.blog-post__toc-item--h3{padding-left:16px;font-size:13px;color:var(--color-text-tertiary)}.about-hero{text-align:center;padding-top:var(--space-20);padding-bottom:var(--space-16)}.about-hero__content{max-width:880px;margin:0 auto}.about-hero__label{display:inline-block;padding:var(--space-2) var(--space-4);background-color:var(--color-primary-light);border-radius:var(--radius-full);margin-bottom:var(--space-6);letter-spacing:.15em;font-size:13px}.about-hero__title{font-size:clamp(36px,5vw,56px);line-height:1.1;letter-spacing:-.025em;margin-bottom:var(--space-8);max-width:800px;margin-left:auto;margin-right:auto}.about-hero__lead{font-size:clamp(20px,2.5vw,24px);line-height:1.5;color:var(--color-text-secondary);max-width:640px;margin:0 auto}.about-section-content{max-width:680px;margin:0 auto}.about-section-content--centered{text-align:center}.about-section-title{font-size:clamp(28px,3.5vw,40px);line-height:1.15;letter-spacing:-.02em;margin-bottom:var(--space-8);position:relative}.about-section-title:before{content:"";display:block;width:48px;height:3px;background:var(--color-primary);margin-bottom:var(--space-6);border-radius:2px}.about-section-content--centered .about-section-title:before{margin-left:auto;margin-right:auto}.about-prose{display:flex;flex-direction:column;gap:var(--space-5)}.about-prose p{font-size:var(--font-size-body);line-height:1.75;color:var(--color-text-secondary)}.about-prose p:first-child{color:var(--color-text-primary)}.about-prose--story .about-story-lead{font-size:clamp(22px,2.5vw,26px);line-height:1.4;color:var(--color-text-primary);font-weight:var(--font-weight-medium);font-style:italic;margin-bottom:var(--space-4)}.about-prose--centered{text-align:center}.about-prose--centered p{max-width:600px;margin-left:auto;margin-right:auto}.about-mission{padding-top:var(--space-16);padding-bottom:var(--space-20)}.about-origin,.about-values{padding-top:var(--space-20);padding-bottom:var(--space-20)}.about-values-intro{color:var(--color-text-secondary);margin-bottom:var(--space-12);max-width:580px}.about-values-list{display:flex;flex-direction:column;gap:var(--space-10)}.about-value-item{padding-left:var(--space-6);border-left:3px solid var(--color-primary);transition:border-color var(--transition-base)}.about-value-item:hover{border-left-color:var(--color-primary-hover)}.about-value-title{font-size:22px;font-weight:var(--font-weight-semibold);line-height:1.3;margin-bottom:var(--space-3);color:var(--color-text-primary)}.about-value-description{font-size:var(--font-size-body);line-height:1.7;color:var(--color-text-secondary)}.about-promise{padding-top:var(--space-20);padding-bottom:var(--space-20)}.about-cta{background:linear-gradient(180deg,var(--color-background) 0%,var(--color-background-subtle) 100%);padding-top:var(--space-20);padding-bottom:var(--space-24)}.about-cta__content{text-align:center;max-width:640px;margin:0 auto}.about-cta__content h2{font-size:clamp(28px,3.5vw,40px);margin-bottom:var(--space-6)}.about-cta__text{color:var(--color-text-secondary);margin-bottom:var(--space-10);max-width:520px;margin-left:auto;margin-right:auto}.about-cta__actions{display:flex;justify-content:center;gap:var(--space-4);flex-wrap:wrap}@media(max-width:1023px){.about-hero{padding-top:var(--space-16);padding-bottom:var(--space-12)}.about-mission,.about-origin,.about-values,.about-promise{padding-top:var(--space-16);padding-bottom:var(--space-16)}.about-cta{padding-top:var(--space-16);padding-bottom:var(--space-20)}}@media(max-width:640px){.about-hero{padding-top:var(--space-12);padding-bottom:var(--space-10)}.about-hero__label{font-size:11px;padding:var(--space-1) var(--space-3)}.about-hero__title,.about-section-title{margin-bottom:var(--space-6)}.about-section-title:before{width:36px;height:2px;margin-bottom:var(--space-4)}.about-prose{gap:var(--space-4)}.about-prose p{font-size:16px}.about-prose--story .about-story-lead{font-size:20px}.about-values-intro{margin-bottom:var(--space-8)}.about-values-list{gap:var(--space-8)}.about-value-item{padding-left:var(--space-4)}.about-value-title{font-size:19px}.about-value-description{font-size:16px}.about-mission,.about-origin,.about-values,.about-promise{padding-top:var(--space-12);padding-bottom:var(--space-12)}.about-cta{padding-top:var(--space-12);padding-bottom:var(--space-16)}.about-cta__text{margin-bottom:var(--space-8)}}@media(prefers-reduced-motion:no-preference){.about-value-item{opacity:0;transform:translate(-8px);animation:fadeInLeft .5s ease forwards}.about-value-item:nth-child(1){animation-delay:.1s}.about-value-item:nth-child(2){animation-delay:.2s}.about-value-item:nth-child(3){animation-delay:.3s}.about-value-item:nth-child(4){animation-delay:.4s}@keyframes fadeInLeft{to{opacity:1;transform:translate(0)}}}.about-timeline{padding:64px 0}.about-timeline__list{position:relative;max-width:700px;margin:0 auto;margin-top:var(--space-10)}.about-timeline__line{position:absolute;left:24px;top:0;bottom:0;width:2px;background:var(--color-border)}.about-milestone{display:flex;gap:32px;margin-bottom:48px;position:relative;align-items:flex-start}.about-milestone:last-child{margin-bottom:0}.about-milestone__year{width:48px;height:48px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;position:relative;z-index:1;box-shadow:0 0 0 4px var(--color-background)}.about-milestone__content{padding-top:8px}.about-milestone__title{font-size:20px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.about-milestone__description{color:var(--color-text-secondary);line-height:1.6}@media(min-width:640px){.about-timeline__line{left:50%;transform:translate(-50%)}.about-milestone{width:50%;margin-left:0;padding-right:48px;justify-content:flex-end}.about-milestone:nth-child(2n){margin-left:50%;padding-right:0;padding-left:48px;justify-content:flex-start}.about-milestone:nth-child(odd){flex-direction:row-reverse}.about-milestone:nth-child(odd) .about-milestone__year{margin-right:-24px}.about-milestone:nth-child(2n) .about-milestone__year{margin-left:-24px}.about-milestone:nth-child(odd) .about-milestone__content{text-align:right}}@media(max-width:639px){.about-timeline__line{left:24px}.about-milestone{padding-left:0}}.about-team{padding:64px 0;background-color:var(--color-background-subtle)}.about-team__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:0}.about-team__card{background:#fff;border-radius:16px;padding:32px;text-align:center;border:1px solid var(--color-border);transition:transform var(--transition-base),box-shadow var(--transition-base)}.about-team__card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.about-team__avatar{width:64px;height:64px;border-radius:50%;background-color:var(--color-primary-light);color:var(--color-primary-text);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;margin:0 auto 16px}.about-team__name{font-size:18px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.about-team__role{color:var(--color-primary-text);font-weight:var(--font-weight-medium);margin-bottom:var(--space-3);display:block}.about-team__bio{color:var(--color-text-secondary);font-size:var(--font-size-small);line-height:1.6}@media(max-width:768px){.about-team__grid{grid-template-columns:1fr;max-width:400px;margin:0 auto}}.about-security{padding:64px 0}.about-security__card{max-width:600px;margin:0 auto;padding:40px;background-color:var(--color-background-elevated);border-radius:16px;text-align:center;border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.about-security__icon{width:64px;height:64px;border-radius:50%;background-color:var(--color-primary-light);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:var(--color-primary)}.about-security__icon svg{width:28px;height:28px}.about-security__title{font-size:22px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:0}.about-security__list{list-style:none;text-align:left;margin:24px 0 0;display:flex;flex-direction:column;gap:12px;padding:0}.about-security__list li{display:flex;gap:8px;align-items:flex-start;font-size:15px;color:var(--color-text-secondary);line-height:1.5}.about-security__list li svg{width:18px;height:18px;color:var(--color-primary);flex-shrink:0;margin-top:2px}@media(max-width:640px){.about-timeline,.about-team,.about-security{padding:40px 0}.about-security__card{padding:28px 20px}}.contact-page{--contact-primary: #2E7A3C;--contact-primary-hover: #256B33;--contact-primary-light: rgba(46, 122, 60, .08);--contact-focus-ring: rgba(46, 122, 60, .4);--contact-cream: #F6F1E8;--contact-cool-gray: #F4F6F5;--contact-white: #FFFFFF;--contact-card-radius: 20px;--contact-btn-radius: 14px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.contact-hero{background-color:var(--contact-cream);padding-top:clamp(72px,10vw,120px);padding-bottom:clamp(72px,10vw,120px);text-align:center}.contact-hero__inner{max-width:640px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:var(--space-6)}.contact-hero__title{font-family:var(--font-family);font-size:clamp(48px,7vw,80px);font-weight:var(--font-weight-bold);line-height:1.05;letter-spacing:-.03em;color:var(--color-text-primary);margin:0}.contact-hero__lead{font-size:clamp(16px,2vw,20px);line-height:1.6;color:var(--color-text-secondary);max-width:480px;margin:0}.contact-hero__avatars{display:flex;align-items:center;gap:0;margin-top:var(--space-2)}.contact-hero__avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:var(--font-weight-semibold);font-family:var(--font-family);border:2.5px solid var(--contact-cream);flex-shrink:0;margin-left:-10px;position:relative;transition:transform var(--transition-base),z-index 0ms}.contact-hero__avatar:first-child{margin-left:0}.contact-hero__avatar:hover{transform:translateY(-4px) scale(1.08);z-index:10}.contact-hero__avatar-caption{font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);letter-spacing:.01em;margin:0}.contact-options{background-color:var(--contact-white);padding-top:clamp(64px,8vw,100px);padding-bottom:clamp(64px,8vw,100px)}.contact-options__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}.contact-option-card{background-color:var(--contact-white);border:1px solid var(--color-border);border-radius:var(--contact-card-radius);padding:var(--space-8) var(--space-6);display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-3);box-shadow:0 2px 8px #1a1a1a0d;transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base)}.contact-option-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-border-strong)}.contact-option-card__icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--contact-primary);margin-bottom:var(--space-1)}.contact-option-card__icon svg{width:24px;height:24px}.contact-option-card__title{font-family:var(--font-family);font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:var(--line-height-tight);margin:0}.contact-option-card__desc{font-size:var(--font-size-body);color:var(--color-text-secondary);line-height:1.5;margin:0;flex:1}.contact-option-card__cta{display:inline-flex;align-items:center;font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);font-family:var(--font-family);color:var(--contact-primary);background:none;border:none;padding:0;cursor:pointer;text-decoration:none;letter-spacing:.01em;transition:color var(--transition-base);margin-top:var(--space-2)}.contact-option-card__cta:after{content:" →";display:inline-block;margin-left:4px;transition:transform var(--transition-base)}.contact-option-card:hover .contact-option-card__cta{color:var(--contact-primary-hover)}.contact-option-card:hover .contact-option-card__cta:after{transform:translate(3px)}.contact-form-section{background-color:var(--contact-cool-gray);padding-top:clamp(64px,8vw,100px);padding-bottom:clamp(64px,8vw,100px)}.contact-form-grid{display:grid;grid-template-columns:1.35fr 1fr;gap:var(--space-8);align-items:start;max-width:1100px;margin:0 auto}.contact-form-wrapper{background-color:var(--contact-white);border-radius:var(--contact-card-radius);padding:clamp(32px,5vw,52px);box-shadow:0 4px 20px #1a1a1a12}.contact-form__heading{font-family:var(--font-family);font-size:clamp(22px,3vw,28px);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:var(--line-height-tight);margin:0 0 var(--space-8)}.contact-form{display:flex;flex-direction:column;gap:var(--space-5)}.contact-form__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5)}.contact-form__field{display:flex;flex-direction:column;gap:var(--space-2)}.contact-form__label{font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-text-primary);display:flex;align-items:center;gap:2px;line-height:1}.contact-form__required{color:var(--color-error)}.contact-form__microcopy{font-size:12px;color:var(--color-text-tertiary);line-height:1.4;margin:0}.contact-form__select{width:100%;height:var(--input-height);padding:0 40px 0 var(--input-padding-x);font-size:var(--font-size-body);font-weight:var(--font-weight-regular);font-family:var(--font-family);color:var(--color-text-primary);background-color:var(--input-background);border:var(--border-width) solid var(--input-border-color);border-radius:var(--input-radius);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;cursor:pointer;transition:border-color var(--transition-base),box-shadow var(--transition-base)}.contact-form__select:hover{border-color:var(--color-border-strong)}.contact-form__select:focus{outline:none;border-color:var(--contact-primary);box-shadow:0 0 0 3px var(--contact-focus-ring)}.contact-form__textarea{width:100%;min-height:200px;padding:var(--input-padding-x);font-size:var(--font-size-body);font-weight:var(--font-weight-regular);font-family:var(--font-family);color:var(--color-text-primary);background-color:var(--input-background);border:var(--border-width) solid var(--input-border-color);border-radius:var(--input-radius);resize:vertical;line-height:1.6;transition:border-color var(--transition-base),box-shadow var(--transition-base);box-sizing:border-box}.contact-form__textarea::placeholder{color:var(--color-text-tertiary)}.contact-form__textarea:hover{border-color:var(--color-border-strong)}.contact-form__textarea:focus{outline:none;border-color:var(--contact-primary);box-shadow:0 0 0 3px var(--contact-focus-ring)}.contact-form__submit{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);height:52px;padding:0 var(--space-8);background-color:var(--contact-primary);color:var(--color-text-inverse);border:none;border-radius:var(--contact-btn-radius);font-size:var(--font-size-button);font-weight:var(--font-weight-semibold);font-family:var(--font-family);cursor:pointer;transition:background-color var(--transition-base),transform var(--transition-fast),box-shadow var(--transition-base);align-self:flex-start;margin-top:var(--space-2);white-space:nowrap}.contact-form__submit:hover:not(:disabled){background-color:var(--contact-primary-hover);box-shadow:0 4px 14px #2e7a3c59}.contact-form__submit:active:not(:disabled){transform:translateY(1px)}.contact-form__submit:focus-visible{outline:none;box-shadow:0 0 0 3px var(--contact-focus-ring)}.contact-form__submit:disabled{opacity:.65;cursor:not-allowed}.contact-form__submit-icon{display:flex;align-items:center;justify-content:center;width:18px;height:18px}.contact-form__submit-icon svg{width:18px;height:18px}.contact-form__spinner{width:17px;height:17px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;flex-shrink:0;animation:contact-spin .7s linear infinite}@keyframes contact-spin{to{transform:rotate(360deg)}}.contact-form-wrapper .input-field:focus,.contact-form-wrapper input:focus{border-color:var(--contact-primary)!important;box-shadow:0 0 0 3px var(--contact-focus-ring)!important}.contact-success{text-align:center;padding:var(--space-12) var(--space-6);display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.contact-success__check{width:72px;height:72px;color:var(--contact-primary);margin-bottom:var(--space-2)}.contact-success__check svg{width:100%;height:100%;overflow:visible}.contact-success__check-circle{stroke-dasharray:157;stroke-dashoffset:157;animation:contact-circle-draw .55s ease forwards}.contact-success__check-mark{stroke-dasharray:40;stroke-dashoffset:40;animation:contact-check-draw .35s ease .45s forwards}@keyframes contact-circle-draw{to{stroke-dashoffset:0}}@keyframes contact-check-draw{to{stroke-dashoffset:0}}.contact-success__title{font-family:var(--font-family);font-size:clamp(22px,3vw,28px);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:var(--line-height-tight);margin:0;animation:contact-fade-up .4s ease .6s both}.contact-success__text{font-size:var(--font-size-body);color:var(--color-text-secondary);line-height:1.6;max-width:380px;margin:0;animation:contact-fade-up .4s ease .72s both}.contact-success__retry{display:inline-flex;align-items:center;height:44px;padding:0 var(--space-6);background:none;border:1.5px solid var(--contact-primary);border-radius:var(--contact-btn-radius);color:var(--contact-primary);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);font-family:var(--font-family);cursor:pointer;transition:background-color var(--transition-base),color var(--transition-base);margin-top:var(--space-2);animation:contact-fade-up .4s ease .84s both}.contact-success__retry:hover{background-color:var(--contact-primary-light)}.contact-success__retry:focus-visible{outline:none;box-shadow:0 0 0 3px var(--contact-focus-ring)}.contact-support-panel{background-color:var(--contact-white);border-radius:var(--contact-card-radius);padding:clamp(28px,4vw,44px);box-shadow:0 4px 20px #1a1a1a12;display:flex;flex-direction:column;gap:var(--space-6);position:sticky;top:calc(var(--navbar-height) + 24px)}.contact-support-panel__title{font-family:var(--font-family);font-size:clamp(18px,2.5vw,22px);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:var(--line-height-tight);margin:0}.contact-support-panel__stats{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-4)}.contact-support-stat{display:flex;align-items:center;gap:var(--space-3)}.contact-support-stat__icon{width:36px;height:36px;border-radius:50%;background-color:var(--contact-primary-light);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--contact-primary)}.contact-support-stat__icon svg{width:17px;height:17px}.contact-support-stat__body{display:flex;flex-direction:column;gap:1px}.contact-support-stat__label{font-size:12px;color:var(--color-text-tertiary);font-weight:var(--font-weight-medium);line-height:1}.contact-support-stat__value{font-size:var(--font-size-body);color:var(--color-text-primary);font-weight:var(--font-weight-semibold);line-height:1.3}.contact-support-testimonial{margin:0;padding:var(--space-4) var(--space-5);background-color:var(--contact-cream);border-radius:14px;border-left:3px solid var(--contact-primary)}.contact-support-testimonial__quote{margin:0 0 var(--space-2)}.contact-support-testimonial__quote p{font-size:var(--font-size-body);color:var(--color-text-primary);font-style:italic;line-height:1.6;margin:0}.contact-support-testimonial__attribution{font-size:var(--font-size-small);color:var(--color-text-tertiary);font-weight:var(--font-weight-medium)}.contact-reassurance{background-color:var(--contact-cream);padding-top:clamp(64px,8vw,100px);padding-bottom:clamp(64px,8vw,100px)}.contact-reassurance__header{text-align:center;margin-bottom:clamp(40px,5vw,64px)}.contact-reassurance__title{font-family:var(--font-family);font-size:clamp(26px,3.5vw,38px);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:var(--line-height-tight);letter-spacing:-.02em;margin:0}.contact-reassurance__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);max-width:960px;margin:0 auto}.contact-reassurance-card{background-color:var(--contact-white);border-radius:var(--contact-card-radius);padding:var(--space-8) var(--space-6);display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-3);border:1px solid var(--color-border);transition:transform var(--transition-base),box-shadow var(--transition-base)}.contact-reassurance-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.contact-reassurance-card__icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--contact-primary)}.contact-reassurance-card__icon svg{width:24px;height:24px}.contact-reassurance-card__divider{width:32px;height:1.5px;background-color:var(--color-border-strong);border-radius:2px;margin-top:2px}.contact-reassurance-card__title{font-family:var(--font-family);font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:var(--line-height-tight);margin:0}.contact-reassurance-card__desc{font-size:var(--font-size-small);color:var(--color-text-secondary);line-height:1.65;margin:0}.contact-connect{background-color:var(--contact-white);padding-top:clamp(52px,7vw,80px);padding-bottom:clamp(52px,7vw,80px);border-top:1px solid var(--color-border)}.contact-connect__inner{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);text-align:center}.contact-connect__email-line{font-size:clamp(15px,2vw,17px);color:var(--color-text-secondary);margin:0;line-height:1.5}.contact-connect__email-link{color:var(--contact-primary);font-weight:var(--font-weight-medium);text-decoration:none;transition:color var(--transition-base);border-bottom:1px solid rgba(46,122,60,.3);padding-bottom:1px}.contact-connect__email-link:hover{color:var(--contact-primary-hover);border-bottom-color:var(--contact-primary-hover)}.contact-connect__email-link:focus-visible{outline:2px solid var(--contact-focus-ring);outline-offset:3px;border-radius:2px}.contact-connect__social-label{font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.12em;margin:0}.contact-connect__social-row{display:flex;align-items:center;justify-content:center;gap:var(--space-3)}.contact-connect__social-btn{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--color-border);background-color:var(--contact-white);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);text-decoration:none;transition:border-color var(--transition-base),color var(--transition-base),background-color var(--transition-base),transform var(--transition-base)}.contact-connect__social-btn svg{width:17px;height:17px}.contact-connect__social-btn:hover{border-color:var(--contact-primary);color:var(--contact-primary);background-color:var(--contact-primary-light);transform:translateY(-2px)}.contact-connect__social-btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--contact-focus-ring)}@keyframes contact-fade-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1023px){.contact-form-grid{grid-template-columns:1fr;gap:var(--space-6);max-width:680px}.contact-support-panel{position:static}.contact-options__grid,.contact-reassurance__grid{gap:var(--space-5)}}@media(max-width:768px){.contact-options__grid,.contact-reassurance__grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}.contact-form__row{grid-template-columns:1fr}.contact-hero__avatar{width:40px;height:40px;font-size:12px}}@media(max-width:640px){.contact-hero{padding-top:64px;padding-bottom:64px}.contact-form-wrapper,.contact-support-panel,.contact-option-card,.contact-reassurance-card{padding:var(--space-6);border-radius:16px}.contact-form__submit{width:100%;justify-content:center}.contact-success{padding:var(--space-8) var(--space-4)}.contact-connect__social-row{gap:var(--space-2)}.contact-support-testimonial{padding:var(--space-4)}}@media(prefers-reduced-motion:reduce){.contact-hero__avatar,.contact-option-card,.contact-reassurance-card,.contact-connect__social-btn,.contact-form__submit,.contact-success__check-circle,.contact-success__check-mark,.contact-success__title,.contact-success__text,.contact-success__retry,.contact-form__spinner{animation:none!important;transition:none!important}.contact-success__check-circle,.contact-success__check-mark{stroke-dashoffset:0}}@media(prefers-reduced-motion:no-preference){.contact-hero__inner{animation:contact-fade-up .6s ease both}.contact-option-card{opacity:0;transform:translateY(18px);animation:contact-fade-up .5s ease forwards}.contact-option-card:nth-child(1){animation-delay:.05s}.contact-option-card:nth-child(2){animation-delay:.15s}.contact-option-card:nth-child(3){animation-delay:.25s}.contact-form-wrapper{animation:contact-fade-up .55s ease .1s both}.contact-support-panel{animation:contact-fade-up .55s ease .2s both}.contact-reassurance-card{opacity:0;transform:translateY(16px);animation:contact-fade-up .5s ease forwards}.contact-reassurance-card:nth-child(1){animation-delay:.08s}.contact-reassurance-card:nth-child(2){animation-delay:.18s}.contact-reassurance-card:nth-child(3){animation-delay:.28s}}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--space-6);background:var(--color-background)}.dashboard-loading__spinner{width:48px;height:48px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.dashboard{min-height:100vh;background:var(--color-background)}.dashboard__main{padding-bottom:var(--space-20)}.dashboard__welcome{padding:var(--space-4) 0 var(--space-6);background:linear-gradient(180deg,var(--color-background-primary) 0%,var(--color-background) 100%)}.welcome__grid{display:flex;align-items:center;justify-content:space-between;gap:var(--space-8)}.welcome__content{max-width:640px}.welcome__greeting{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-primary-light);border-radius:var(--radius-full);margin-bottom:var(--space-5)}.welcome__greeting svg{width:16px;height:16px;color:var(--color-primary)}.welcome__title{font-size:clamp(32px,5vw,48px);letter-spacing:var(--letter-spacing-tight);margin-bottom:var(--space-4);background:linear-gradient(135deg,var(--color-text-primary) 0%,var(--color-primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.welcome__subtitle{color:var(--color-text-secondary);max-width:520px}.welcome__avatar{flex-shrink:0}.avatar{display:flex;align-items:center;justify-content:center;border-radius:50%;font-weight:var(--font-weight-semibold);color:var(--color-text-inverse);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);box-shadow:var(--shadow-lg),0 0 0 4px #2f5d461a}.avatar--large{width:88px;height:88px;font-size:28px;overflow:hidden}.avatar--has-image{background:none}.avatar__img{width:100%;height:100%;object-fit:cover}.dashboard__actions{padding:var(--space-12) 0}.actions__header{margin-bottom:var(--space-10)}.actions__title{font-size:var(--font-size-h2);margin-bottom:var(--space-2)}.actions__subtitle{color:var(--color-text-secondary)}.actions__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6)}.action-card{display:flex;flex-direction:column;gap:var(--space-5);padding:var(--space-8);border-radius:var(--radius-xl);border:1px solid var(--color-border);background:var(--color-background-elevated);transition:all var(--transition-base);position:relative;overflow:hidden}.action-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;opacity:0;transition:opacity var(--transition-base)}.action-card:hover{border-color:var(--color-border-strong);box-shadow:var(--shadow-md);transform:translateY(-2px)}.action-card:hover:before{opacity:1}.action-card--primary:before{background:linear-gradient(90deg,var(--color-primary) 0%,#4A7A5F 100%)}.action-card--secondary:before{background:linear-gradient(90deg,#6b7280,#9ca3af)}.action-card--tertiary:before{background:linear-gradient(90deg,#7c3aed,#a78bfa)}.action-card--accent:before{background:linear-gradient(90deg,#ec4899,#f472b6)}.action-card--premium:before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.action-card__icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);background:var(--color-background-primary)}.action-card__icon svg{width:28px;height:28px;color:var(--color-primary)}.action-card--tertiary .action-card__icon{background:#7c3aed1a}.action-card--tertiary .action-card__icon svg{color:#7c3aed}.action-card--accent .action-card__icon{background:#ec48991a}.action-card--accent .action-card__icon svg{color:#ec4899}.action-card--premium .action-card__icon{background:#f59e0b1a}.action-card--premium .action-card__icon svg{color:#f59e0b}.action-card__content{flex:1}.action-card__title{font-size:20px;margin-bottom:var(--space-2)}.action-card__text{color:var(--color-text-secondary);font-size:var(--font-size-small);line-height:1.5}.action-card .btn{align-self:flex-start;margin-top:auto}.action-card .btn svg{width:18px;height:18px}.action-card__pending{display:inline-flex;align-items:center;margin-top:var(--space-2);padding:var(--space-1) var(--space-3);background:#ec48991a;border:none;border-radius:var(--radius-full);font-size:13px;font-weight:var(--font-weight-medium);color:#ec4899;cursor:pointer;transition:all var(--transition-fast)}.action-card__pending:hover{background:#ec489933;text-decoration:underline}.dashboard__activity{padding:var(--section-padding-y) 0;background:var(--color-background-subtle)}.activity__header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:var(--space-10);gap:var(--space-6)}.activity__header-content h2{margin-bottom:var(--space-2)}.activity__view-all{display:flex;align-items:center;gap:var(--space-2);white-space:nowrap}.activity__view-all svg{width:18px;height:18px;transition:transform var(--transition-base)}.activity__view-all:hover svg{transform:translate(4px)}.memories__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-6)}.memory-card{border-radius:var(--radius-xl);overflow:hidden;background:var(--color-background-elevated);border:1px solid var(--color-border);transition:all var(--transition-base)}.memory-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-border-strong)}.memory-card__image{position:relative;aspect-ratio:4/3;overflow:hidden;background-color:var(--color-background-subtle)}.memory-card__type{position:absolute;top:var(--space-3);right:var(--space-3);width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#fffffff2;border-radius:var(--radius-md);font-size:12px;box-shadow:var(--shadow-sm)}.memory-card__type svg{width:16px;height:16px;color:var(--color-text-secondary)}.memory-card__content{padding:var(--space-5)}.memory-card__date{display:flex!important;flex-direction:row!important;align-items:center!important;flex-wrap:nowrap!important;gap:6px!important;margin-bottom:var(--space-2);white-space:nowrap!important;width:fit-content!important;padding:4px 12px!important;background:#0009!important;color:#fff!important;border-radius:999px!important;font-size:11px!important;line-height:1!important}.memory-card__date svg{width:14px!important;height:14px!important;flex-shrink:0!important;color:inherit!important;display:block!important}.memory-card__date span{display:inline-block!important;line-height:1!important}.memory-card__title{font-size:16px;margin-bottom:var(--space-2);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.memory-card__description{color:var(--color-text-tertiary);font-size:13px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.memory-card__footer{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border-subtle)}.memory-card__likes{display:flex;align-items:center;gap:var(--space-2);color:var(--color-text-tertiary);font-size:13px;padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);background:transparent;border:none;cursor:pointer;transition:all var(--transition-fast)}.memory-card__likes:hover{background:#ec48991a;color:#ec4899}.memory-card__likes:active{transform:scale(.95)}.memory-card__likes svg{width:16px;height:16px;color:#ec4899;transition:transform var(--transition-fast)}.memory-card__likes:hover svg{transform:scale(1.15)}.memory-card__likes--active{color:#ec4899}.memory-card__likes--active svg{fill:#ec4899}.dashboard__sidebar-section{padding:var(--section-padding-y) 0}.sidebar__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-8)}.sidebar__block{background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6)}.sidebar__block--full{grid-column:1 / -1}.sidebar__block-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5)}.sidebar__block-header h3{font-size:18px}.members__list{display:flex;flex-direction:column;gap:var(--space-3)}.member-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);transition:background var(--transition-fast);cursor:pointer;background:transparent;border:none;width:100%;text-align:left}.member-item:hover{background:var(--color-background-subtle)}.member-item__avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);flex-shrink:0}.member-item__avatar--add{background:var(--color-primary-light);border:2px dashed var(--color-primary)}.member-item__avatar--add svg{width:18px;height:18px;color:var(--color-primary)}.member-item__info{display:flex;flex-direction:column;gap:2px;min-width:0}.member-item--add .member-item__info span{color:var(--color-primary)}.events__list{display:flex;flex-direction:column;gap:var(--space-4)}.event-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3);border-radius:var(--radius-md);transition:background var(--transition-fast);cursor:pointer}.event-item:hover{background:var(--color-background-subtle)}.event-item__date{width:48px;height:52px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-background-primary) 0%,var(--color-primary-light) 100%);border-radius:var(--radius-md);flex-shrink:0}.event-item__month{font-size:11px;font-weight:var(--font-weight-semibold);color:var(--color-primary);text-transform:uppercase;letter-spacing:.05em}.event-item__day{font-size:20px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1}.event-item__info{display:flex;flex-direction:column;gap:2px}.stats-card{background:linear-gradient(135deg,var(--color-background-primary) 0%,var(--color-background-warm) 100%);border:1px solid var(--color-primary-light)}.stats-card__title{font-size:20px;margin-bottom:var(--space-8);text-align:center}.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-6);text-align:center}.stat-item{display:flex;flex-direction:column;gap:var(--space-1)}.stat-item__value{font-size:36px;font-weight:var(--font-weight-bold);color:var(--color-primary);line-height:1}@media(max-width:1024px){.actions__grid,.memories__grid,.sidebar__grid{grid-template-columns:repeat(2,1fr)}.sidebar__block--full{grid-column:1 / -1}.stats__grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:768px){.dashboard__welcome{padding:var(--space-10) 0 var(--space-8)}.welcome__grid{flex-direction:column-reverse;text-align:center}.welcome__content{display:flex;flex-direction:column;align-items:center}.welcome__subtitle{text-align:center}.welcome__title{font-size:32px}.avatar--large{width:72px;height:72px;font-size:24px}.actions__grid{grid-template-columns:1fr!important}.action-card{padding:var(--space-6)}.memories__grid{grid-template-columns:1fr}.activity__header{flex-direction:column;align-items:flex-start}.sidebar__grid{grid-template-columns:1fr}.stats__grid{grid-template-columns:repeat(2,1fr)}.stat-item__value{font-size:28px}}@media(max-width:480px){.actions__title{font-size:28px}.action-card__icon{width:48px;height:48px}.action-card__icon svg{width:24px;height:24px}}.dash-modal-overlay{position:fixed;inset:0;background:#00000080;z-index:999}.dash-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--color-background-elevated, #fff);border-radius:var(--radius-xl, 16px);box-shadow:var(--shadow-xl, 0 20px 60px rgba(0, 0, 0, .15));max-width:500px;width:90%;z-index:1000}.dash-modal__header{padding:var(--space-6, 24px);border-bottom:1px solid var(--color-border, #e5e7eb)}.dash-modal__header h3{margin:0;font-size:var(--font-size-modal-title, 1.25rem)}.dash-modal__content{padding:var(--space-6, 24px)}.dash-modal__footer{padding:var(--space-6, 24px);border-top:1px solid var(--color-border, #e5e7eb);display:flex;justify-content:flex-end;gap:var(--space-3, 12px)}.dash-modal__label{display:block;font-size:.875rem;font-weight:500;margin-bottom:6px;color:var(--color-text-primary, #1a1a1a)}.upload-modal{width:800px;max-width:95vw}.wizard-progress{display:flex;justify-content:space-between;padding:var(--space-4) var(--space-8);background:var(--color-background-subtle);border-bottom:1px solid var(--color-border-subtle)}.wizard-step{display:flex;align-items:center;gap:var(--space-2);font-size:14px;color:var(--color-text-tertiary);font-weight:var(--font-weight-medium)}.wizard-step--active{color:var(--color-primary)}.wizard-step--completed{color:var(--color-text-primary)}.step-number{width:24px;height:24px;border-radius:50%;background:var(--color-border);color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.wizard-step--active .step-number,.wizard-step--completed .step-number{background:var(--color-primary);color:#fff}.step-content{animation:fadeIn var(--transition-base)}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;margin-bottom:var(--space-2);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.form-hint{font-size:12px;color:var(--color-text-tertiary);margin-top:var(--space-1)}.type-chips{display:flex;gap:var(--space-3);flex-wrap:wrap}.type-chip{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-background-elevated);cursor:pointer;transition:all var(--transition-fast);font-weight:var(--font-weight-medium)}.type-chip:hover{border-color:var(--color-border-strong);background:var(--color-background-subtle)}.type-chip--selected{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary-dark)}.type-chip svg{width:18px;height:18px}.dropzone{border:2px dashed var(--color-border-strong);border-radius:var(--radius-xl);padding:var(--space-8);text-align:center;background:var(--color-background-subtle);cursor:pointer;transition:all var(--transition-base);display:flex;flex-direction:column;align-items:center;justify-content:center}.dropzone:hover,.dropzone--drag-over{border-color:var(--color-primary);background:var(--color-background-secondary)}.dropzone-icon{width:48px;height:48px;color:var(--color-text-tertiary);margin-bottom:var(--space-4)}.dropzone-text{font-size:16px;font-weight:var(--font-weight-medium);margin-bottom:var(--space-2)}.dropzone-hint{font-size:14px;color:var(--color-text-tertiary)}.media-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--space-4);margin-top:var(--space-4)}.media-thumbnail{position:relative;border-radius:var(--radius-md);overflow:hidden;aspect-ratio:1;background:var(--color-background-subtle);border:1px solid var(--color-border)}.media-thumbnail img,.media-thumbnail video{width:100%;height:100%;object-fit:cover}.media-thumbnail__remove{position:absolute;top:4px;right:4px;background:#0009;color:#fff;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--transition-fast)}.media-thumbnail__remove:hover{background:#dc2626e6}.file-preview{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background-elevated)}.tags-input-container{display:flex;flex-wrap:wrap;gap:var(--space-2);padding:var(--space-2);border:1px solid var(--color-border);border-radius:8px;background:var(--color-background-elevated);min-height:var(--input-height)}.tags-input-container:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.tag-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:var(--color-background-subtle);border-radius:var(--radius-full);font-size:13px;border:1px solid var(--color-border)}.tag-chip__remove{background:none;border:none;cursor:pointer;display:flex;align-items:center;color:var(--color-text-tertiary);padding:0}.tag-input{flex:1;min-width:120px;border:none;background:transparent;font-size:14px;padding:4px;color:var(--color-text-primary)}.tag-input:focus{outline:none}.memory-preview-container{display:flex;justify-content:center;padding:var(--space-4);background:var(--color-background-subtle);border-radius:var(--radius-lg)}.memory-preview-card{width:320px;background:var(--color-background-elevated);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}.memory-preview-card--full{width:100%;max-width:100%}.summary-item{padding:16px;background:var(--color-background-elevated);border-radius:var(--radius-md);border:1px solid var(--color-border);transition:all var(--transition-fast)}.summary-item:hover{border-color:var(--color-border-strong);box-shadow:var(--shadow-sm)}.summary-item__label{font-size:12px;font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.summary-item__value{font-size:14px;color:var(--color-text-primary);font-weight:var(--font-weight-medium);line-height:1.4}.tree-page{position:fixed;top:var(--navbar-height, 64px);left:0;right:0;bottom:0;background:var(--fmp-beige, #F5EDE3);display:flex;flex-direction:column;z-index:10;overflow:hidden}.tree-page--blurred{overflow:hidden}.tree-page--blurred .tree-main,.tree-page--blurred .navbar,.tree-page--blurred .footer{filter:blur(8px) grayscale(20%);pointer-events:none;-webkit-user-select:none;user-select:none}.tree-main{flex:1;padding:0;min-height:0;display:flex;flex-direction:column}.tree-main .container{max-width:100%;width:100%;padding:0;margin:0;flex:1;min-height:0;display:flex;flex-direction:column}.tree-card{background:transparent;border-radius:0;border:none;box-shadow:none;display:flex;flex-direction:column;overflow:hidden;height:100%;min-height:0}.tree-header{display:none}@media(max-width:640px){.tree-header{padding:var(--space-4);flex-direction:column;align-items:stretch;gap:var(--space-3)}}.tree-header__title{font-size:24px;margin:0}.tree-header__stats{margin-top:var(--space-1)}.tree-header__actions{display:flex;align-items:center;gap:var(--space-3)}.tree-header__actions .btn svg{width:18px;height:18px}.tree-container{flex:1;min-height:0;position:relative;background:var(--fmp-beige, #F5EDE3);overflow:hidden;cursor:grab;-webkit-user-select:none;user-select:none;display:flex;flex-direction:column}.tree-container--dragging{cursor:grabbing}.tree-layout-wrapper{position:absolute;inset:0}.tree-layout-wrapper--full-width .generation-lane-sidebar{display:none}.tree-layout-wrapper--full-width .tree-canvas{left:0}.generation-lane-pill{position:absolute;left:var(--space-4);font-size:11px;font-weight:var(--font-weight-bold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.08em;background:#fffffff2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);border:1px solid var(--color-border-subtle);box-shadow:var(--shadow-sm);white-space:nowrap;pointer-events:auto;transition:top .1s ease-out}.tree-canvas{position:absolute;top:0;left:0;min-width:100%;min-height:100%;transform-origin:0 0}@media(max-width:768px){.generation-lane-sidebar{display:none}.tree-canvas{min-width:1200px;min-height:1000px}}.tree-connections{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}.tree-connection{fill:none;stroke:#3d3d3d;stroke-width:1.5;stroke-linecap:round;opacity:.7}.tree-connection--spouse{stroke:#3d3d3d;stroke-width:1.5;opacity:.7}.tree-connection--parent{stroke:#3d3d3d;opacity:.7}.tree-connection--inlaw,.tree-connection--sibling{stroke:#3d3d3d;opacity:.5}.generation-labels,.generation-label,.canvas-hint{display:none}.drawer-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:all var(--transition-base);z-index:var(--z-modal-backdrop)}.drawer-overlay--visible{opacity:1;visibility:visible}.side-drawer{position:absolute;top:0;left:0;bottom:0;width:340px;max-width:90vw;background:var(--color-background-elevated, #fff);border-right:1px solid var(--color-border, #e0e0e0);box-shadow:var(--shadow-xl);transform:translate(-100%);transition:transform var(--transition-slow, .3s ease);z-index:var(--z-modal, 500);display:flex;flex-direction:column;overflow:hidden}.side-drawer--open{transform:translate(0)}.side-drawer--nonblocking{box-shadow:8px 0 32px #0000001f}.drawer__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-subtle);background:var(--color-background-elevated)}.drawer__header-label{font-size:13px;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em}.drawer__close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;color:var(--color-text-tertiary);transition:all var(--transition-fast)}.drawer__close:hover{background:var(--color-background-subtle);color:var(--color-text-primary)}.drawer__close svg{width:20px;height:20px}.drawer__content{flex:1;overflow-y:auto;padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-5);scrollbar-width:thin;scrollbar-color:transparent transparent;-ms-overflow-style:-ms-autohiding-scrollbar}.drawer__content:hover,.drawer__content:active{scrollbar-color:var(--color-border-strong, #D6D4D1) transparent}.drawer__content::-webkit-scrollbar{width:5px}.drawer__content::-webkit-scrollbar-track{background:transparent}.drawer__content::-webkit-scrollbar-thumb{background:transparent;border-radius:var(--radius-full, 9999px)}.drawer__content:hover::-webkit-scrollbar-thumb,.drawer__content:active::-webkit-scrollbar-thumb{background:var(--color-border-strong, #D6D4D1)}.drawer__content::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary, #757575)}.drawer__profile{display:flex;align-items:center;gap:var(--space-4);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border-subtle)}.drawer__avatar{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:var(--font-weight-bold);color:var(--color-text-inverse);flex-shrink:0;box-shadow:var(--shadow-md)}.drawer__avatar--male{background:linear-gradient(135deg,#4a90a4,#2f6b7f)}.drawer__avatar--female{background:linear-gradient(135deg,#b4838d,#8b5a5a)}.drawer__avatar--other{background:linear-gradient(135deg,var(--color-primary) 0%,#1F3D2E 100%)}.drawer__avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.drawer__profile-info{flex:1;min-width:0}.drawer__name{font-size:20px;margin:0 0 var(--space-1) 0;line-height:1.2}.drawer__relationship{margin-bottom:var(--space-1)}.drawer__you-badge{display:inline-block;background:var(--color-primary-light);color:var(--color-primary);font-size:11px;font-weight:var(--font-weight-semibold);padding:2px var(--space-2);border-radius:var(--radius-full);margin-top:var(--space-1)}.drawer__life-info{display:flex;flex-wrap:wrap;gap:var(--space-4)}.life-info__item{display:flex;align-items:center;gap:var(--space-2)}.life-info__item svg{width:18px;height:18px;color:var(--color-text-tertiary);flex-shrink:0}.drawer__stats-row{display:flex;gap:var(--space-3)}.drawer__stat-pill{flex:1;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--color-background-subtle);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle)}.drawer__stat-pill svg{width:20px;height:20px;color:var(--color-primary)}.drawer__stat-count{font-size:18px;font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.drawer__actions-primary{display:flex;flex-direction:column;gap:var(--space-3)}.drawer__action-btn{width:100%;justify-content:center}.drawer__action-btn svg{width:18px;height:18px}.drawer__actions-secondary{display:flex;flex-direction:column;gap:var(--space-2);padding-top:var(--space-3);border-top:1px solid var(--color-border-subtle)}.drawer__action-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:14px;font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-align:left;transition:all var(--transition-fast)}.drawer__action-link:hover{background:var(--color-background-subtle);color:var(--color-text-primary)}.drawer__action-link svg{width:18px;height:18px;color:var(--color-text-tertiary);transition:color var(--transition-fast)}.drawer__action-link:hover svg{color:var(--color-primary)}.drawer__action-link--danger{color:var(--color-danger)}.drawer__action-link--danger:hover{background:rgba(var(--color-danger-rgb),.08);color:var(--color-danger)}.drawer__action-link--danger svg{color:var(--color-danger);opacity:.7}.drawer__action-link--danger:hover svg{color:var(--color-danger);opacity:1}.drawer__section{margin-top:calc(var(--space-2) * -1);display:flex;flex-direction:column;gap:var(--space-3)}.drawer__section-title{font-size:13px;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em}.drawer__link-card{background:var(--color-background-subtle);border:1px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);min-height:80px;display:flex;align-items:center}.link-card__empty{width:100%;display:flex;flex-direction:column;align-items:center;gap:var(--space-2);text-align:center}.link-card__action{color:var(--color-primary);font-weight:600}.link-card__status{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.link-status__info{display:flex;align-items:center;gap:var(--space-3)}.link-status__icon{width:36px;height:36px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0000000d}.link-card__status--pending .link-status__icon{color:#f59e0b}.link-card__status--accepted .link-status__icon{color:#10b981}.link-status__icon svg{width:18px;height:18px}.link-card__view{font-size:11px!important;padding:2px 8px!important}@media(max-width:768px){.tree-header{padding:var(--space-4) var(--space-4)}.tree-header__title{font-size:20px}.tree-header__actions{width:100%;justify-content:flex-end}.generation-lane-sidebar{display:none}.tree-container{padding:40px}.zoom-controls{bottom:var(--space-4);right:var(--space-4)}.canvas-hint{display:none}.side-drawer{width:100%;max-width:100vw}}@media(max-width:480px){.drawer__life-info{flex-direction:column;gap:var(--space-2)}.drawer__stats-row{flex-direction:column}.drawer__profile{flex-direction:column;text-align:center}.drawer__profile-info{text-align:center}.drawer__avatar{width:64px;height:64px;font-size:22px}.drawer__name{font-size:18px}.action-toast{width:calc(100% - var(--space-8));max-width:none}}.tree-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-8);gap:var(--space-4);min-height:400px}.tree-loading__spinner{width:48px;height:48px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.tree-error{display:flex;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-4) var(--space-6);background:#ef44441a;border-bottom:1px solid rgba(239,68,68,.2)}.tree-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-8);gap:var(--space-4);min-height:400px;text-align:center}.tree-empty__icon{width:80px;height:80px;border-radius:50%;background:var(--color-background);border:2px dashed var(--color-border);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4)}.tree-empty__icon svg{width:36px;height:36px;color:var(--color-text-tertiary)}.tree-empty h3{margin:0;color:var(--color-text-primary)}.tree-empty .btn{margin-top:var(--space-4)}.tree-controls{display:flex;align-items:center;gap:var(--space-5);padding:var(--space-3) var(--space-6);border-bottom:1px solid var(--color-border-subtle);background:var(--color-background-elevated);flex-wrap:wrap}.tree-controls__group{display:flex;flex-direction:column;gap:var(--space-2)}.tree-controls__chips,.tree-controls__toggle{display:flex;gap:var(--space-2);flex-wrap:wrap}.tree-controls__chip{border:1px solid var(--color-border);background:var(--color-background-subtle);border-radius:var(--radius-full);padding:4px 12px;font-size:12px;cursor:pointer;color:var(--color-text-secondary);transition:all var(--transition-fast)}.tree-controls__chip--active{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.tree-controls__chip:disabled{opacity:.6;cursor:not-allowed}.action-toast__action{background:none;border:none;color:var(--color-primary);font-weight:var(--font-weight-semibold);cursor:pointer}.action-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-background-elevated);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border-left:3px solid var(--color-primary);z-index:calc(var(--z-modal) + 100)}.action-toast--error{border-left:3px solid var(--color-error);background:#fee2e2;color:#991b1b}.action-toast--success{border-left:3px solid var(--color-success);background:#d1fae5;color:#065f46}.tree-skeleton{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:80px 40px;min-height:400px}.tree-skeleton__row{display:flex;gap:24px;justify-content:center}.tree-skeleton__card{width:120px;height:150px;border-radius:8px;background:linear-gradient(90deg,#e8e0d6 25%,#f0e8de,#e8e0d6 75%);background-size:200% 100%;animation:skeletonShimmer 1.5s ease-in-out infinite}.tree-skeleton__card--wide{width:140px;height:160px}.tree-skeleton__connector{width:2px;height:24px;background:#d9d0c5;border-radius:1px}@keyframes skeletonShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.tree-error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 40px;text-align:center;gap:12px;min-height:300px}.tree-error-boundary__icon{color:var(--color-danger, #dc2626);margin-bottom:4px}.tree-error-boundary__title{font-size:18px;font-weight:600;color:var(--color-text-primary, #1a1a1a);margin:0}.tree-error-boundary__message{font-size:14px;color:var(--color-text-secondary, #666);margin:0;max-width:320px}.tree-error-boundary__btn{margin-top:8px;padding:8px 20px;border-radius:6px;border:1px solid var(--fmp-navy, #1D2842);background:var(--fmp-navy, #1D2842);color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .15s}.tree-error-boundary__btn:hover{opacity:.9}@media print{.navbar,.side-drawer,.bottom-bar,.top-toolbar,.tree-search-overlay,.tree-header,.tree-error,.tree-loading,.action-toast,.confirm-modal,.confirm-modal-overlay{display:none!important}.tree-page{position:static;inset:auto;background:#fff;overflow:visible;height:auto}.tree-main{overflow:visible;height:auto}.tree-card{box-shadow:none;border:none;background:#fff}.tree-container{overflow:visible!important;width:100%!important;height:auto!important;cursor:default!important}.person-card-v2,.person-card{border:1px solid #ccc!important;box-shadow:none!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.tree-connections,.tree-connectors-svg{-webkit-print-color-adjust:exact;print-color-adjust:exact}.tree-page:after{content:"Famili Cloud";position:fixed;bottom:12px;right:16px;font-size:10px;color:#999;font-family:sans-serif;z-index:9999}}.share-modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:opacity var(--transition-base),visibility var(--transition-base);z-index:var(--z-modal-backdrop)}.share-modal-overlay--visible{opacity:1;visibility:visible}.share-modal{position:fixed;z-index:var(--z-modal);background:var(--color-background-elevated);border:1px solid var(--color-border);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;max-height:90vh;opacity:0;visibility:hidden;transition:opacity var(--transition-slow),visibility var(--transition-slow),transform var(--transition-slow);top:50%;left:50%;transform:translate(-50%,-50%) scale(.95);width:600px;max-width:calc(100vw - 48px);border-radius:var(--radius-2xl)}.share-modal--open{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}@media(max-width:640px){.share-modal{inset:auto 0 0;transform:translateY(100%);width:100%;max-width:100%;max-height:85vh;border-radius:var(--radius-2xl) var(--radius-2xl) 0 0}.share-modal--open{transform:translateY(0)}}.share-modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0}.share-modal__title{font-size:16px;margin:0;color:var(--color-text-primary)}.share-modal__close{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;color:var(--color-text-tertiary);transition:all var(--transition-fast)}.share-modal__close:hover{background:var(--color-background-subtle);color:var(--color-text-primary)}.share-modal__close svg{width:24px;height:24px}.share-modal__content{flex:1;overflow-y:auto;padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-8)}.share-modal__loading{display:flex;align-items:center;justify-content:center;padding:48px 24px;color:var(--color-text-secondary, #666);font-size:14px}.share-modal__footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-5) var(--space-6);border-top:1px solid var(--color-border-subtle);background:var(--color-background-subtle);flex-shrink:0}@media(max-width:640px){.share-modal__footer{padding:var(--space-4)}.share-modal__footer .button{flex:1}}.share-section{display:flex;flex-direction:column;gap:var(--space-4)}.share-section__header{display:flex;align-items:center;gap:var(--space-3)}.share-section__header svg{width:20px;height:20px;color:var(--color-primary);flex-shrink:0}.share-section__title{font-size:15px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;text-transform:uppercase;letter-spacing:.03em}.visibility-options{display:flex;flex-direction:column;gap:var(--space-3)}.visibility-option{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--color-background-subtle);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base)}.visibility-option:hover{border-color:var(--color-border-strong);background:var(--color-background-muted)}.visibility-option--selected{border-color:var(--color-primary);background:var(--color-background-primary)}.visibility-option__input{position:absolute;opacity:0;pointer-events:none}.visibility-option__radio{width:20px;height:20px;border:2px solid var(--color-border-strong);border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);margin-top:2px}.visibility-option--selected .visibility-option__radio{border-color:var(--color-primary)}.visibility-option--selected .visibility-option__radio:after{content:"";width:10px;height:10px;background:var(--color-primary);border-radius:50%}.visibility-option__icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-background-elevated);border-radius:var(--radius-md);flex-shrink:0;box-shadow:var(--shadow-xs)}.visibility-option__icon svg{width:20px;height:20px;color:var(--color-text-secondary)}.visibility-option--selected .visibility-option__icon{background:var(--color-primary)}.visibility-option--selected .visibility-option__icon svg{color:var(--color-text-inverse)}.visibility-option__content{display:flex;flex-direction:column;gap:2px;flex:1}.visibility-option__label{font-size:15px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.visibility-option__description{font-size:13px;color:var(--color-text-tertiary)}.invite-form{display:flex;flex-direction:column;gap:var(--space-4)}.invite-form__row{display:flex;gap:var(--space-3);align-items:flex-start}.invite-form__email{flex:1}.invite-form__role{width:160px;flex-shrink:0}.invite-form__role .select-wrapper{margin-bottom:0}.invite-form__role .famili-select__control{min-height:var(--input-height)!important}@media(max-width:640px){.invite-form__row{flex-wrap:wrap}.invite-form__email{width:100%}.invite-form__role{flex:1;width:auto}.invite-form__button{width:100%}}.invite-form__button{flex-shrink:0;height:var(--input-height)}.invites-table-wrapper{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-background-elevated)}.invites-table{width:100%;border-collapse:collapse;font-size:14px}.invites-table th{text-align:left;padding:var(--space-3) var(--space-4);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);background:var(--color-background-subtle);border-bottom:1px solid var(--color-border);font-size:12px;text-transform:uppercase;letter-spacing:.05em}.invites-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-subtle);color:var(--color-text-primary)}.invites-table tr:last-child td{border-bottom:none}.invites-table__email{font-weight:var(--font-weight-medium);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invites-table__role{display:inline-block;padding:2px 10px;background:var(--color-background-subtle);border-radius:var(--radius-full);font-size:12px;font-weight:var(--font-weight-medium)}.invites-table__status{display:inline-block;padding:2px 10px;border-radius:var(--radius-full);font-size:12px;font-weight:var(--font-weight-semibold)}.invites-table__status--pending{background:#fef3c7;color:#92400e}.invites-table__status--accepted{background:var(--color-primary-light);color:var(--color-primary)}.invites-table__actions{display:flex;gap:var(--space-2)}.invites-action{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;font-size:12px;font-weight:var(--font-weight-medium);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.invites-action svg{width:14px;height:14px}.invites-action--resend{color:var(--color-primary)}.invites-action--resend:hover{background:var(--color-primary-light)}.invites-action--remove{color:var(--color-danger)}.invites-action--remove:hover{background:rgba(var(--color-danger-rgb),.1)}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);background:var(--color-background-subtle);border-radius:var(--radius-lg);cursor:pointer}.toggle-row__label{font-size:15px;font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.toggle-switch{position:relative;width:48px;height:26px;background:var(--color-border-strong);border:none;border-radius:var(--radius-full);cursor:pointer;transition:background-color var(--transition-fast);padding:0}.toggle-switch__thumb{position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast)}.toggle-switch--on .toggle-switch__thumb{transform:translate(22px)}.share-link-section{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-4);background:var(--color-background-subtle);border-radius:var(--radius-lg);margin-top:var(--space-3);animation:fadeIn var(--transition-base)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.share-link-row{display:flex;gap:var(--space-2)}.share-link-input{flex:1;height:var(--input-height-sm);padding:0 var(--input-padding-x);font-size:13px;color:var(--color-text-secondary);background-color:var(--color-background-elevated);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-md);cursor:default}.share-link-copy{flex-shrink:0}.share-link-copy svg{width:16px;height:16px}.share-link-permission{display:flex;flex-direction:column;gap:0}.share-link-permission .select-wrapper{margin-bottom:0}.share-link-permission .select__label{margin-bottom:var(--space-2)}.share-link-note{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-3);background:var(--color-background-warm);border-radius:var(--radius-md);line-height:1.5}.share-link-note svg{width:16px;height:16px;flex-shrink:0;color:var(--color-text-tertiary);margin-top:2px}.privacy-options{display:flex;flex-direction:column;gap:var(--space-3)}.privacy-option{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-background-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:background-color var(--transition-fast)}.privacy-option:hover{background:var(--color-background-muted)}.privacy-option__checkbox{position:absolute;opacity:0;pointer-events:none}.privacy-option__checkmark{width:22px;height:22px;border:2px solid var(--color-border-strong);border-radius:var(--radius-sm);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);background:var(--color-background-elevated)}.privacy-option__checkbox:checked+.privacy-option__checkmark{background:var(--color-primary);border-color:var(--color-primary)}.privacy-option__checkbox:checked+.privacy-option__checkmark:after{content:"";width:6px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg);margin-bottom:2px}.privacy-option__label{flex:1;font-size:15px;font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.privacy-option__info{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);cursor:help;color:var(--color-text-tertiary);transition:color var(--transition-fast)}.privacy-option__info:hover{color:var(--color-primary)}.privacy-option__info svg{width:18px;height:18px}.share-toast{position:fixed;bottom:var(--space-6);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:var(--color-text-primary);color:var(--color-text-inverse);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);font-size:14px;font-weight:var(--font-weight-medium);z-index:var(--z-toast);animation:toastSlideUp var(--transition-base)}.share-toast svg{width:18px;height:18px}.share-toast--success{background:var(--color-primary)}.share-toast--error{background:var(--color-danger)}@keyframes toastSlideUp{0%{opacity:0;transform:translate(-50%,16px)}to{opacity:1;transform:translate(-50%)}}.confirm-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:calc(var(--z-modal) + 10);animation:fadeIn var(--transition-fast)}.confirm-dialog{background:var(--color-background-elevated);border-radius:var(--radius-xl);padding:var(--space-6);width:360px;max-width:calc(100vw - 48px);box-shadow:var(--shadow-xl);animation:scaleIn var(--transition-base)}.confirm-dialog__message{margin-bottom:var(--space-5);font-size:15px;line-height:1.5}.confirm-dialog__actions{display:flex;justify-content:flex-end;gap:var(--space-3)}@media(max-width:640px){.share-modal__content{padding:var(--space-5);gap:var(--space-6)}.share-modal__header{padding:var(--space-5)}.share-modal__title{font-size:18px}.visibility-option{padding:var(--space-3)}.visibility-option__icon{width:36px;height:36px}.invites-table{font-size:13px}.invites-table th,.invites-table td{padding:var(--space-2) var(--space-3)}.share-link-row{flex-direction:column}.share-link-copy{width:100%}.share-link-permission{flex-direction:column;align-items:flex-start}.share-link-permission__select{width:100%;max-width:none}}.union-editor-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;animation:unionFadeIn .3s ease}.union-editor-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:560px;max-height:85vh;background:#fff;border-radius:24px;box-shadow:0 20px 40px #0000001a;z-index:2001;display:flex;flex-direction:column;overflow:hidden;animation:unionSlideUp .3s ease}@keyframes unionFadeIn{0%{opacity:0}to{opacity:1}}@keyframes unionSlideUp{0%{opacity:0;transform:translate(-50%,-40%)}to{opacity:1;transform:translate(-50%,-50%)}}.union-editor-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e5e7eb}.union-editor-header h2{font-size:1.25rem;font-weight:600;color:#111827;margin:0}.union-editor-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:#f3f4f6;border-radius:50%;cursor:pointer;transition:background .2s}.union-editor-close:hover{background:#e5e7eb}.union-editor-close svg{width:18px;height:18px;color:#6b7280}.union-editor-body{padding:24px;overflow-y:auto;flex:1}.union-editor-section{margin-bottom:24px}.union-editor-section-title{font-size:.875rem;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px}.union-editor-person-list{display:flex;flex-direction:column;gap:8px}.union-editor-person-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px}.union-editor-person-avatar{width:36px;height:36px;border-radius:50%;background:#3b82f6;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;flex-shrink:0}.union-editor-person-name{flex:1;font-size:.9375rem;color:#111827}.union-editor-person-remove{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;cursor:pointer;color:#9ca3af;border-radius:6px;transition:color .2s,background .2s}.union-editor-person-remove:hover{color:#ef4444;background:#fef2f2}.union-editor-person-remove svg{width:16px;height:16px}.union-editor-add-btn{display:flex;align-items:center;gap:8px;padding:10px 14px;background:transparent;border:1px dashed #d1d5db;border-radius:12px;cursor:pointer;color:#6b7280;font-size:.875rem;transition:border-color .2s,color .2s;width:100%}.union-editor-add-btn:hover{border-color:#3b82f6;color:#3b82f6}.union-editor-add-btn svg{width:18px;height:18px}.union-editor-select{margin-top:8px}.union-editor-dates{display:grid;grid-template-columns:1fr 1fr;gap:16px}.union-editor-date-field label{display:block;font-size:.8125rem;color:#6b7280;margin-bottom:6px}.union-editor-date-field input{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:10px;font-size:.9375rem;color:#111827;transition:border-color .2s}.union-editor-date-field input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.union-editor-notes textarea{width:100%;min-height:80px;padding:10px 14px;border:1px solid #d1d5db;border-radius:12px;font-size:.9375rem;color:#111827;resize:vertical;font-family:inherit}.union-editor-notes textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.union-editor-notes label{display:block;font-size:.8125rem;color:#6b7280;margin-bottom:6px}.union-editor-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-top:1px solid #e5e7eb;gap:12px}.union-editor-footer-left,.union-editor-footer-right{display:flex;gap:8px}.union-editor-btn{padding:10px 20px;border-radius:12px;font-size:.9375rem;font-weight:500;cursor:pointer;border:none;transition:background .2s,color .2s}.union-editor-btn--cancel{background:#f3f4f6;color:#374151}.union-editor-btn--cancel:hover{background:#e5e7eb}.union-editor-btn--save{background:#3b82f6;color:#fff}.union-editor-btn--save:hover{background:#2563eb}.union-editor-btn--save:disabled{background:#93c5fd;cursor:not-allowed}.union-editor-btn--danger{background:transparent;color:#ef4444;border:1px solid #fca5a5}.union-editor-btn--danger:hover{background:#fef2f2}.union-editor-error{padding:10px 14px;background:#fef2f2;border:1px solid #fca5a5;border-radius:10px;color:#dc2626;font-size:.875rem;margin-bottom:16px}.union-editor-empty{text-align:center;padding:20px;color:#9ca3af;font-size:.875rem}.arm-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--color-background-elevated);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:860px;width:90%;height:680px;max-height:90vh;display:flex;flex-direction:column;z-index:1000;animation:armModalSlideUp .3s ease-out}.arm-overlay{position:fixed;inset:0;background:#00000080;z-index:999}.arm-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--color-border);flex-shrink:0}.arm-header__content{flex:1}.arm-header h2{margin-bottom:var(--space-2);font-size:var(--font-size-modal-title)}.arm-close{background:none;border:none;padding:var(--space-2);cursor:pointer;color:var(--color-text-tertiary);transition:color var(--transition-fast);flex-shrink:0}.arm-close:hover{color:var(--color-text-primary)}.arm-close svg{width:24px;height:24px}.arm-tabs{display:flex;border-bottom:1px solid var(--color-border);flex-shrink:0}.arm-tab{flex:1;padding:var(--space-4);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:15px;font-weight:var(--font-weight-medium);color:var(--color-text-secondary);transition:all var(--transition-fast)}.arm-tab:hover{color:var(--color-text-primary)}.arm-tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.arm-content{flex:1;overflow-y:auto;padding:var(--space-6) var(--space-8) var(--space-6) var(--space-6);width:100%}.arm-link-tab{display:flex;flex-direction:column;gap:var(--space-4);width:100%}.arm-search-section{display:flex;flex-direction:column;gap:var(--space-3);width:100%}.arm-search-input{position:relative;display:flex;align-items:center;width:100%}.arm-search-input svg{position:absolute;left:var(--space-3);width:18px;height:18px;color:var(--color-text-tertiary)}.arm-search-input input{width:100%;padding:var(--space-3) var(--space-3) var(--space-3) var(--space-10);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background-elevated);color:var(--color-text-primary);font-size:14px;transition:border-color var(--transition-fast)}.arm-search-input input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.arm-filter-chips{display:flex;gap:var(--space-2);flex-wrap:wrap}.arm-filter-chip{padding:var(--space-2) var(--space-3);background:var(--color-background-subtle);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:13px;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.arm-filter-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.arm-filter-chip--active{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary-dark)}.arm-memory-list{display:flex;flex-direction:column;gap:var(--space-3);width:100%}.arm-memory-item{display:flex;gap:var(--space-3);padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);width:100%}.arm-memory-item:hover{border-color:var(--color-primary);background:var(--color-background-subtle)}.arm-memory-item--selected{border-color:var(--color-primary);background:var(--color-primary-light)}.arm-memory-item__checkbox{width:24px;height:24px;border:2px solid var(--color-border-strong);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition-fast)}.arm-memory-item--selected .arm-memory-item__checkbox{background:var(--color-primary);border-color:var(--color-primary)}.arm-memory-item__checkbox svg{width:16px;height:16px;color:#fff}.arm-memory-item__image{width:80px;height:80px;border-radius:var(--radius-md);overflow:hidden;background:var(--color-background-subtle);flex-shrink:0}.arm-memory-item__image img{width:100%;height:100%;object-fit:cover}.arm-memory-item__placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary)}.arm-memory-item__placeholder svg{width:32px;height:32px}.arm-memory-item__content{flex:1;display:flex;flex-direction:column;gap:var(--space-1)}.arm-memory-item__description{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-top:var(--space-1)}.arm-create-tab{display:flex;flex-direction:column;gap:var(--space-4);width:100%}.arm-form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);width:100%}.arm-form-field{display:flex;flex-direction:column;gap:var(--space-2);width:100%}.arm-form-label{font-weight:var(--font-weight-medium);color:var(--color-text-primary);font-size:14px}.arm-form-input-date{padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background-elevated);color:var(--color-text-primary);font-size:14px;transition:border-color var(--transition-fast)}.arm-form-input-date:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.arm-form-textarea{width:100%;padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background-elevated);color:var(--color-text-primary);font-family:inherit;font-size:14px;resize:vertical;transition:border-color var(--transition-fast)}.arm-form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.arm-upload-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);border:2px dashed var(--color-border);border-radius:var(--radius-lg);background:var(--color-background-subtle);gap:var(--space-2);margin-bottom:var(--space-4);text-align:center}.arm-upload-placeholder svg{width:48px;height:48px;color:var(--color-text-tertiary)}.arm-loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-12);text-align:center;width:100%}.arm-spinner{width:32px;height:32px;color:var(--color-primary);animation:armSpin 1s linear infinite}@keyframes armSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.arm-error{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-danger-light, #FEE2E2);border:1px solid var(--color-danger, #EF4444);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.arm-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-12);text-align:center;width:100%}.arm-empty-state svg{width:64px;height:64px;color:var(--color-text-tertiary)}.arm-footer{padding:var(--space-6);border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:var(--space-3);flex-shrink:0}.arm-footer button{display:flex;align-items:center;gap:var(--space-2)}.arm-footer .arm-spinner{width:18px;height:18px}.arm-toast{position:absolute;bottom:var(--space-6);left:50%;transform:translate(-50%);padding:var(--space-4) var(--space-6);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:10;animation:armSlideUp .3s ease-out}.arm-toast--success{background:#10b981;color:#fff}.arm-toast--error{background:var(--color-danger);color:#fff}@keyframes armModalSlideUp{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}@keyframes armSlideUp{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}@media(max-width:768px){.arm-modal{max-width:95%;max-height:90vh}.arm-form-row{grid-template-columns:1fr}.arm-header,.arm-content{padding:var(--space-4)}.arm-footer{padding:var(--space-4);flex-direction:column-reverse}.arm-footer button{width:100%}.arm-filter-chips{overflow-x:auto;flex-wrap:nowrap}}.asl-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;animation:aslFadeIn .3s ease}.asl-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:500px;background:#fff;border-radius:24px;box-shadow:0 20px 40px #0000001a;z-index:2001;display:flex;flex-direction:column;overflow:hidden;animation:aslSlideUp .3s ease}@keyframes aslFadeIn{0%{opacity:0}to{opacity:1}}@keyframes aslSlideUp{0%{opacity:0;transform:translate(-50%,-40%)}to{opacity:1;transform:translate(-50%,-50%)}}.asl-header{padding:32px;display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1px solid #f0f0f0}.asl-header__content h2{margin-bottom:4px;color:#1a1a1a}.asl-close{background:#f5f5f5;border:none;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#666;transition:all .2s ease}.asl-close:hover{background:#eee;color:#111}.asl-close svg{width:18px;height:18px}.asl-content{padding:32px;max-height:60vh;overflow-y:auto}.asl-options{display:flex;flex-direction:column;gap:16px}.asl-option-card{display:flex;align-items:center;gap:20px;padding:20px;background:#f8f9fa;border:2px solid transparent;border-radius:16px;text-align:left;cursor:pointer;transition:all .2s ease;width:100%}.asl-option-card:hover{background:#fff;border-color:var(--color-primary, #6366f1);box-shadow:0 10px 25px #00000014;transform:translateY(-4px)}.asl-option-card:hover .asl-option-card__icon{background:var(--color-primary, #6366f1);color:#fff;box-shadow:0 4px 12px #6366f14d}.asl-option-card:hover .asl-option-card__icon svg{transform:scale(1.1)}.asl-option-card__icon{width:48px;height:48px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--color-primary, #6366f1);box-shadow:0 2px 6px #0000000d;transition:all .3s ease}.asl-option-card__icon svg{width:24px;height:24px;transition:all .3s ease}.asl-option-card__content{flex:1}.asl-search-view{display:flex;flex-direction:column;gap:20px}.asl-search-input-wrapper{position:relative;display:flex;align-items:center}.asl-search-input-wrapper svg{position:absolute;left:16px;width:20px;height:20px;color:#999}.asl-search-input{width:100%;padding:14px 14px 14px 48px;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:12px;font-size:15px;transition:all .2s ease}.asl-search-input:focus{background:#fff;border-color:var(--color-primary, #6366f1);box-shadow:0 0 0 4px #6366f11a;outline:none}.asl-results{display:flex;flex-direction:column;gap:8px;margin-top:8px}.asl-user-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;background:#fff;border:1px solid #f0f0f0;cursor:pointer;transition:all .2s ease;width:100%;text-align:left}.asl-user-item:hover{background:#f8f9fa;border-color:#e0e0e0}.asl-user-item--selected{background:#6366f10d;border-color:var(--color-primary, #6366f1)}.asl-user-avatar{width:40px;height:40px;background:#eef2ff;color:var(--color-primary, #6366f1);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.asl-user-info{flex:1}.asl-user-item svg{width:20px;height:20px;color:var(--color-primary, #6366f1)}.asl-empty{padding:32px;text-align:center}.asl-confirmation-box{margin-top:16px;padding:16px;background:#f0fdf4;border-radius:12px;border:1px solid #dcfce7}.asl-info-notice{display:flex;gap:12px;align-items:flex-start;color:#166534}.asl-info-notice svg{width:18px;height:18px;flex-shrink:0;margin-top:2px}.asl-footer{padding:24px 32px;background:#f9fafb;display:flex;justify-content:flex-end;gap:12px}:root{--card-bg: #ffffff;--card-border: #d4d4d4;--card-border-hover: #3d3d3d;--card-shadow: 0 1px 4px rgba(0, 0, 0, .06);--card-shadow-hover: 0 3px 10px rgba(0, 0, 0, .1);--card-deceased-opacity: .75;--avatar-male-bg: #7a9bb5;--avatar-female-bg: #b5908a;--avatar-other-bg: #8a9e8a;--heritage-green: #2F5D46}.person-card{position:absolute;display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 10px 14px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:8px;cursor:pointer;z-index:10;width:140px;box-shadow:var(--card-shadow);-webkit-user-select:none;user-select:none;text-align:center;transition:border-color .15s ease,box-shadow .15s ease}.person-card:hover{border-color:var(--card-border-hover);box-shadow:0 4px 12px #00000026;z-index:20}.person-card:focus{outline:none;border-color:var(--heritage-green);box-shadow:0 0 0 2px #2f5d4633}.person-card--selected{border:2px solid var(--fmp-navy, #1D2842);box-shadow:0 4px 12px #1d284240}.person-card--current-user{border-color:var(--heritage-green)}.person-card--deceased{opacity:var(--card-deceased-opacity)}.person-card--deceased .person-card__avatar{opacity:.6}.person-card--connected{border-color:var(--heritage-green)}.person-card--male{background:#fff;color:var(--fmp-navy, #1D2842)}.person-card--male .person-card__name{color:var(--fmp-navy, #1D2842)}.person-card--male .person-card__dates{color:#1d284299}.person-card--female{background:#fff;color:var(--fmp-navy, #1D2842)}.person-card--female .person-card__name{color:var(--fmp-navy, #1D2842)}.person-card--female .person-card__dates{color:#1d284299}.person-card--selected{background:var(--fmp-navy, #1D2842);color:#fff}.person-card--selected .person-card__name{color:#fff}.person-card--selected .person-card__dates{color:#ffffffb3}.person-card--selected .person-card__action-btn{background:#ffffff1f;color:#fffc}.person-card--selected .person-card__action-btn:hover{background:#fff3;color:#fff}.person-card--compact{padding:8px 6px 10px;gap:4px;width:90px}.person-card--compact .person-card__avatar{width:44px;height:44px;font-size:14px}.person-card--compact .person-card__name{font-size:10px}.person-card--compact .person-card__dates{font-size:9px}.person-card--placeholder{flex-direction:column;background:#fff;border:1px solid #d4d4d4;border-radius:8px;box-shadow:0 1px 3px #0000000f;color:var(--fmp-navy, #1D2842);width:140px;padding:16px 10px;text-align:center;gap:8px;display:flex;align-items:center;justify-content:center;transition:border-color .2s,box-shadow .2s;z-index:5}.person-card--placeholder:hover{border-color:var(--fmp-navy, #1D2842);box-shadow:0 2px 8px #0000001f;z-index:6}.person-card__placeholder-icon{width:36px;height:36px;margin:0 auto;color:var(--fmp-navy, #1D2842)}.person-card__placeholder-icon svg{width:100%;height:100%}.person-card__placeholder-text{font-size:12px;font-weight:600;color:var(--fmp-navy, #1D2842);text-align:center}.person-card__avatar{position:relative;flex-shrink:0;width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff;overflow:visible;border:2px solid var(--card-border)}.person-card--male .person-card__avatar{background:var(--avatar-male-bg)}.person-card--female .person-card__avatar{background:var(--avatar-female-bg)}.person-card--other .person-card__avatar,.person-card:not(.person-card--male):not(.person-card--female) .person-card__avatar{background:var(--avatar-other-bg)}.person-card__photo{width:100%;height:100%;object-fit:cover;border-radius:50%;position:absolute;inset:0}.person-card__initials{text-transform:uppercase;letter-spacing:.08em;font-size:inherit}.person-card__deceased-indicator{position:absolute;top:-2px;right:-2px;width:14px;height:14px;background:#6b7280;border-radius:50%;border:2px solid #ffffff}.person-card__deceased-indicator:after{content:"†";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff;font-weight:700}.person-card__badge{position:absolute;bottom:-6px;left:50%;transform:translate(-50%);font-size:8px;font-weight:700;padding:2px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.04em;border:2px solid #ffffff;white-space:nowrap}.person-card__badge--you{background:var(--heritage-green);color:#fff}.person-card__info{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:0;width:100%;text-align:center}.person-card__name{font-size:13px;font-weight:700;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.person-card__dates-row{display:flex;align-items:center;justify-content:center;gap:4px}.person-card__dates{font-size:11px;color:#888}.person-card__living-badge,.person-card__relation,.person-card__lineage,.person-card__lineage-dot,.person-card__lineage--maternal,.person-card__lineage--paternal{display:none}.person-card__connected-badge,.person-card__connected-badge svg{display:none}.person-card__actions{position:absolute;top:4px;right:4px;display:flex;gap:2px;opacity:0;transition:opacity .15s ease;pointer-events:none;z-index:30}.person-card:hover .person-card__actions,.person-card:focus-visible .person-card__actions{opacity:1;pointer-events:auto}.person-card__action-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;background:#0000000f;color:#555;border:none;border-radius:4px;cursor:pointer;transition:background .12s ease,color .12s ease}.person-card__action-btn:hover{background:#0000001f;color:#333}.person-card__action-btn svg{width:12px;height:12px}.person-card__add-btn{display:none}.person-card--focus{border-color:var(--fmp-gold, #D4A843);box-shadow:0 0 0 2px #d4a84333}.person-card__accent-bar{position:absolute;bottom:0;left:8px;right:8px;height:4px;border-radius:0 0 4px 4px}.person-card__accent-bar--male,.person-card__accent-bar--female{background:var(--fmp-gold, #D4A843)}.person-card__accent-bar--other{background:#999}.person-card__focus-badge{position:absolute;bottom:-12px;left:50%;transform:translate(-50%);background:var(--fmp-gold, #D4A843);color:#fff;font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 8px;border-radius:2px;white-space:nowrap;z-index:2}.person-card__focus-tab{position:absolute;right:-28px;top:50%;transform:translateY(-50%);width:28px;height:32px;border-radius:0 6px 6px 0;border:1px solid var(--card-border);border-left:none;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s,background .15s,box-shadow .15s;z-index:3;padding:0;box-shadow:2px 1px 4px #00000014}.person-card:hover .person-card__focus-tab,.person-card:focus-visible .person-card__focus-tab{opacity:1}.person-card__focus-tab:hover{background:#f5f5f5;box-shadow:2px 1px 6px #0000001f}.person-card__focus-tab svg{width:16px;height:16px;color:#555}.person-card__focus-tab:hover svg{color:#333}.person-card__focus-tooltip{position:absolute;left:calc(100% + 8px);top:50%;transform:translateY(-50%);background:#2d2d2d;color:#fff;font-size:12px;font-weight:500;padding:6px 12px;border-radius:6px;white-space:nowrap;pointer-events:none;z-index:100;line-height:1.3;opacity:0;transition:opacity .15s ease}.person-card__focus-tab:hover .person-card__focus-tooltip{opacity:1}.person-card__focus-tooltip:before{content:"";position:absolute;right:100%;top:50%;transform:translateY(-50%);border:5px solid transparent;border-right-color:#2d2d2d}.person-card--selected .person-card__focus-tab{background:#ffffffe6;border-color:#ffffff4d}.mini-person-card{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border:1px solid #d4d4d4;border-radius:8px}.mini-person-card--new{border-color:var(--heritage-green);background:linear-gradient(135deg,#2f5d460f,#fff);animation:pulse-border 2s ease-in-out infinite}@keyframes pulse-border{0%,to{box-shadow:0 0 #2f5d4666}50%{box-shadow:0 0 0 6px #2f5d4600}}.mini-person-card__avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;overflow:hidden;flex-shrink:0}.mini-person-card__avatar--male{background:var(--avatar-male-bg)}.mini-person-card__avatar--female{background:var(--avatar-female-bg)}.mini-person-card__avatar--other{background:var(--avatar-other-bg)}.mini-person-card__avatar img{width:100%;height:100%;object-fit:cover}.mini-person-card__info{display:flex;flex-direction:column;gap:1px;min-width:0}.mini-person-card__name{font-size:13px;font-weight:600;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-person-card__label{font-size:11px;color:#888}@media(max-width:768px){.person-card{padding:10px 8px 12px;gap:4px;width:110px}.person-card__avatar{width:52px;height:52px;font-size:16px}.person-card__name{font-size:11px}.person-card__dates{font-size:9px}.person-card__actions{opacity:1;pointer-events:auto}.person-card__focus-tab{opacity:1}}.person-card--selected{animation:card-select .25s ease}@keyframes card-select{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}:root{--connector-color: #3d3d3d;--connector-color-divorced: #999;--connector-color-highlight: #2F5D46;--connector-opacity: .7;--connector-opacity-hover: .9;--connector-junction-size: 3px;--connector-bg: #f5f0e8}.tree-connectors{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1;overflow:visible}.tree-connector{pointer-events:visibleStroke;cursor:pointer}.tree-connector__line{stroke:var(--connector-color);stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:miter;opacity:var(--connector-opacity);transition:opacity .2s ease,stroke .2s ease}.tree-connector--biological .tree-connector__line,.tree-connector--parent_child .tree-connector__line{stroke:var(--connector-color)}.tree-connector--adoptive .tree-connector__line{stroke:var(--connector-color);stroke-dasharray:8 4}.tree-connector--step .tree-connector__line{stroke:var(--connector-color);stroke-dasharray:2 4}.tree-connector--guardian .tree-connector__line{stroke:var(--connector-color);stroke-dasharray:12 4 2 4}.tree-connector--spouse .tree-connector__line{stroke:var(--connector-color);opacity:var(--connector-opacity)}.tree-connector--inlaw .tree-connector__line,.tree-connector--sibling .tree-connector__line{stroke:var(--connector-color);opacity:.5}.tree-connector:hover .tree-connector__line{opacity:var(--connector-opacity-hover);stroke-width:2.5px}.tree-connector--highlighted .tree-connector__line{stroke:var(--connector-color-highlight);opacity:var(--connector-opacity-hover);stroke-width:2px}@keyframes dash-animation{to{stroke-dashoffset:-20}}.tree-connector--animated .tree-connector__line{animation:dash-animation .5s linear infinite}.connector-junction{fill:var(--connector-color);stroke:var(--connector-bg);stroke-width:1.5px;transition:fill .2s ease,stroke-width .2s ease}.connector-junction--highlighted{fill:var(--connector-color-highlight);stroke-width:2px}.connector-vertical-drop,.connector-sibling-bar,.connector-child-drop{stroke:var(--connector-color);stroke-width:1.5px;stroke-linecap:round}.connector--ended .tree-connector__line{stroke:var(--connector-color-divorced);stroke-dasharray:6 4}.connector--ended .connector-junction{fill:var(--connector-color-divorced)}.tree-union-group{pointer-events:visibleStroke}.tree-union-group:hover .tree-connector__line{opacity:var(--connector-opacity-hover)}.tree-union-group:hover .connector-junction{transform:scale(1.2)}@media(max-width:768px){.tree-connector__line{stroke-width:1.5px}.tree-connector:hover .tree-connector__line{stroke-width:2px}.connector-junction{r:2px}.connector-sibling-bar{stroke-width:1.5px}}.tree-canvas-container{position:relative;flex:1;min-height:0;overflow:hidden;cursor:grab;-webkit-user-select:none;user-select:none;background:var(--fmp-beige, #F5EDE3)}.tree-canvas-container--dragging{cursor:grabbing}.generation-lane-sidebar{position:absolute;left:0;top:0;bottom:0;width:220px;background:transparent;z-index:100;pointer-events:none;overflow:visible}.generation-lane-pill{position:absolute;left:var(--space-4, 16px);font-size:11px;font-weight:700;color:var(--color-text-secondary, #666);text-transform:uppercase;letter-spacing:.08em;background:#fffffff2;padding:6px 12px;border-radius:999px;border:1px solid var(--color-border-subtle, #e0e0e0);box-shadow:0 2px 8px #00000014;white-space:nowrap;pointer-events:auto;transform:translateY(-50%)}.generation-lane-pill:hover{background:#fff;box-shadow:0 4px 12px #0000001f}.tree-canvas{position:absolute;inset:0;transform-origin:0 0;will-change:transform}.tree-canvas--animating{transition:transform .3s ease-out}.tree-minimap{position:absolute;bottom:80px;right:24px;width:160px;height:100px;background:var(--color-background-elevated, #fff);border:1px solid var(--color-border, #e0e0e0);border-radius:8px;box-shadow:0 4px 16px #0000001f;z-index:99;overflow:hidden;display:none}.tree-minimap__viewport{position:absolute;border:2px solid var(--color-primary, #2F4F3C);background:#2f4f3c1a;border-radius:4px;pointer-events:none}.tree-minimap__nodes{position:absolute;inset:4px}.tree-minimap__node{position:absolute;width:4px;height:4px;background:var(--color-text-tertiary, #888);border-radius:50%}.tree-minimap__node--current{background:var(--color-primary, #2F4F3C);width:6px;height:6px}.tree-canvas--pixel{position:relative;inset:auto}.tree-connectors--pixel{position:absolute;top:0;left:0}.person-card--pixel{position:absolute}@media(max-width:768px){.generation-lane-sidebar{display:none}.tree-zoom-controls{bottom:16px;right:16px;padding:6px;gap:4px}.tree-zoom-control{width:32px;height:32px}.tree-zoom-control svg{width:18px;height:18px}.tree-zoom-level{min-width:40px;font-size:12px}.tree-canvas-hint{bottom:16px;padding:6px 16px}.tree-canvas-hint span{font-size:11px}}@media(prefers-color-scheme:dark){.tree-canvas-container{background:var(--fmp-beige, #F5EDE3)}.generation-lane-pill{background:#1e1e1ef2;border-color:#333}.tree-zoom-controls,.tree-canvas-hint{background:#1e1e1e;border-color:#333}}.crop-modal-overlay{position:fixed;inset:0;background:#0009;z-index:999;animation:cropFadeIn .2s ease-out}.crop-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:520px;max-width:95vw;max-height:90vh;background:var(--color-background-elevated);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);z-index:1000;display:flex;flex-direction:column;overflow:hidden;animation:cropSlideUp .25s ease-out}.crop-modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border)}.crop-modal__title{font-size:18px;font-weight:600;color:var(--color-text-primary);margin:0}.crop-modal__close{width:32px;height:32px;border-radius:var(--radius-md);border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast)}.crop-modal__close:hover{background:var(--color-background-subtle);color:var(--color-text-primary)}.crop-modal__body{flex:1;display:flex;flex-direction:column}.crop-modal__canvas{position:relative;width:100%;height:350px;background:#111}.crop-modal__controls{padding:var(--space-4) var(--space-6)}.crop-modal__zoom-row{display:flex;align-items:center;gap:var(--space-3)}.crop-modal__zoom-icon{flex-shrink:0;color:var(--color-text-tertiary)}.crop-modal__zoom-slider{flex:1;height:4px;accent-color:var(--color-primary);cursor:pointer}.crop-modal__footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border)}.crop-modal__btn{padding:var(--space-2) var(--space-5);border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);border:none}.crop-modal__btn:disabled{opacity:.6;cursor:not-allowed}.crop-modal__btn--cancel{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}.crop-modal__btn--cancel:hover:not(:disabled){background:var(--color-background-subtle)}.crop-modal__btn--confirm{background:var(--color-primary);color:var(--color-text-inverse)}.crop-modal__btn--confirm:hover:not(:disabled){background:var(--color-primary-hover)}@keyframes cropFadeIn{0%{opacity:0}to{opacity:1}}@keyframes cropSlideUp{0%{opacity:0;transform:translate(-50%,-48%)}to{opacity:1;transform:translate(-50%,-50%)}}@media(max-width:480px){.crop-modal__canvas{height:280px}.crop-modal__header,.crop-modal__controls,.crop-modal__footer{padding-left:var(--space-4);padding-right:var(--space-4)}.crop-modal__footer{flex-direction:column}.crop-modal__btn{width:100%;text-align:center;padding:var(--space-3) var(--space-5)}}.toggle-group{display:flex;flex-direction:column;gap:4px}.toggle-group__label{font-size:.85rem;font-weight:500;color:var(--color-text-secondary, #666)}.toggle-group__options{display:flex;border:1px solid #ddd;border-radius:6px;overflow:hidden}.toggle-group__btn{flex:1;padding:8px 12px;border:none;background:#fff;font-size:13px;cursor:pointer;border-right:1px solid #ddd;transition:background .2s,color .2s;color:var(--color-text-primary, #333)}.toggle-group__btn:last-child{border-right:none}.toggle-group__btn--active{background:var(--color-primary, #2F5D46);color:var(--color-text-inverse, #fff)}.toggle-group__btn:hover:not(.toggle-group__btn--active){background:#f5f0e8}.profile-view{display:flex;flex-direction:column;gap:16px;padding:0 4px}.profile-view__header{display:flex;align-items:center;gap:14px}.profile-view__avatar{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#fff;flex-shrink:0;position:relative;cursor:pointer;overflow:hidden}.profile-view__avatar--male{background:linear-gradient(135deg,#4a90a4,#2f6b7f)}.profile-view__avatar--female{background:linear-gradient(135deg,#b4838d,#8b5a5a)}.profile-view__avatar--other{background:linear-gradient(135deg,#888,#666)}.profile-view__avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.profile-view__avatar-overlay{position:absolute;inset:0;border-radius:50%;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease}.profile-view__avatar:hover .profile-view__avatar-overlay{opacity:1}.profile-view__avatar-spinner{width:20px;height:20px;animation:avatarSpin 1s linear infinite}@keyframes avatarSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.profile-view__info{flex:1;min-width:0}.profile-view__name{font-size:18px;font-weight:600;margin:0 0 2px;color:var(--color-text-primary, #1a1a1a)}.profile-view__status{font-size:13px;color:var(--color-text-secondary, #666)}.profile-view__actions{display:flex;align-items:center;gap:8px}.profile-view__action-btn--primary{padding:8px 16px;background:var(--color-primary, #2F5D46);color:var(--color-text-inverse, #fff);border:none;border-radius:20px;font-size:13px;font-weight:500;cursor:pointer;transition:background var(--transition-base, .2s)}.profile-view__action-btn--primary:hover{background:var(--color-primary-hover, #264A38)}.profile-view__action-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid #ddd;border-radius:50%;background:#fff;cursor:pointer;color:var(--color-text-secondary, #666);transition:all .2s}.profile-view__action-icon:hover{border-color:var(--color-primary, #2F5D46);color:var(--color-primary, #2F5D46)}.profile-view__action-icon svg{width:16px;height:16px}.profile-view__action-icon--danger:hover{border-color:#d32f2f;color:#d32f2f}.profile-view__separator{height:3px;background:var(--fmp-gold, #D4A843);border-radius:2px}.profile-view__missing{background:var(--color-background-subtle, #f9f7f4);border-radius:8px;overflow:hidden}.profile-view__missing-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 14px;background:none;border:none;cursor:pointer;font-size:14px;font-weight:500;color:var(--color-text-primary, #1a1a1a)}.profile-view__chevron{display:flex;transition:transform .2s}.profile-view__chevron svg{width:16px;height:16px}.profile-view__chevron--open{transform:rotate(180deg)}.profile-view__missing-content{padding:0 14px 14px}.profile-view__missing-hint{font-size:13px;color:var(--color-text-secondary, #666);margin:0 0 6px}.profile-view__missing-prompt{font-size:13px;font-weight:500;margin:0 0 4px;color:var(--color-text-primary, #1a1a1a)}.profile-view__missing-list{margin:0;padding-left:20px;font-size:13px;color:var(--color-text-secondary, #666)}.profile-view__missing-list li{margin-bottom:2px}.profile-view__form{display:flex;flex-direction:column;gap:14px}.profile-view__field{display:flex;flex-direction:column;gap:4px}.profile-view__field-label{font-size:.85rem;font-weight:500;color:var(--color-text-secondary, #666)}.profile-view__field input[type=text]{padding:9px 12px;border:1px solid #ddd;border-radius:6px;font-size:.95rem;background:#fff;color:var(--color-text-primary, #1a1a1a);transition:border-color .15s}.profile-view__field input[type=text]:focus{outline:none;border-color:var(--color-primary, #2F5D46);box-shadow:0 0 0 2px #2f5d461f}.profile-view__field input[type=date]{width:100%;box-sizing:border-box;padding:9px 12px;border:1px solid #ddd;border-radius:6px;font-size:.95rem;font-family:inherit;background:#fff;color:var(--color-text-primary, #1a1a1a);transition:border-color .15s;appearance:none;-webkit-appearance:none}.profile-view__field input[type=date]:not(:valid){color:var(--color-text-secondary, #666)}.profile-view__field input[type=date]:focus{outline:none;border-color:var(--color-primary, #2F5D46);box-shadow:0 0 0 2px #2f5d461f}.profile-view__field input[type=date]::-webkit-calendar-picker-indicator{opacity:.55;cursor:pointer;border-radius:3px;padding:2px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232F5D46' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E");background-repeat:no-repeat;background-size:15px 15px;background-position:center;width:20px;height:20px;transition:opacity .15s}.profile-view__field input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1;background-color:#2f5d4614}.add-member-flow-v2{display:flex;flex-direction:column}.amf__step{display:flex;flex-direction:column;gap:16px}.amf__back-btn{display:flex;align-items:center;gap:4px;background:none;border:none;cursor:pointer;color:var(--color-text-secondary, #666);font-size:14px;padding:0;margin-bottom:4px}.amf__back-btn:hover{color:var(--color-text-primary, #1a1a1a)}.amf__context{display:flex;align-items:center;gap:12px;padding-bottom:12px;border-bottom:1px solid #eee}.amf__mini-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;flex-shrink:0}.amf__mini-avatar--male{background:linear-gradient(135deg,#4a90a4,#2f6b7f)}.amf__mini-avatar--female{background:linear-gradient(135deg,#b4838d,#8b5a5a)}.amf__mini-avatar--other{background:linear-gradient(135deg,#888,#666)}.amf__context-text{flex:1;min-width:0}.amf__heading{font-size:16px;font-weight:600;margin:0;color:var(--color-text-primary, #1a1a1a)}.amf__subtext{font-size:13px;color:var(--color-text-secondary, #666);margin:2px 0 0}.amf__prompt{font-size:14px;font-weight:500;color:var(--color-text-primary, #1a1a1a);margin:0}.amf__radio-list{display:flex;flex-direction:column;gap:8px}.amf__radio-option{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border:1px solid #ddd;border-radius:8px;cursor:pointer;transition:border-color .15s,background .15s}.amf__radio-option:hover{border-color:#bbb;background:#faf8f5}.amf__radio-option--selected{border-color:var(--color-primary, #2F5D46);background:var(--color-primary-light, rgba(47, 93, 70, .08))}.amf__radio-option--disabled{opacity:.5;cursor:not-allowed}.amf__radio-option--disabled:hover{border-color:#ddd;background:transparent}.amf__radio-option input[type=radio]{margin-top:3px;accent-color:var(--color-primary, #2F5D46)}.amf__radio-content{display:flex;flex-direction:column;gap:2px}.amf__radio-label{font-size:14px;font-weight:500;color:var(--color-text-primary, #1a1a1a)}.amf__radio-desc{font-size:12px;color:var(--color-text-secondary, #666)}.amf__step-actions{display:flex;flex-direction:column;gap:8px;margin-top:4px}.amf__btn{padding:11px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s,opacity .2s;text-align:center}.amf__btn:disabled{opacity:.5;cursor:not-allowed}.amf__btn--primary{background:var(--color-primary, #2F5D46);color:var(--color-text-inverse, #fff);border:none}.amf__btn--primary:hover:not(:disabled){background:var(--color-primary-hover, #264A38)}.amf__btn--secondary{background:var(--color-background-elevated, #fff);color:var(--color-primary, #2F5D46);border:1px solid var(--color-primary, #2F5D46)}.amf__btn--secondary:hover:not(:disabled){background:var(--color-background-subtle, #F7F6F4)}.amf__btn--full{width:100%}.amf__form{display:flex;flex-direction:column;gap:14px}.amf__photo-upload{display:flex;align-items:center;gap:12px;cursor:pointer;padding:8px 0}.amf__photo-placeholder{width:48px;height:48px;border-radius:50%;border:2px dashed #ccc;display:flex;align-items:center;justify-content:center;color:#999;flex-shrink:0;transition:border-color .2s,color .2s}.amf__photo-upload:hover .amf__photo-placeholder{border-color:var(--color-primary, #2F5D46);color:var(--color-primary, #2F5D46)}.amf__photo-preview-wrap{position:relative;flex-shrink:0}.amf__photo-preview{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid var(--color-border, #ddd)}.amf__photo-remove{position:absolute;top:-4px;right:-4px;width:18px;height:18px;border-radius:50%;background:var(--color-danger, #e53e3e);border:2px solid #fff;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:transform .15s}.amf__photo-remove:hover{transform:scale(1.15)}.amf__photo-label{font-size:.85rem;color:var(--color-primary, #2F5D46);font-weight:500}.amf__field{display:flex;flex-direction:column;gap:4px}.amf__field-label{font-size:.85rem;font-weight:500;color:var(--color-text-secondary, #666)}.amf__field input[type=text]{padding:9px 12px;border:1px solid #ddd;border-radius:6px;font-size:.95rem;background:#fff;color:var(--color-text-primary, #1a1a1a)}.amf__field input[type=text]:focus{outline:none;border-color:var(--color-primary, #2F5D46);box-shadow:0 0 0 2px #2f5d461f}.amf__field input[type=date]{width:100%;box-sizing:border-box;padding:9px 12px;border:1px solid #ddd;border-radius:6px;font-size:.95rem;font-family:inherit;background:#fff;color:var(--color-text-primary, #1a1a1a);transition:border-color .15s;appearance:none;-webkit-appearance:none}.amf__field input[type=date]:not(:valid){color:var(--color-text-secondary, #666)}.amf__field input[type=date]:focus{outline:none;border-color:var(--color-primary, #2F5D46);box-shadow:0 0 0 2px #2f5d461f}.amf__field input[type=date]::-webkit-calendar-picker-indicator{color:var(--color-primary, #2F5D46);opacity:.55;cursor:pointer;border-radius:3px;padding:2px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232F5D46' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E");background-repeat:no-repeat;background-size:15px 15px;background-position:center;-webkit-filter:none;filter:none;width:20px;height:20px;transition:opacity .15s}.amf__field input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1;background-color:#2f5d4614}.amf__field--checkbox{flex-direction:row;align-items:center;gap:8px}.amf__field--checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-primary, #2F5D46)}.amf__field--checkbox span{font-size:13px;color:var(--color-text-secondary, #666)}.amf__error{color:#d32f2f;font-size:13px;margin:0}.child-attribution{display:flex;flex-direction:column;gap:16px}.child-attribution__back{display:flex;align-items:center;gap:4px;background:none;border:none;cursor:pointer;color:var(--color-text-secondary, #666);font-size:14px;padding:0;margin-bottom:4px}.child-attribution__back:hover{color:var(--color-text-primary, #1a1a1a)}.child-attribution__context{display:flex;align-items:center;gap:12px;padding-bottom:12px;border-bottom:1px solid #eee}.child-attribution__mini-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;flex-shrink:0}.child-attribution__mini-avatar--male{background:linear-gradient(135deg,#4a90a4,#2f6b7f)}.child-attribution__mini-avatar--female{background:linear-gradient(135deg,#b4838d,#8b5a5a)}.child-attribution__mini-avatar--other{background:linear-gradient(135deg,#888,#666)}.child-attribution__heading{font-size:16px;font-weight:600;margin:0}.child-attribution__subtext{font-size:13px;color:var(--color-text-secondary, #666);margin:2px 0 0}.child-attribution__prompt{font-size:14px;font-weight:500;margin:0;color:var(--color-text-primary, #1a1a1a)}.child-attribution__options{display:flex;flex-direction:column;gap:8px}.child-attribution__option{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border:1px solid #ddd;border-radius:8px;cursor:pointer;transition:border-color .15s,background .15s}.child-attribution__option:hover{border-color:#bbb;background:#faf8f5}.child-attribution__option--selected{border-color:var(--color-primary, #2F5D46);background:var(--color-primary-light, rgba(47, 93, 70, .08))}.child-attribution__option input[type=radio]{margin-top:2px;accent-color:var(--color-primary, #2F5D46)}.child-attribution__option-content{display:flex;flex-direction:column;gap:8px;flex:1}.child-attribution__option-label{font-size:14px;font-weight:500}.child-attribution__children-list{display:flex;flex-direction:column;gap:8px}.child-attribution__child-row{display:flex;align-items:center;gap:10px}.child-attribution__child-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:#fff;flex-shrink:0}.child-attribution__child-avatar--male{background:#4a90a4}.child-attribution__child-avatar--female{background:#b4838d}.child-attribution__child-avatar--other{background:#888}.child-attribution__child-info{display:flex;flex-direction:column}.child-attribution__child-name{font-size:13px;font-weight:500}.child-attribution__child-status{font-size:11px;color:var(--color-text-secondary, #666)}.child-attribution__btn{width:100%;padding:11px 16px;background:var(--color-primary, #2F5D46);color:var(--color-text-inverse, #fff);border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background var(--transition-base, .2s),opacity var(--transition-base, .2s)}.child-attribution__btn:disabled{opacity:.5;cursor:not-allowed}.child-attribution__btn:hover:not(:disabled){background:var(--color-primary-hover, #264A38)}.parent-attribution{display:flex;flex-direction:column;gap:16px}.parent-attribution__back{display:flex;align-items:center;gap:4px;background:none;border:none;cursor:pointer;color:var(--color-text-secondary, #666);font-size:14px;padding:0;margin-bottom:4px}.parent-attribution__back:hover{color:var(--color-text-primary, #1a1a1a)}.parent-attribution__context{display:flex;align-items:center;gap:12px;padding-bottom:12px;border-bottom:1px solid #eee}.parent-attribution__mini-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;flex-shrink:0}.parent-attribution__mini-avatar--male{background:linear-gradient(135deg,#4a90a4,#2f6b7f)}.parent-attribution__mini-avatar--female{background:linear-gradient(135deg,#b4838d,#8b5a5a)}.parent-attribution__mini-avatar--other{background:linear-gradient(135deg,#888,#666)}.parent-attribution__heading{font-size:16px;font-weight:600;margin:0}.parent-attribution__subtext{font-size:13px;color:var(--color-text-secondary, #666);margin:2px 0 0}.parent-attribution__prompt{font-size:14px;font-weight:500;margin:0;color:var(--color-text-primary, #1a1a1a)}.parent-attribution__options{display:flex;flex-direction:column;gap:8px}.parent-attribution__option{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border:1px solid #ddd;border-radius:8px;cursor:pointer;transition:border-color .15s,background .15s}.parent-attribution__option:hover{border-color:#bbb;background:#faf8f5}.parent-attribution__option--selected{border-color:var(--color-primary, #2F5D46);background:var(--color-primary-light, rgba(47, 93, 70, .08))}.parent-attribution__option input[type=radio]{margin-top:2px;accent-color:var(--color-primary, #2F5D46)}.parent-attribution__option-content{display:flex;flex-direction:column;gap:8px;flex:1}.parent-attribution__option-label{font-size:14px;font-weight:500}.parent-attribution__family-unit{display:flex;flex-direction:column;gap:10px}.parent-attribution__person-row{display:flex;align-items:center;gap:10px}.parent-attribution__person-row--child{padding-left:8px}.parent-attribution__person-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#fff;flex-shrink:0}.parent-attribution__person-avatar--small{width:28px;height:28px;font-size:12px}.parent-attribution__person-avatar--male{background:#4a90a4}.parent-attribution__person-avatar--female{background:#b4838d}.parent-attribution__person-avatar--other{background:#888}.parent-attribution__person-info{display:flex;flex-direction:column}.parent-attribution__person-name{font-size:13px;font-weight:500}.parent-attribution__person-status{font-size:11px;color:var(--color-text-secondary, #666)}.parent-attribution__children-section{display:flex;flex-direction:column;gap:6px;padding-top:4px;border-top:1px solid #eee}.parent-attribution__children-label{font-size:11px;font-weight:500;color:var(--color-text-secondary, #888);text-transform:capitalize}.parent-attribution__btn{width:100%;padding:11px 16px;background:var(--color-primary, #2F5D46);color:var(--color-text-inverse, #fff);border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background var(--transition-base, .2s),opacity var(--transition-base, .2s)}.parent-attribution__btn:disabled{opacity:.5;cursor:not-allowed}.parent-attribution__btn:hover:not(:disabled){background:var(--color-primary-hover, #264A38)}.success-confirmation{display:flex;flex-direction:column;align-items:center;gap:20px;padding:16px 4px;text-align:center}.success-confirmation__graphic{margin-top:8px}.success-confirmation__emoji{font-size:56px;line-height:1}.success-confirmation__title{font-size:20px;font-weight:600;margin:0;color:var(--color-text-primary, #1a1a1a)}.success-confirmation__card{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--color-background-subtle, #f9f7f4);border-radius:10px;width:100%;max-width:260px}.success-confirmation__avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;flex-shrink:0}.success-confirmation__avatar--male{background:linear-gradient(135deg,#4a90a4,#2f6b7f)}.success-confirmation__avatar--female{background:linear-gradient(135deg,#b4838d,#8b5a5a)}.success-confirmation__avatar--other{background:linear-gradient(135deg,#888,#666)}.success-confirmation__card-info{display:flex;flex-direction:column;align-items:flex-start}.success-confirmation__card-name{font-size:15px;font-weight:600;color:var(--color-text-primary, #1a1a1a)}.success-confirmation__card-status{font-size:12px;color:var(--color-text-secondary, #666)}.success-confirmation__message{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--color-text-primary, #1a1a1a)}.success-confirmation__check{display:flex;color:#2e7d32}.success-confirmation__actions{display:flex;flex-direction:column;gap:8px;width:100%}.success-confirmation__btn{width:100%;padding:11px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s;text-align:center}.success-confirmation__btn--primary{background:var(--color-primary, #2F5D46);color:var(--color-text-inverse, #fff);border:none}.success-confirmation__btn--primary:hover{background:var(--color-primary-hover, #264A38)}.success-confirmation__btn--secondary{background:var(--color-background-elevated, #fff);color:var(--color-primary, #2F5D46);border:1px solid var(--color-primary, #2F5D46)}.success-confirmation__btn--secondary:hover{background:var(--color-background-subtle, #F7F6F4)}.success-confirmation__invite-btn{display:flex;align-items:center;justify-content:center;gap:8px;background:none;border:1px dashed var(--color-primary, #2F5D46);border-radius:6px;padding:10px 16px;color:var(--color-primary, #2F5D46);font-size:13px;font-weight:500;cursor:pointer;width:100%;transition:background .2s}.success-confirmation__invite-btn:hover{background:#2f5d460f}.success-confirmation__invite-form{display:flex;flex-direction:column;gap:8px;width:100%}.success-confirmation__invite-label{font-size:13px;color:var(--color-text-secondary, #666);text-align:left}.success-confirmation__invite-input{padding:9px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;width:100%;box-sizing:border-box}.success-confirmation__invite-input:focus{outline:none;border-color:var(--color-primary, #2F5D46);box-shadow:0 0 0 2px #2f5d461f}.success-confirmation__invite-error{font-size:12px;color:var(--color-danger, #e53e3e);margin:0;text-align:left}.success-confirmation__invite-actions{display:flex;gap:8px}.success-confirmation__invite-cancel{flex:1;padding:8px 12px;border:1px solid #ddd;border-radius:6px;background:#fff;color:var(--color-text-secondary, #666);font-size:13px;font-weight:500;cursor:pointer}.success-confirmation__invite-send{flex:1;padding:8px 12px;border:none;border-radius:6px;background:var(--color-primary, #2F5D46);color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s}.success-confirmation__invite-send:hover:not(:disabled){background:var(--color-primary-hover, #264A38)}.success-confirmation__invite-send:disabled,.success-confirmation__invite-cancel:disabled{opacity:.6;cursor:not-allowed}.success-confirmation__invite-sent{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:#2e7d3214;border-radius:6px;color:#2e7d32;font-size:13px;font-weight:500;width:100%}.search-existing-person{display:flex;flex-direction:column;gap:16px}.sep__back-btn{display:flex;align-items:center;gap:4px;background:none;border:none;cursor:pointer;color:var(--color-text-secondary, #666);font-size:14px;padding:0;margin-bottom:4px}.sep__back-btn:hover{color:var(--color-text-primary, #1a1a1a)}.sep__context{display:flex;align-items:center;gap:12px;padding-bottom:12px;border-bottom:1px solid #eee}.sep__mini-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;flex-shrink:0}.sep__mini-avatar--male{background:linear-gradient(135deg,#4a90a4,#2f6b7f)}.sep__mini-avatar--female{background:linear-gradient(135deg,#b4838d,#8b5a5a)}.sep__mini-avatar--other{background:linear-gradient(135deg,#888,#666)}.sep__context-text{flex:1;min-width:0}.sep__heading{font-size:16px;font-weight:600;margin:0;color:var(--color-text-primary, #1a1a1a)}.sep__subtext{font-size:13px;color:var(--color-text-secondary, #666);margin:2px 0 0}.sep__search-wrapper{position:relative}.sep__search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--color-text-secondary, #999);pointer-events:none;display:flex}.sep__search-input{width:100%;padding:9px 12px 9px 34px;border:1px solid #ddd;border-radius:6px;font-size:.95rem;background:#fff;color:var(--color-text-primary, #1a1a1a);box-sizing:border-box}.sep__search-input:focus{outline:none;border-color:var(--color-primary, #2F5D46);box-shadow:0 0 0 2px #2f5d461f}.sep__error{color:#d32f2f;font-size:13px;margin:0}.sep__linking{font-size:13px;color:var(--color-text-secondary, #666);margin:0}.sep__list{display:flex;flex-direction:column;gap:2px}.sep__person-item{display:flex;align-items:center;gap:12px;padding:8px 10px;border:none;background:none;border-radius:6px;cursor:pointer;text-align:left;transition:background .15s}.sep__person-item:hover:not(:disabled){background:var(--fmp-beige, #F5EDE3)}.sep__person-item:disabled{opacity:.5;cursor:not-allowed}.sep__person-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0}.sep__person-avatar--male{background:linear-gradient(135deg,#4a90a4,#2f6b7f)}.sep__person-avatar--female{background:linear-gradient(135deg,#b4838d,#8b5a5a)}.sep__person-avatar--other{background:linear-gradient(135deg,#888,#666)}.sep__person-info{display:flex;flex-direction:column;gap:1px;min-width:0}.sep__person-name{font-size:14px;font-weight:500;color:var(--color-text-primary, #1a1a1a);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sep__person-status{font-size:12px;color:var(--color-text-secondary, #666)}.sep__empty{font-size:14px;color:var(--color-text-secondary, #666);text-align:center;padding:24px 0;margin:0}.bottom-bar{position:absolute;bottom:0;left:0;right:0;height:48px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:#fff;border-top:1px solid #e0e0e0;z-index:50}.bottom-bar__group{display:flex;align-items:center;gap:4px}.bottom-bar__btn{width:36px;height:36px;border:none;background:transparent;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#555;transition:background .15s,color .15s}.bottom-bar__btn:hover{background:#f0f0f0;color:var(--fmp-navy, #1D2842)}.bottom-bar__btn svg{width:18px;height:18px}.bottom-bar__btn--label{width:auto;padding:0 10px;gap:5px}.bottom-bar__btn-text{font-size:12px;font-weight:600;color:inherit;white-space:nowrap}.bottom-bar__new-btn{padding:6px 20px;border:none;border-radius:6px;background:#d4edda;color:#1d2842;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.bottom-bar__new-btn:hover{background:#c3e6cb}.bottom-bar__zoom-level{min-width:40px;text-align:center;font-size:12px;font-weight:600;color:#666;font-variant-numeric:tabular-nums}@media(max-width:480px){.bottom-bar{padding:0 8px}.bottom-bar__new-btn{padding:6px 14px;font-size:12px}.bottom-bar__btn-text{display:none}.bottom-bar__btn--label{width:36px;padding:0}}.top-toolbar{position:absolute;top:16px;right:16px;display:flex;align-items:center;gap:8px;z-index:50}.top-toolbar__btn{width:36px;height:36px;border:none;background:#fff;border-radius:8px;box-shadow:0 1px 4px #0000001a;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#555;transition:background .15s,color .15s,box-shadow .15s}.top-toolbar__btn:hover{background:#f5f5f5;color:var(--fmp-navy, #1D2842);box-shadow:0 2px 8px #00000026}.top-toolbar__btn svg{width:18px;height:18px}@media(max-width:768px){.top-toolbar{top:12px;right:12px}}.tree-search-overlay{position:absolute;top:16px;left:50%;transform:translate(-50%);width:340px;max-width:calc(100% - 200px);z-index:110;animation:searchSlideDown .15s ease-out}@keyframes searchSlideDown{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.tree-search-overlay__input-wrap{position:relative;display:flex;align-items:center}.tree-search-overlay__icon{position:absolute;left:12px;width:16px;height:16px;color:#888;pointer-events:none}.tree-search-overlay__input{width:100%;padding:10px 12px 10px 36px;font-size:14px;border:none;border-radius:8px;background:#fff;box-shadow:0 2px 12px #00000026;outline:none;color:#222}.tree-search-overlay__input::placeholder{color:#aaa}.tree-search-overlay__input:focus{box-shadow:0 2px 16px #0003}.tree-search-overlay__close{position:absolute;right:8px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:4px;cursor:pointer;color:#888}.tree-search-overlay__close:hover{background:#f0f0f0;color:#333}.tree-search-overlay__close svg{width:14px;height:14px}.tree-search-overlay__results{margin-top:4px;background:#fff;border-radius:8px;box-shadow:0 4px 16px #0000001f;max-height:280px;overflow-y:auto}.tree-search-overlay__result{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .1s ease;border-bottom:1px solid #f0f0f0}.tree-search-overlay__result:last-child{border-bottom:none}.tree-search-overlay__result:hover{background:#f8f6f2}.tree-search-overlay__result-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.tree-search-overlay__result-avatar--male{background:#7a9bb5}.tree-search-overlay__result-avatar--female{background:#b5908a}.tree-search-overlay__result-avatar--other{background:#8a9e8a}.tree-search-overlay__result-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.tree-search-overlay__result-info{display:flex;flex-direction:column;gap:1px;min-width:0}.tree-search-overlay__result-name{font-size:13px;font-weight:600;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-search-overlay__result-detail{font-size:11px;color:#888}.tree-search-overlay__empty{padding:16px;text-align:center;color:#888;font-size:13px}@media(max-width:768px){.tree-search-overlay{width:calc(100% - 32px);max-width:none}}.confirm-modal-overlay{position:fixed;inset:0;background:#00000080;z-index:calc(var(--z-modal) + 10);animation:confirmFadeIn .2s ease-out}.confirm-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:420px;max-width:90vw;background:var(--color-background-elevated);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--space-8);text-align:center;z-index:calc(var(--z-modal) + 11);animation:confirmSlideUp .25s ease-out}@keyframes confirmSlideUp{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}@keyframes confirmFadeIn{0%{opacity:0}to{opacity:1}}.confirm-modal__icon{width:56px;height:56px;margin:0 auto var(--space-4);border-radius:50%;display:flex;align-items:center;justify-content:center}.confirm-modal__icon svg{width:28px;height:28px}.confirm-modal__icon--danger{background:rgba(var(--color-danger-rgb),.1);color:var(--color-danger)}.confirm-modal__icon--warning{background:#fef3c7;color:#d97706}.confirm-modal__title{font-size:16px;margin-bottom:var(--space-3)}.confirm-modal__description{margin-bottom:var(--space-6);line-height:1.6}.confirm-modal__actions{display:flex;gap:var(--space-3);justify-content:center}.confirm-modal__actions .btn{min-width:120px}@media(max-width:480px){.confirm-modal{padding:var(--space-6)}.confirm-modal__actions{flex-direction:column}.confirm-modal__actions .btn{width:100%}}.profile-header{position:relative;background:var(--color-background);padding-bottom:var(--space-16)}.profile-header__cover{position:relative;height:280px;overflow:hidden}@media(min-width:768px){.profile-header__cover{height:360px}}.profile-header__cover-img{width:100%;height:100%;object-fit:cover;object-position:center 30%}.profile-header__cover-overlay{position:absolute;inset:0;background:linear-gradient(180deg,#0000001a,#0000004d 60%,#00000080)}.profile-header__content{position:relative;margin-top:-120px}.profile-header__breadcrumb{margin-bottom:var(--space-6)}.breadcrumb-link{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-full);font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.breadcrumb-link:hover{background:var(--color-background-elevated);color:var(--color-primary);transform:translate(-4px)}.breadcrumb-link svg{width:16px;height:16px}.profile-card{display:grid;grid-template-columns:1fr;gap:var(--space-6);background:var(--color-background-elevated);border-radius:var(--radius-2xl);padding:var(--space-6);box-shadow:var(--shadow-lg);border:var(--border-width) solid var(--color-border-subtle)}@media(min-width:768px){.profile-card{grid-template-columns:auto 1fr;gap:var(--space-8);padding:var(--space-8)}}.profile-card__avatar-wrapper{display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.profile-card__avatar{width:140px;height:140px;border-radius:50%;overflow:hidden;border:5px solid var(--color-background-elevated);box-shadow:0 0 0 3px var(--color-primary),0 8px 32px #2f5d4640;flex-shrink:0}@media(min-width:768px){.profile-card__avatar{width:180px;height:180px;border-width:6px}}.profile-card__avatar img{width:100%;height:100%;object-fit:cover}.profile-card__generation{display:inline-block;padding:var(--space-1) var(--space-3);background:var(--color-primary-light);color:var(--color-primary);font-size:12px;font-weight:var(--font-weight-semibold);border-radius:var(--radius-full);letter-spacing:.02em}.profile-card__info{min-width:0}.profile-card__header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-4)}.profile-card__name{font-size:32px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1.2;letter-spacing:-.02em;margin:0}@media(min-width:768px){.profile-card__name{font-size:38px}}.profile-card__nickname{font-size:var(--font-size-body);color:var(--color-text-tertiary);font-style:italic;margin-top:var(--space-1)}.profile-card__actions{display:flex;gap:var(--space-2)}.profile-action-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-primary);color:var(--color-text-inverse);border-radius:var(--radius-lg);font-size:var(--font-size-small);font-weight:var(--font-weight-medium);transition:all var(--transition-base)}.profile-action-btn svg{width:16px;height:16px}.profile-action-btn:hover{background:var(--color-primary-hover);transform:translateY(-1px)}.profile-action-btn--secondary{background:var(--color-background-subtle);color:var(--color-text-secondary);padding:var(--space-2)}.profile-action-btn--secondary:hover{background:var(--color-border);color:var(--color-text-primary)}.profile-card__meta{display:flex;flex-wrap:wrap;gap:var(--space-4);margin-bottom:var(--space-5)}.profile-meta-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-small);color:var(--color-text-secondary)}.profile-meta-item svg{width:16px;height:16px;color:var(--color-primary);flex-shrink:0}.profile-card__bio{font-size:var(--font-size-body);line-height:1.7;color:var(--color-text-secondary);margin-bottom:var(--space-6);max-width:700px}.profile-card__quote{position:relative;padding:var(--space-5);background:linear-gradient(135deg,var(--color-background-primary) 0%,var(--color-background-warm) 100%);border-radius:var(--radius-xl);border-left:4px solid var(--color-primary)}.quote-icon{position:absolute;top:var(--space-3);right:var(--space-4);width:48px;height:48px}.quote-icon svg{width:100%;height:100%;color:var(--color-primary)}.profile-card__quote blockquote{font-size:17px;font-style:italic;line-height:1.6;color:var(--color-text-primary);margin:0;max-width:600px}.profile-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4);margin-top:var(--space-8)}@media(min-width:640px){.profile-stats{grid-template-columns:repeat(4,1fr)}}.profile-stat{display:flex;flex-direction:column;align-items:center;padding:var(--space-5);background:var(--color-background-elevated);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-xl);text-align:center;transition:all var(--transition-base)}.profile-stat:hover{border-color:var(--color-primary);box-shadow:0 4px 12px #2f5d461a;transform:translateY(-2px)}.profile-stat__value{font-size:28px;font-weight:var(--font-weight-bold);color:var(--color-primary);line-height:1.2}.profile-stat__label{font-size:var(--font-size-small);color:var(--color-text-tertiary);margin-top:var(--space-1)}.section-header{display:flex;flex-wrap:wrap;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-10)}.section-header__icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--color-primary-light);border-radius:var(--radius-lg);flex-shrink:0}.section-header__icon svg{width:28px;height:28px;color:var(--color-primary)}.section-header__subtitle{margin-top:var(--space-2);max-width:500px}.section-header__action{margin-left:auto}.section-header__action svg{width:16px;height:16px}.timeline-section{background:var(--color-background-cool)}.timeline{position:relative;max-width:900px;margin:0 auto;padding:var(--space-6) 0}.timeline__line{position:absolute;left:24px;top:0;bottom:100px;width:2px;background:linear-gradient(180deg,var(--color-primary) 0%,rgba(47,93,70,.3) 100%)}@media(min-width:768px){.timeline__line{left:50%;transform:translate(-50%)}}.timeline-event{position:relative;display:grid;grid-template-columns:60px 1fr;gap:var(--space-4);margin-bottom:var(--space-8);padding-left:var(--space-2)}@media(min-width:768px){.timeline-event{grid-template-columns:1fr 100px 1fr;gap:var(--space-6);padding-left:0}.timeline-event--left .timeline-event__content{grid-column:1;grid-row:1;text-align:right}.timeline-event--left .timeline-event__marker{grid-column:2;grid-row:1}.timeline-event--right .timeline-event__content{grid-column:3}.timeline-event--right .timeline-event__marker{grid-column:2}.timeline-event--left .timeline-event__card{margin-left:auto}}.timeline-event__marker{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);position:relative;z-index:1}.timeline-event__icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-background-elevated);border:3px solid var(--color-primary);border-radius:50%;box-shadow:var(--shadow-md);transition:all var(--transition-base)}.timeline-event__icon svg{width:22px;height:22px;color:var(--color-primary)}.timeline-event:hover .timeline-event__icon{transform:scale(1.1);box-shadow:0 4px 16px #2f5d4640}.timeline-event__icon--birth{background:linear-gradient(135deg,#ffeef2,#ffe4ec);border-color:#e91e63}.timeline-event__icon--birth svg{color:#e91e63}.timeline-event__icon--education{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-color:#1976d2}.timeline-event__icon--education svg{color:#1976d2}.timeline-event__icon--marriage{background:linear-gradient(135deg,#fce4ec,#f8bbd9);border-color:#c2185b}.timeline-event__icon--marriage svg{color:#c2185b}.timeline-event__icon--child{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border-color:#ff9800}.timeline-event__icon--child svg{color:#ff9800}.timeline-event__icon--career{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-color:var(--color-primary)}.timeline-event__icon--achievement{background:linear-gradient(135deg,#fff8e1,#ffecb3);border-color:#ffc107}.timeline-event__icon--achievement svg{color:#ffc107}.timeline-event__year{font-size:12px;font-weight:var(--font-weight-bold);color:var(--color-primary);background:var(--color-background-elevated);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);white-space:nowrap}.timeline-event__card{padding:var(--space-5);background:var(--color-background-elevated);border-radius:var(--radius-xl);border:var(--border-width) solid var(--color-border);transition:all var(--transition-base);max-width:400px}.timeline-event:hover .timeline-event__card{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.timeline-event__date{display:inline-block;font-size:12px;font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);margin-bottom:var(--space-2);text-transform:uppercase;letter-spacing:.05em}.timeline-event__title{font-size:18px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-2)}.timeline-event__description{font-size:var(--font-size-small);line-height:1.6;color:var(--color-text-secondary);margin:0}.timeline-add{display:flex;justify-content:center;padding-top:var(--space-6);position:relative;z-index:2}.timeline-add__btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background:var(--color-background-elevated);border:2px dashed var(--color-border-strong);border-radius:var(--radius-full);font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);transition:all var(--transition-base)}.timeline-add__btn span{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-light);border-radius:50%;color:var(--color-primary);font-size:18px}.timeline-add__btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.memories-section{background:var(--color-background-warm)}.memories-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}@media(min-width:768px){.memories-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-5)}}@media(min-width:1024px){.memories-grid{grid-template-columns:repeat(4,1fr)}}.memory-card{position:relative;border-radius:var(--radius-xl);overflow:hidden;background:var(--color-background-elevated);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.memory-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.memory-card__image{position:relative;aspect-ratio:4 / 3;overflow:hidden}.memory-card__image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.memory-card:hover .memory-card__image img{transform:scale(1.05)}.memory-card__overlay{position:absolute;top:var(--space-3);left:var(--space-3)}.memory-card__date{display:inline-block;padding:var(--space-1) var(--space-3);background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:var(--radius-full);font-size:11px;font-weight:var(--font-weight-semibold);color:#fff;letter-spacing:.03em}.memory-card__title{font-size:15px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-1);line-height:1.3}.memory-card__description{font-size:13px;color:var(--color-text-tertiary);margin:0;line-height:1.4}.memory-card--featured{grid-column:span 2;grid-row:span 2}.memory-card--featured .memory-card__image{aspect-ratio:auto;height:100%;min-height:300px}.memory-card--featured .memory-card__content{position:absolute;bottom:0;left:0;right:0;padding:var(--space-6);background:linear-gradient(to top,rgba(0,0,0,.8),transparent)}.memory-card--featured .memory-card__title{font-size:20px;color:#fff;margin-bottom:var(--space-2)}.memory-card--featured .memory-card__description{color:#fffc}.memory-card--featured .memory-card__overlay{top:var(--space-4);left:var(--space-4)}.memory-card--featured .memory-card__date{font-size:12px;padding:var(--space-2) var(--space-4)}.memories-cta{display:flex;justify-content:center;margin-top:var(--space-10)}.memories-cta svg{width:18px;height:18px}.relationships-section{background:var(--color-background)}.relationships-content{display:flex;flex-direction:column;gap:var(--space-10)}.relationship-group__title{display:flex;align-items:center;gap:var(--space-3);font-size:18px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-5);padding-bottom:var(--space-3);border-bottom:var(--border-width) solid var(--color-border)}.relationship-group__title svg{width:22px;height:22px;color:var(--color-primary)}.relationship-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}@media(min-width:640px){.relationship-cards{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.relationship-cards{grid-template-columns:repeat(4,1fr)}}.relationship-cards--single{grid-template-columns:1fr;max-width:400px}.relationship-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--color-background-elevated);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-xl);transition:all var(--transition-base)}.relationship-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.relationship-card__avatar{position:relative;width:60px;height:60px;border-radius:50%;overflow:hidden;flex-shrink:0;border:3px solid var(--color-border)}.relationship-card:hover .relationship-card__avatar{border-color:var(--color-primary)}.relationship-card__avatar img{width:100%;height:100%;object-fit:cover}.relationship-card__badge{position:absolute;bottom:-2px;right:-2px;width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:#e91e63;border:2px solid var(--color-background-elevated);border-radius:50%;font-size:10px;color:#fff}.relationship-card__info{min-width:0}.relationship-card__name{font-size:15px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.relationship-card__relationship{font-size:12px;font-weight:var(--font-weight-semibold);color:var(--color-primary);margin:0 0 var(--space-1);text-transform:uppercase;letter-spacing:.05em}.relationship-card__subtitle{font-size:13px;color:var(--color-text-tertiary);margin:0}.relationship-card__status{font-size:12px;color:var(--color-text-tertiary);margin:var(--space-1) 0 0}.relationship-card--spouse{background:linear-gradient(135deg,var(--color-background-primary) 0%,var(--color-background-warm) 100%);border-color:#2f5d4633}.relationship-card--spouse .relationship-card__avatar{width:80px;height:80px;border-color:var(--color-primary)}.relationship-card--spouse .relationship-card__name{font-size:18px}.person-cta{background:linear-gradient(180deg,var(--color-background-primary) 0%,var(--color-background-cream) 100%)}.person-cta__content{text-align:center;max-width:600px;margin:0 auto}.person-cta__icon{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;background:var(--color-primary-light);border-radius:50%;margin-bottom:var(--space-6)}.person-cta__icon svg{width:40px;height:40px;color:var(--color-primary)}.person-cta__text{margin:var(--space-4) 0 var(--space-8)}.person-cta__actions{display:flex;justify-content:center;gap:var(--space-4);flex-wrap:wrap}.person-cta__actions svg{width:20px;height:20px}.navbar-logo-img{height:36px;width:auto}@media(max-width:640px){.profile-card__name{font-size:26px}.profile-card__actions{width:100%;justify-content:center}.profile-card__meta{justify-content:center}.profile-card__bio{text-align:center}.profile-card__quote blockquote{font-size:15px}.section-header{flex-direction:column;text-align:center;align-items:center}.section-header__action{margin-left:0}.timeline-event__card{max-width:100%}.memory-card--featured{grid-column:span 2;grid-row:span 1}.memory-card--featured .memory-card__image{aspect-ratio:16 / 9;min-height:auto}.relationship-cards{grid-template-columns:1fr}.person-cta__actions{flex-direction:column;align-items:center}}.memories-page{min-height:100vh;background-color:var(--color-bg-primary)}.memories-header{padding-top:60px;padding-bottom:40px}.memories-header__content{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap}.header-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.search-bar{position:relative;width:350px;height:52px}.search-bar svg{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--color-text-tertiary);pointer-events:none}.search-bar input{width:100%;height:100%;padding:0 16px 0 52px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:12px;font-size:.95rem;color:var(--color-text-primary);transition:all .2s ease}.search-bar input:focus{outline:none;border-color:var(--color-accent-primary);background:var(--color-bg-primary);box-shadow:0 0 0 4px rgba(var(--color-accent-primary-rgb),.1)}.memories-controls{padding:24px 0;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);position:sticky;top:var(--navbar-height);z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffc}.controls-wrapper{display:flex;justify-content:space-between;align-items:center;gap:24px}.category-filters{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}.category-filters::-webkit-scrollbar{display:none}.filter-pill{padding:10px 20px;border-radius:100px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);color:var(--color-text-secondary);font-size:.9rem;font-weight:500;white-space:nowrap;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.filter-pill:hover{background:var(--color-bg-primary);border-color:var(--color-text-tertiary)}.filter-pill.active{background:var(--color-text-primary);color:#fff;border-color:var(--color-text-primary)}.view-toggle{display:flex;background:var(--color-bg-tertiary);border:1px solid var(--color-border);padding:4px;border-radius:10px}.toggle-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--color-text-tertiary);border-radius:8px;cursor:pointer;transition:all .2s ease}.toggle-btn svg{width:20px;height:20px}.toggle-btn:hover{color:var(--color-text-secondary)}.toggle-btn.active{background:var(--color-bg-primary);color:var(--color-accent-primary);box-shadow:var(--shadow-sm)}.memories-content{padding:60px 0}.memories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:32px}.memories-timeline{display:flex;flex-direction:column;gap:80px}.timeline-group{display:flex;gap:60px}.timeline-year{width:80px;display:flex;flex-direction:column;align-items:center;gap:16px;flex-shrink:0}.timeline-year span{font-size:2rem;font-weight:800;color:var(--color-text-primary);font-family:var(--font-heading);line-height:1}.timeline-year .line{flex:1;width:2px;background:linear-gradient(to bottom,var(--color-border),transparent);border-radius:1px}.timeline-memories{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:32px;flex:1}.memory-card-link{text-decoration:none;color:inherit;display:block;cursor:pointer}.memory-card{background:var(--color-bg-primary);border-radius:20px;overflow:hidden;border:1px solid var(--color-border);transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}.memory-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:rgba(var(--color-accent-primary-rgb),.2)}.memory-card__media{position:relative;aspect-ratio:4 / 3;overflow:hidden;background:var(--color-bg-tertiary)}.memory-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.4,0,.2,1)}.memory-card:hover .memory-card__media img{transform:scale(1.05)}.memory-card__video-thumb{position:relative;width:100%;height:100%}.memory-card__video-thumb video{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.4,0,.2,1)}.memory-card:hover .memory-card__video-thumb video{transform:scale(1.05)}.memory-card__play-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:48px;height:48px;background:#ffffffd9;border-radius:50%;display:flex;align-items:center;justify-content:center;pointer-events:none}.memory-card__play-icon svg{width:22px;height:22px;color:var(--color-text-primary)}.memory-card__type-badge{position:absolute;top:16px;left:16px;width:36px;height:36px;background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--color-text-primary);box-shadow:0 4px 12px #0000001a}.memory-card__type-badge svg{width:20px;height:20px}.memory-card__favorite-badge{position:absolute;top:16px;right:16px;width:36px;height:36px;background:rgba(var(--color-accent-primary-rgb),.9);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}.memory-card__favorite-badge svg{width:18px;height:18px;fill:currentColor}.memory-card__content{padding:24px;display:flex;flex-direction:column;flex:1}.memory-card__meta{display:flex;justify-content:space-between;margin-bottom:12px}.memory-card__category{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-accent-primary)}.memory-card__date{font-size:.85rem;color:var(--color-text-tertiary)}.memory-card__title{font-size:1.25rem;font-weight:700;margin-bottom:12px;color:var(--color-text-primary);line-height:1.4}.memory-card__description{font-size:.95rem;color:var(--color-text-secondary);line-height:1.6;margin-bottom:24px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.memory-card__footer{margin-top:auto;display:flex;justify-content:space-between;align-items:center;padding-top:20px;border-top:1px solid var(--color-border)}.memory-card__people{display:flex;align-items:center;margin-left:8px}.person-tag{width:34px;height:34px;margin-left:-10px;background:#f0f2f5;border:2px solid #ffffff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:var(--color-text-secondary);transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0000000d}.person-tag:hover{z-index:10;transform:translateY(-2px) scale(1.1);background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.person-tag--photo{width:34px;height:34px;margin-left:-10px;border:2px solid #ffffff;border-radius:50%;object-fit:cover;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0000001a;cursor:pointer}.person-tag--photo:first-child{margin-left:0}.person-tag--photo:hover{z-index:10;transform:translateY(-2px) scale(1.15);box-shadow:0 4px 12px #0003}.people-more{font-size:.8rem;font-weight:600;color:var(--color-text-tertiary);margin-left:8px}.memory-card__stats{display:flex;align-items:center;gap:6px;color:var(--color-text-tertiary);font-size:.9rem;background:none;border:none;padding:8px 12px;border-radius:8px;cursor:pointer;transition:all .2s ease;font-family:inherit}.memory-card__stats:hover{background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.memory-card__stats svg{width:16px;height:16px;color:#ff4b4b;transition:all .2s ease}.memory-card__stats.liked svg{fill:#ff4b4b;transform:scale(1.1)}.memory-card__stats.liked{color:#ff4b4b}.memory-card--timeline{border-radius:16px}.memory-card--timeline .memory-card__media{aspect-ratio:16 / 9}.memories-empty{text-align:center;padding:100px 0;background:var(--color-bg-tertiary);border-radius:32px;border:2px dashed var(--color-border)}@media(max-width:1024px){.timeline-group{gap:30px}}@media(max-width:768px){.memories-header__content{flex-direction:column;align-items:flex-start}.search-bar{width:100%}.timeline-group{flex-direction:column;gap:20px}.timeline-year{width:auto;flex-direction:row;align-items:center}.timeline-year .line{height:2px;width:auto;flex:1;background:linear-gradient(to right,var(--color-border),transparent)}.controls-wrapper{flex-direction:column;align-items:stretch}.view-toggle{justify-content:center}}.memory-detail-page{min-height:100vh;background-color:var(--color-bg-primary)}.memory-detail-main{padding-top:40px;padding-bottom:80px}.memory-detail__header{margin-bottom:30px}.back-btn{display:flex;align-items:center;gap:8px;background:none;border:none;color:var(--color-text-tertiary);font-size:.95rem;font-weight:500;cursor:pointer;padding:8px 0;transition:color .2s ease}.back-btn:hover{color:var(--color-accent-primary)}.back-btn svg{width:20px;height:20px}.memory-detail__grid{display:grid;grid-template-columns:1.2fr .8fr;gap:60px;align-items:start}.media-card{border-radius:24px;overflow:hidden;background:var(--color-bg-tertiary);box-shadow:var(--shadow-xl)}.media-container{position:relative;width:100%}.media-container img{width:100%;height:auto;display:block;max-height:700px;object-fit:contain}.media-container .media-video{width:100%;max-height:700px;display:block;background:#000}.video-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2}.play-button{width:80px;height:80px;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--color-accent-primary);cursor:pointer;box-shadow:0 10px 30px #0003;transition:transform .3s cubic-bezier(.4,0,.2,1)}.play-button:hover{transform:scale(1.1)}.media-actions{padding:24px;display:flex;gap:20px;border-top:1px solid var(--color-border);background:var(--color-bg-primary)}.action-btn{display:flex;align-items:center;gap:10px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);padding:12px 24px;border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;color:var(--color-text-secondary)}.action-btn:hover{background:var(--color-bg-primary);border-color:var(--color-text-tertiary)}.like-btn.active{background:#ef44441a;color:#ef4444;border-color:#ef4444}.like-btn.active svg{fill:#ef4444;stroke:#ef4444}.action-btn svg{width:20px;height:20px}.memory-detail__badges{display:flex;gap:12px;margin-bottom:20px}.category-badge{background:rgba(var(--color-accent-primary-rgb),.1);color:var(--color-accent-primary);padding:6px 14px;border-radius:100px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.favorite-badge{background:#fffbeb;color:#b45309;padding:6px 14px;border-radius:100px;font-size:.75rem;font-weight:700}.memory-detail__title{margin-bottom:24px;line-height:1.2}.memory-detail__meta-list{display:flex;flex-direction:column;gap:16px;margin-bottom:40px}.meta-item{display:flex;align-items:center;gap:12px;color:var(--color-text-tertiary)}.meta-item svg{width:20px;height:20px;color:var(--color-text-tertiary)}.memory-detail__description{margin-bottom:50px;font-size:1.1rem;line-height:1.8;color:var(--color-text-secondary)}.memory-detail__people-section{margin-top:50px}.memory-detail__people-section h3{font-size:1.25rem;margin-bottom:24px}.people-grid{display:grid;grid-template-columns:1fr;gap:16px;width:100%}@media(min-width:640px){.people-grid{grid-template-columns:repeat(2,1fr)}}.memory-person-card{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:12px;text-decoration:none;transition:all .2s ease;width:100%;box-sizing:border-box}.memory-person-card:hover{background:var(--color-bg-primary);border-color:var(--color-accent-primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.memory-person-card--static{cursor:default}.memory-person-card--static:hover{transform:none;box-shadow:none;border-color:var(--color-border)}.person-avatar{width:36px;height:36px;min-width:36px;min-height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;color:var(--color-text-primary);flex-shrink:0}.person-avatar-img{width:36px;height:36px;min-width:36px;min-height:36px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--color-border)}.person-name{font-size:.9rem;font-weight:600;color:var(--color-text-primary);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.memory-detail-loading{display:flex;align-items:center;justify-content:center;min-height:100vh}.spinner{width:48px;height:48px;border:3px solid var(--color-border);border-top-color:var(--color-accent-primary);border-radius:50%;animation:spin 1s linear infinite}.error-section{text-align:center;padding:100px 0}.error-section h2{margin-bottom:20px}.error-section p{margin-bottom:40px;color:var(--color-text-tertiary)}@media(max-width:1024px){.memory-detail__grid{grid-template-columns:1fr;gap:40px}}@media(max-width:768px){.memory-detail-main{padding-top:20px}.action-btn{flex:1;justify-content:center}}section.stories-header{padding:60px 0}.stories-page{min-height:100vh;background-color:var(--color-background);display:flex;flex-direction:column}.stories-header__content{display:flex;justify-content:space-between;align-items:center;gap:var(--space-8)}.header-text{max-width:600px}.header-actions{display:flex;gap:var(--space-4)}.featured-story{margin-bottom:var(--space-16)}.stories-filters{background-color:var(--color-background);padding:var(--space-4) 0;border-bottom:1px solid var(--color-border-subtle)}.filters-bar{display:flex;justify-content:space-between;align-items:center;gap:var(--space-6);flex-wrap:wrap}.filter-tabs{display:flex;gap:var(--space-2);flex-wrap:wrap}.filter-tab{padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-background-elevated);color:var(--color-text-secondary);font-size:14px;font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base);white-space:nowrap}.filter-tab:hover{border-color:var(--color-primary);color:var(--color-text-primary)}.filter-tab.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-inverse)}.search-box{position:relative;display:flex;align-items:center;min-width:240px}.search-box svg{position:absolute;left:var(--space-3);width:18px;height:18px;color:var(--color-text-tertiary);pointer-events:none}.search-box input{width:100%;padding:var(--space-2) var(--space-4);padding-left:var(--space-10);border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-background-elevated);color:var(--color-text-primary);font-size:14px;transition:all var(--transition-base)}.search-box input::placeholder{color:var(--color-text-tertiary)}.search-box input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.stories-empty{text-align:center;padding:var(--space-16) var(--space-4);background:var(--color-background-elevated);border-radius:var(--radius-lg);border:1px dashed var(--color-border);margin-bottom:var(--space-8)}.featured-card{position:relative;display:flex;flex-direction:column;background:var(--color-background-elevated);border-radius:var(--radius-xl);border:1px solid var(--color-border);overflow:hidden;transition:transform var(--transition-base),box-shadow var(--transition-base);cursor:pointer}.featured-story{position:relative;margin-bottom:var(--space-8)}.featured-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.featured-card__image{position:relative;width:100%;height:320px}.featured-card__image img{width:100%;height:100%;object-fit:cover}.featured-card__content{display:flex;flex-direction:column;padding:var(--space-8);flex:1}.featured-card__meta{display:flex;gap:var(--space-4);margin-bottom:var(--space-4);font-size:var(--font-size-small);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-weight:var(--font-weight-semibold)}.featured-card__title{font-size:32px;margin-bottom:var(--space-4);line-height:1.2}.featured-card__excerpt{font-size:18px;color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--space-6)}.stories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-8);margin-bottom:var(--space-16)}@media(max-width:1100px){.stories-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}.featured-card-link,.story-card-link{text-decoration:none;color:inherit;display:flex;flex-direction:column;height:100%;width:100%}.story-card.story-card--grid{background:var(--color-background-elevated);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden;transition:all var(--transition-base);cursor:pointer;display:flex;flex-direction:column;height:100%;padding:0}.story-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--color-primary)}.story-card__image{height:200px;position:relative;width:100%;flex-shrink:0}.story-card__image img{width:100%;height:100%;object-fit:cover;display:block}.story-card__content{padding:var(--space-6) var(--space-8);flex:1;display:flex;align-items:flex-start;flex-direction:column;text-align:left;box-sizing:border-box;width:100%}.story-card__meta{display:flex;align-items:center;justify-content:flex-start;gap:var(--space-3);margin-bottom:var(--space-3);font-size:11px;text-transform:uppercase;letter-spacing:.05em;font-weight:var(--font-weight-bold);color:var(--color-primary)}.story-card__date{color:var(--color-text-tertiary);font-weight:var(--font-weight-medium)}.story-card__title{font-size:20px;margin-bottom:var(--space-3);line-height:1.4;color:var(--color-text-primary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;max-width:100%;word-wrap:break-word;overflow-wrap:break-word;box-sizing:border-box}.story-card__excerpt{font-size:15px;color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--space-4);display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;max-width:100%;word-wrap:break-word;overflow-wrap:break-word;box-sizing:border-box}.story-card__footer{width:100%;margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:var(--space-4);border-top:1px solid var(--color-border-subtle)}.story-author{display:flex;align-items:center;gap:var(--space-2)}.author-avatar{width:28px;height:28px;border-radius:50%;background:var(--color-background);border:1px solid var(--color-border);color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;transition:all var(--transition-base)}.author-avatar:hover{border-color:var(--color-primary);background:var(--color-primary);color:var(--color-text-inverse);transform:translateY(-1px)}.author-name{font-size:12px;font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.story-card.story-card--grid .story-stats{display:flex;align-items:center;justify-content:center;gap:4px;color:var(--color-text-tertiary);font-size:13px}.story-card.story-card--grid .story-stats svg{width:14px;height:14px;flex-shrink:0;margin:0}.create-story-btn{display:flex;align-items:center;gap:var(--space-2);background:var(--color-primary);color:var(--color-text-inverse);padding:var(--space-3) var(--space-5);border-radius:var(--radius-full);font-weight:var(--font-weight-semibold);transition:all var(--transition-base)}.create-story-btn:hover{background:var(--color-primary-dark);transform:translateY(-1px)}@media(max-width:1024px){.featured-card__title{font-size:28px}}@media(max-width:768px){.stories-header__content{flex-direction:column;align-items:flex-start}.filters-bar{flex-direction:column;align-items:stretch;gap:var(--space-4)}.filter-tabs{justify-content:flex-start;overflow-x:auto;padding-bottom:var(--space-2);-webkit-overflow-scrolling:touch;flex-wrap:nowrap}.search-box{min-width:unset;width:100%}}@media(max-width:640px){.featured-card__image{height:240px}.featured-card__content{padding:var(--space-6)}.featured-card__title{font-size:24px}}.new-story-split-btn{position:relative;display:flex;align-items:stretch}.new-story-split-btn .split-btn-main{border-top-right-radius:0!important;border-bottom-right-radius:0!important;border-right:1px solid rgba(255,255,255,.2)!important}.split-btn-trigger{background:var(--color-primary);color:var(--color-text-inverse);border:2px solid transparent;border-left:1px solid rgba(255,255,255,.3);height:var(--button-height);padding:0 var(--space-3);border-top-right-radius:var(--button-radius);border-bottom-right-radius:var(--button-radius);cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;justify-content:center;margin-left:-2px}.split-btn-trigger:hover{background:var(--color-primary-hover)}.split-btn-trigger svg{width:16px;height:16px;color:var(--color-text-inverse)}.new-story-dropdown{position:absolute;top:calc(100% + 4px);right:0;background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:200px;z-index:100;overflow:hidden}.new-story-dropdown .dropdown-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);width:100%;border:none;background:transparent;color:var(--color-text-primary);font-size:14px;font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base);text-align:left}.new-story-dropdown .dropdown-item:hover{background:var(--color-background);color:var(--color-primary)}.new-story-dropdown .dropdown-item svg{width:18px;height:18px}.filters-right{display:flex;align-items:center;gap:var(--space-3)}.sort-select-wrapper{min-width:160px}.sort-select-wrapper .famili-select__control{border-radius:var(--radius-full);min-height:40px;padding:0 8px}.story-card{position:relative}.story-card-kebab{position:absolute;top:var(--space-3);right:var(--space-3);z-index:10}.kebab-trigger{width:26px;height:26px;border-radius:50%;background:#fffffff2;border:1px solid var(--color-border);display:grid;place-items:center;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm);padding:0}.kebab-trigger:hover{background:var(--color-background-elevated);border-color:var(--color-primary)}.kebab-trigger svg{width:14px!important;height:14px!important;color:var(--color-text-secondary);display:block}.story-card-kebab .kebab-dropdown{position:absolute;top:calc(100% + var(--space-2));right:0;background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:160px;z-index:100;overflow:hidden}.story-card-kebab .kebab-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);width:100%;border:none;background:transparent;color:var(--color-text-primary);font-size:14px;font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base);text-align:left}.story-card-kebab .kebab-item:hover{background:var(--color-background)}.story-card-kebab .kebab-item--danger{color:var(--color-danger)}.story-card-kebab .kebab-item--danger:hover{background:rgba(var(--color-danger-rgb),.1)}.story-card-kebab .kebab-item svg{width:14px;height:14px;margin:0}.story-card.story-card--grid .kebab-item.kebab-item--danger svg{color:var(--color-danger)}.story-type-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);background:var(--color-primary-light);color:var(--color-primary);font-size:10px;font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.05em}.visibility-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:10px;font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.05em}.visibility-badge--private{background:#9ca3af1a;color:#6b7280}.visibility-badge--family{background:#3b82f61a;color:#3b82f6}.visibility-badge--public{background:#10b9811a;color:#10b981}.stories-empty--no-stories{padding:var(--space-20) var(--space-4)}.empty-icon{width:64px;height:64px;margin:0 auto var(--space-6);border-radius:50%;background:var(--color-primary-light);display:flex;align-items:center;justify-content:center}.empty-icon svg{width:32px;height:32px;color:var(--color-primary)}.stories-empty h2{margin-bottom:var(--space-3)}.empty-actions{display:flex;gap:var(--space-3);justify-content:center;margin-top:var(--space-6);flex-wrap:wrap}.modal-content h3{margin-bottom:var(--space-4)}@media(max-width:768px){.filters-right{width:100%;flex-direction:column}.search-box,.sort-select-wrapper,.new-story-split-btn{width:100%}.new-story-split-btn .split-btn-main{flex:1}}.legal-summary{padding:24px;background:var(--color-background-primary, var(--color-background-elevated));border-radius:12px;margin-bottom:32px;border-left:4px solid var(--color-primary)}.legal-summary h3{margin-bottom:12px;font-size:18px}.legal-summary ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.legal-summary li{display:flex;gap:8px;font-size:14px;color:var(--color-text-secondary);line-height:1.5}.legal-summary li:before{content:"✓";color:var(--color-primary);font-weight:700;flex-shrink:0}.legal-cookie-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:var(--color-primary);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;margin-top:16px;transition:all .2s}.legal-cookie-btn:hover{background:var(--color-primary-hover);transform:translateY(-1px)}.legal-page{padding-top:var(--navbar-height);background-color:var(--color-background);min-height:100vh}.legal-header{background-color:var(--color-background-subtle);padding:var(--space-12) 0;margin-bottom:var(--space-10);text-align:center}.legal-header__date{display:block;margin-top:var(--space-4);font-size:var(--font-size-small);color:var(--color-text-tertiary);font-weight:var(--font-weight-medium)}.legal-content{max-width:720px;margin:0 auto;padding-bottom:var(--space-16)}.legal-section{margin-bottom:var(--space-12);padding-left:var(--space-6);border-left:2px solid transparent;transition:border-color var(--transition-base)}.legal-section:hover{border-left-color:var(--color-primary-light)}.legal-section__title{font-size:24px;margin-bottom:var(--space-4);color:var(--color-text-primary);position:relative;display:inline-block}.legal-section__content{font-size:18px;line-height:1.7;color:var(--color-text-secondary)}.legal-section__content p{margin-bottom:var(--space-4)}.legal-section__content ul{margin-bottom:var(--space-4);padding-left:var(--space-4)}.legal-section__content li{margin-bottom:var(--space-2);position:relative}.legal-section__content strong{color:var(--color-text-primary);font-weight:var(--font-weight-semibold)}.legal-callout{background-color:var(--color-background-elevated);border-radius:var(--radius-lg);padding:var(--space-6);margin:var(--space-8) 0;border:1px solid var(--color-border)}.legal-callout__title{font-size:16px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-2);display:flex;align-items:center;gap:var(--space-2)}.legal-callout__text{font-size:16px;color:var(--color-text-secondary);margin:0}@media(min-width:1024px){.legal-grid{display:grid;grid-template-columns:240px 1fr;gap:var(--space-12);align-items:start}.legal-nav{position:sticky;top:calc(var(--navbar-height) + var(--space-8));padding-right:var(--space-4)}.legal-nav__link{display:block;padding:var(--space-2) 0;color:var(--color-text-tertiary);text-decoration:none;font-size:14px;transition:color var(--transition-base)}.legal-nav__link:hover,.legal-nav__link--active{color:var(--color-primary);font-weight:var(--font-weight-semibold)}}.legal-ownership{padding:16px 20px;background:var(--color-background-subtle);border-radius:8px;margin-bottom:24px;font-size:14px}.member-profile{min-height:100vh;background:var(--color-background)}.member-profile__main{padding-bottom:var(--space-12)}.member-profile__breadcrumb{padding:var(--space-4) 0;border-bottom:1px solid var(--color-border-subtle)}.breadcrumb{display:flex;align-items:center;gap:var(--space-2);font-size:14px}.breadcrumb__link{color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition-fast)}.breadcrumb__link:hover{color:var(--color-primary)}.breadcrumb__current{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.breadcrumb svg{width:16px;height:16px;color:var(--color-text-tertiary)}.member-profile__header{padding:var(--space-8) 0}.profile-header{display:flex;gap:var(--space-6);align-items:flex-start}.profile-header__avatar{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary-light),var(--color-primary));color:var(--color-primary-dark);display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:var(--font-weight-bold);flex-shrink:0;margin-bottom:1rem;overflow:hidden}.profile-header__avatar-image{width:100%;height:100%;object-fit:cover}.profile-header__info{flex:1}.profile-header__title-row{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap;margin-bottom:var(--space-3)}.profile-header__name{margin:0}.profile-header__relationship{padding:var(--space-1) var(--space-3);background:var(--color-primary-light);color:var(--color-primary-dark);border-radius:var(--radius-full);font-size:14px;font-weight:var(--font-weight-medium)}.profile-header__years{color:var(--color-text-secondary);font-size:18px}.profile-header__meta{display:flex;gap:var(--space-4);flex-wrap:wrap;margin-bottom:var(--space-4)}.profile-meta-item{display:flex;align-items:center;gap:var(--space-2)}.profile-meta-item svg{width:16px;height:16px;color:var(--color-text-tertiary)}.privacy-chip{padding:2px var(--space-2);background:var(--color-background-subtle);border-radius:var(--radius-sm);text-transform:capitalize}.profile-header__actions{display:flex;gap:var(--space-3);align-items:center}.profile-header__more{position:relative}.more-menu{position:absolute;top:100%;right:0;margin-top:var(--space-2);background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:180px;z-index:10}.more-menu__item{width:100%;padding:var(--space-3) var(--space-4);background:none;border:none;text-align:left;cursor:pointer;font-size:14px;color:var(--color-text-primary);transition:background var(--transition-fast)}.more-menu__item:hover{background:var(--color-background-subtle)}.more-menu__item--danger{color:var(--color-danger)}.more-menu__item--danger:hover{background:var(--color-danger-muted)}.member-profile__stats{padding:var(--space-6) 0}.stats-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4)}.stat-card{text-align:center;padding:var(--space-5)}.stat-card__value{font-size:36px;font-weight:var(--font-weight-bold);color:var(--color-primary);margin-bottom:var(--space-2)}.member-profile__tabs{border-bottom:1px solid var(--color-border);padding:0}.tabs{display:flex;gap:var(--space-2)}.tab{padding:var(--space-4) var(--space-5);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:16px;font-weight:var(--font-weight-medium);color:var(--color-text-secondary);transition:all var(--transition-fast)}.tab:hover{color:var(--color-text-primary)}.tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.member-profile__content{padding:var(--space-8) 0}.overview-grid{display:grid;grid-template-columns:1fr 320px;gap:var(--space-6)}.overview-main{display:flex;flex-direction:column;gap:var(--space-6)}.overview-sidebar{display:flex;flex-direction:column;gap:var(--space-4)}.about-card{padding:var(--space-6)}.about-bio{margin:var(--space-4) 0;line-height:1.6}.about-tags{display:flex;flex-wrap:wrap;gap:var(--space-2);margin:var(--space-4) 0}.tag-chip{padding:var(--space-1) var(--space-3);background:var(--color-background-subtle);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:13px;color:var(--color-text-secondary)}.about-details{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border-subtle)}.detail-row{display:flex;justify-content:space-between;padding:var(--space-2) 0}.recent-memories-card{padding:var(--space-6)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.memory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-4)}.memory-tile{text-decoration:none;color:inherit;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border);transition:all var(--transition-base)}.memory-tile:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.memory-tile__image{aspect-ratio:1;background:var(--color-background-subtle);overflow:hidden}.memory-tile__image img,.memory-tile__image video{width:100%;height:100%;object-fit:cover}.memory-tile__placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary)}.memory-tile__placeholder svg{width:48px;height:48px}.memory-tile__content{padding:var(--space-3)}.memory-tile__title{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:var(--space-1)}.key-details-card{padding:var(--space-5)}.key-details{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-4)}.detail-item{display:flex;flex-direction:column;gap:var(--space-1)}.recent-stories-card{padding:var(--space-5)}.story-list{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-4)}.story-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);text-decoration:none;color:inherit;transition:background var(--transition-fast)}.story-item:hover{background:var(--color-background-subtle)}.story-item svg{width:20px;height:20px;color:var(--color-primary);flex-shrink:0}.story-item__content{flex:1}.memories-tab{display:flex;flex-direction:column;gap:var(--space-6)}.memory-grid-full{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-5)}.memory-card-link{text-decoration:none;color:inherit}.memory-card__image{aspect-ratio:16 / 9;background:var(--color-background-subtle);overflow:hidden}.memory-card__image img,.memory-card__image video{width:100%;height:100%;object-fit:cover}.memory-card__placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary)}.memory-card__placeholder svg{width:64px;height:64px}.memory-card__content{padding:var(--space-4)}.memory-card__description{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-top:var(--space-2)}.stories-tab{display:flex;flex-direction:column;gap:var(--space-6)}.story-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-5)}.story-card-link{text-decoration:none;color:inherit}.story-card{padding:var(--space-6);text-align:center}.story-card svg{width:48px;height:48px;color:var(--color-primary);margin:0}.family-tab{padding:var(--space-4) 0}.family-links-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-5)}.family-links-card{padding:var(--space-5)}.family-links-card__header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border-subtle)}.family-links-card__header svg{width:24px;height:24px;color:var(--color-primary)}.family-links-card__header h4{margin:0}.family-links-list{display:flex;flex-direction:column;gap:var(--space-3)}.family-link-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);text-decoration:none;color:inherit;transition:background var(--transition-fast)}.family-link-item:hover{background:var(--color-background-subtle)}.family-link-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary-light),var(--color-primary));color:var(--color-primary-dark);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:var(--font-weight-bold);flex-shrink:0}.family-link-info{flex:1;min-width:0}.family-link-info p{margin:0}.invite-success-banner{padding:var(--space-2) var(--space-4);background:var(--color-success-muted, #e6f4ea);border:1px solid var(--color-success, #34a853);border-radius:var(--radius-md);margin-bottom:var(--space-3)}.modal__error{margin-top:var(--space-4);padding:var(--space-3);background:var(--color-danger-muted);border-radius:var(--radius-md)}.empty-state{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-8);text-align:center}.empty-state>svg{width:48px;height:48px;color:var(--color-text-tertiary)}.empty-state-large{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-12);text-align:center}.empty-state-large>svg{width:64px;height:64px;color:var(--color-text-tertiary)}.modal-overlay{position:fixed;inset:0;background:#00000080;z-index:999}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--color-background-elevated);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:500px;width:90%;z-index:1000}.member-profile-loading{min-height:100vh;display:flex;align-items:center;justify-content:center}@media(max-width:1024px){.overview-grid{grid-template-columns:1fr}.overview-sidebar{order:-1}}@media(max-width:768px){.profile-header{flex-direction:column;align-items:center;text-align:center}.profile-header__avatar{width:100px;height:100px;font-size:40px}.profile-header__title-row,.profile-header__meta{justify-content:center}.profile-header__actions{flex-wrap:wrap;justify-content:center}.stats-strip{grid-template-columns:repeat(2,1fr)}.tabs{overflow-x:auto}.memory-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.memory-grid-full,.story-grid{grid-template-columns:1fr}}.edit-member{min-height:100vh;background:var(--color-background)}.edit-member__main{padding-bottom:var(--space-12)}.edit-member__breadcrumb{padding:var(--space-4) 0;border-bottom:1px solid var(--color-border-subtle)}.edit-member__header{padding:var(--space-8) 0 var(--space-6) 0}.edit-header{width:100%;margin:0}.edit-member__form{padding:var(--space-6) 0}.form-container{width:100%;margin:0}.form-section{background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);margin-bottom:var(--space-6)}.form-section h3{margin-bottom:var(--space-5);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border-subtle)}.form-section--danger{border-color:var(--color-danger);background:var(--color-danger-muted)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);margin-bottom:var(--space-4)}.form-label{font-weight:var(--font-weight-medium);color:var(--color-text-primary);font-size:14px}.form-textarea{width:100%;padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background-elevated);color:var(--color-text-primary);font-family:inherit;font-size:14px;resize:vertical;transition:border-color var(--transition-fast)}.form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.form-hint{margin-top:var(--space-1)}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);background:var(--color-background-subtle);border-radius:var(--radius-lg);cursor:pointer;border:none;width:100%;text-align:left;margin-bottom:var(--space-4)}.toggle-row__content{display:flex;flex-direction:column;gap:var(--space-1)}.toggle-switch{position:relative;width:48px;height:24px;background:var(--color-border-strong);border-radius:12px;border:none;cursor:pointer;transition:background var(--transition-base)}.toggle-switch__thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform var(--transition-base)}.toggle-switch--on{background:var(--color-primary)}.toggle-switch--on .toggle-switch__thumb{transform:translate(24px)}.tags-input{display:flex;flex-wrap:wrap;gap:var(--space-2);padding:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background-elevated);min-height:44px}.tags-input:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.tag{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);background:var(--color-background-subtle);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:13px;color:var(--color-text-primary)}.tag__remove{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;color:var(--color-text-tertiary);transition:color var(--transition-fast)}.tag__remove:hover{color:var(--color-danger)}.tag__remove svg{width:14px;height:14px}.tags-input__field{flex:1;min-width:120px;border:none;background:transparent;font-size:14px;padding:var(--space-1);color:var(--color-text-primary)}.tags-input__field:focus{outline:none}.tags-input__field::placeholder{color:var(--color-text-tertiary)}.form-actions{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-6) 0}.danger-zone{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);background:var(--color-background-elevated);border:1px solid var(--color-danger);border-radius:var(--radius-lg)}.danger-zone__content{display:flex;flex-direction:column;gap:var(--space-1)}.modal-overlay{position:fixed;inset:0;background:#00000080;z-index:999;animation:fadeIn .2s ease-out}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--color-background-elevated);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:500px;width:90%;z-index:1000;animation:slideUp .3s ease-out}.modal__header{padding:var(--space-6);border-bottom:1px solid var(--color-border)}.modal__header h3{margin:0;font-size:var(--font-size-modal-title)}.modal__content{padding:var(--space-6)}.modal__footer{padding:var(--space-6);border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:var(--space-3)}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);padding:var(--space-4) var(--space-6);background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:1000;animation:slideUp .3s ease-out}.toast--success{background:#10b981;color:#fff;border-color:#10b981}.toast--error{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.edit-member-loading{min-height:100vh;display:flex;align-items:center;justify-content:center}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.editmember-photo-section{margin-bottom:var(--space-5)}.editmember-photo-area{margin-top:var(--space-2)}.editmember-photo-preview{position:relative;display:inline-block}.editmember-photo-preview img{width:120px;height:120px;object-fit:cover;border-radius:50%;border:2px solid var(--color-border)}.editmember-photo-recrop{position:absolute;top:-8px;left:-8px;width:24px;height:24px;border-radius:50%;background:var(--color-primary);border:2px solid var(--color-background-elevated);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:transform var(--transition-fast)}.editmember-photo-recrop:hover{transform:scale(1.1)}.editmember-photo-recrop svg{width:12px;height:12px}.editmember-photo-remove{position:absolute;top:-8px;right:-8px;width:24px;height:24px;border-radius:50%;background:var(--color-danger);border:2px solid var(--color-background-elevated);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:transform var(--transition-fast)}.editmember-photo-remove:hover{transform:scale(1.1)}.editmember-photo-remove svg{width:14px;height:14px}.editmember-photo-upload{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-2)}.editmember-photo-upload-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--color-background-subtle);border:1px dashed var(--color-border-strong);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:14px;cursor:pointer;transition:all var(--transition-fast)}.editmember-photo-upload-btn:hover{background:var(--color-background-elevated);border-color:var(--color-primary);color:var(--color-primary)}.editmember-photo-upload-btn svg{width:18px;height:18px}@media(max-width:768px){.form-container{max-width:100%}.form-row{grid-template-columns:1fr}.form-section{padding:var(--space-4)}.danger-zone{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.danger-zone button{width:100%}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}}@keyframes authCardIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}.auth-page{display:flex;flex-direction:column;min-height:100vh;background-color:#f4f6f5}.auth-page__main{flex:1;display:flex;flex-direction:column}.auth-page__center{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 24px;background:radial-gradient(circle at center,rgba(69,179,91,.08),transparent 60%)}.auth-card{width:100%;max-width:480px;background:#fff;border-radius:20px;box-shadow:0 10px 40px #0000000f;padding:56px;display:flex;flex-direction:column}@media(prefers-reduced-motion:no-preference){.auth-card{animation:authCardIn .5s cubic-bezier(.22,1,.36,1) both}}@media(max-width:639px){.auth-card{padding:36px 24px;border-radius:16px;max-width:100%}}.auth-card__logo{display:flex;justify-content:center;margin-bottom:28px}.auth-card__logo img{height:40px;width:auto;object-fit:contain}.auth-card__header{margin-bottom:28px;text-align:center}.auth-card__title{font-size:28px;font-weight:700;line-height:1.2;letter-spacing:-.02em;color:#111827;margin:0 0 6px}@media(max-width:639px){.auth-card__title{font-size:22px}}.auth-card__subtitle{font-size:15px;color:#6b7280;line-height:1.5;margin:0}.auth-card__body{display:flex;flex-direction:column}.auth-error-banner{padding:12px 16px;background-color:#fef2f2;border:1px solid #FECACA;border-radius:10px;margin-bottom:20px}.auth-error-banner .text{color:#dc2626!important;font-size:13px!important}.auth-form{width:100%;display:flex;flex-direction:column;gap:20px}.auth-form .input__label{font-size:13px!important;font-weight:500!important;color:#6b7280!important;margin-bottom:6px!important}.auth-form .input-wrapper--lg .input,.auth-form .input-wrapper .input{min-height:48px!important;font-size:15px!important;border-color:#e2e8f0!important;border-radius:10px!important;transition:border-color .2s ease,box-shadow .2s ease!important}.auth-form .input-wrapper--lg .input:focus,.auth-form .input-wrapper .input:focus{border-color:#45b35b!important;box-shadow:0 0 0 3px #45b35b26!important;outline:none!important}.auth-form .input-wrapper--error .input{border-color:#fca5a5!important}.auth-form .input-wrapper--error .input:focus{box-shadow:0 0 0 3px #ef44441f!important}.auth-form .input__error{font-size:12px!important;color:#dc2626!important;margin-top:5px!important}.auth-form--shake{animation:shake .5s ease}.auth-pw{display:flex;flex-direction:column}.auth-pw__label{display:block;font-size:13px;font-weight:500;color:#6b7280;margin-bottom:6px}.auth-pw__wrap{position:relative;display:flex;align-items:center}.auth-pw .input{padding-right:52px!important;min-height:48px!important;font-size:15px!important;border-color:#e2e8f0!important;border-radius:10px!important;transition:border-color .2s ease,box-shadow .2s ease!important}.auth-pw .input:focus{border-color:#45b35b!important;box-shadow:0 0 0 3px #45b35b26!important;outline:none!important}.auth-pw__toggle{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;padding:4px;cursor:pointer;color:#9ca3af;display:flex;align-items:center;justify-content:center;transition:color .2s ease;z-index:2;line-height:1}.auth-pw__toggle:hover{color:#4b5563}.auth-pw__toggle svg{width:18px;height:18px}.auth-pw__forgot-row{display:flex;justify-content:flex-end;margin-top:-6px}.auth-link{font-size:13px;color:#45b35b;text-decoration:none;font-weight:500;transition:color .2s ease}.auth-link:hover{color:#2f7a3c;text-decoration:underline}.auth-cta{width:100%!important;height:52px!important;font-size:15px!important;font-weight:600!important;border-radius:12px!important;margin-top:4px}.auth-cta.button--primary{background-color:#2f7a3c!important;border-color:#2f7a3c!important;color:#fff!important;transition:background-color .2s ease,transform .15s ease,box-shadow .2s ease!important}.auth-cta.button--primary:hover:not(:disabled){background-color:#1f6b2e!important;border-color:#1f6b2e!important;transform:scale(1.01)!important;box-shadow:0 4px 14px #2f7a3c4d!important}.auth-cta.button--primary:active:not(:disabled){transform:scale(.99)!important}.auth-cta.button--primary:disabled{opacity:.65!important;cursor:not-allowed!important}.auth-divider{width:100%;display:flex;align-items:center;gap:16px;margin:20px 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background-color:#e5e7eb}.auth-divider span{font-size:12px;color:#9ca3af;font-weight:500;text-transform:lowercase;flex-shrink:0}.auth-social{display:flex;gap:12px;width:100%}.auth-social__btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;height:44px;padding:0 16px;font-family:var(--font-family, inherit);font-size:14px;font-weight:500;color:#374151;background-color:#fff;border:1.5px solid #E5E7EB;border-radius:10px;cursor:pointer;transition:border-color .2s ease,background-color .2s ease,box-shadow .2s ease;white-space:nowrap}.auth-social__btn:hover:not(:disabled){border-color:#d1d5db;background-color:#f9fafb;box-shadow:0 1px 4px #0000000f}.auth-social__btn:active:not(:disabled){transform:translateY(1px)}.auth-social__btn:focus-visible{outline:none;box-shadow:0 0 0 3px #45b35b26}.auth-social__btn:disabled{opacity:.5;cursor:not-allowed}.auth-social__btn svg{width:18px;height:18px;flex-shrink:0}.auth-alt{text-align:center;margin-top:20px}.auth-alt p,.auth-alt .text{font-size:14px!important;color:#6b7280!important}.auth-alt__link{color:#45b35b;font-weight:700;text-decoration:none;transition:color .2s ease}.auth-alt__link:hover{color:#2f7a3c;text-decoration:underline}.auth-security{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:16px;padding:10px 14px;background:#f9fafb;border-radius:8px}.auth-security svg{color:#9ca3af;flex-shrink:0}.auth-security .text{font-size:12px!important;color:#9ca3af!important;line-height:1.4!important}.auth-trust{font-size:12px;color:#9ca3af;line-height:1.4;text-align:center;margin:12px 0 0}.auth-strength{margin-top:4px;margin-bottom:2px}.auth-strength__bar{height:4px;background:#e5e7eb;border-radius:9999px;overflow:hidden}.auth-strength__fill{height:100%;border-radius:9999px;transition:width .3s ease,background-color .3s ease}.auth-strength__fill--weak{width:20%;background-color:#ef4444}.auth-strength__fill--fair{width:60%;background-color:#f59e0b}.auth-strength__fill--strong{width:100%;background-color:#22c55e}.auth-strength__label{font-size:11px;margin-top:4px;text-align:right;font-weight:500}.auth-strength__label--weak{color:#ef4444}.auth-strength__label--fair{color:#f59e0b}.auth-strength__label--strong{color:#22c55e}.auth-requirements{display:flex;flex-direction:column;gap:7px;padding:14px 16px;background:#f9fafb;border:1px solid #E5E7EB;border-radius:10px;margin-top:2px}.auth-requirement{display:flex;align-items:center;justify-content:space-between;gap:8px}.auth-requirement__icon{width:16px;height:16px;min-width:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;background-color:#e5e7eb;color:#9ca3af;transition:background-color .2s ease,color .2s ease;flex-shrink:0}.auth-requirement--met .auth-requirement__icon{background-color:#22c55e;color:#fff}.auth-requirement__icon svg{width:10px;height:10px}.auth-requirement__label{font-size:12px;color:#9ca3af;transition:color .2s ease;line-height:1.4;order:-1}.auth-requirement--met .auth-requirement__label{color:#16a34a;font-weight:500}.auth-terms{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:13px;color:#6b7280;line-height:1.5;margin-top:4px}.auth-terms input[type=checkbox]{width:16px;height:16px;min-width:16px;margin-top:2px;accent-color:#2F7A3C;cursor:pointer;border-radius:4px}.auth-terms a{color:#45b35b;text-decoration:underline;text-underline-offset:2px;font-weight:500}.auth-terms a:hover{color:#2f7a3c}.auth-terms__error{font-size:12px!important;color:#dc2626!important;margin-top:-4px}@media(max-width:639px){.auth-page__center{padding:24px 16px 40px;align-items:flex-start}.auth-social{flex-direction:column}.auth-social__btn{flex:unset;width:100%}.auth-divider{margin:16px 0}}.auth-verify{width:100%;display:flex;flex-direction:column;align-items:center;gap:0}.auth-verify__body{width:100%;display:flex;flex-direction:column;align-items:center;gap:20px}.auth-verify__otp{width:100%;display:flex;flex-direction:column;align-items:center}.auth-verify__timer{font-size:13px;color:#9ca3af;text-align:center;margin:0;line-height:1.5}.auth-verify__attempts{font-size:13px;color:#9ca3af;text-align:center;margin:0}.auth-verify__expired{width:100%;padding:12px 16px;background:#fef9c3;border:1px solid #FDE047;border-radius:10px;font-size:13px;color:#854d0e;text-align:center;line-height:1.5}.auth-verify__btn{width:100%!important;height:52px!important;font-size:15px!important;font-weight:600!important;border-radius:12px!important}.auth-verify__btn.button--primary{background-color:#2e7a3c!important;border-color:#2e7a3c!important;color:#fff!important;transition:background-color .2s ease,transform .15s ease,box-shadow .2s ease!important}.auth-verify__btn.button--primary:hover:not(:disabled){background-color:#1d6b2c!important;border-color:#1d6b2c!important;transform:scale(1.01)!important;box-shadow:0 4px 14px #2e7a3c47!important}.auth-verify__btn.button--primary:active:not(:disabled){transform:scale(.99)!important}.auth-verify__btn.button--primary:disabled{opacity:.55!important;cursor:not-allowed!important}.auth-verify__resend{text-align:center;font-size:14px;color:#6b7280;line-height:1.5}.auth-verify__resend-btn{background:none;border:none;padding:0;font-family:inherit;font-size:inherit;font-weight:600;color:#2e7a3c;cursor:pointer;text-decoration:none;transition:color .2s ease}.auth-verify__resend-btn:hover:not(:disabled){color:#1d6b2c;text-decoration:underline}.auth-verify__resend-btn:disabled{color:#9ca3af;cursor:not-allowed}.auth-verify__resend-countdown{font-weight:600;color:#9ca3af}.auth-verify__back-row{text-align:center;margin-top:4px}.auth-verify__back-link{font-size:13px;color:#6b7280;text-decoration:none;font-weight:500;transition:color .2s ease;display:inline-flex;align-items:center;gap:4px}.auth-verify__back-link:hover{color:#2e7a3c;text-decoration:underline}.auth-verify__back-link svg{width:14px;height:14px;flex-shrink:0}.auth-forgot__icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;margin:0 auto 4px;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-radius:16px;color:#2e7a3c}.auth-forgot__icon svg{width:32px;height:32px}.auth-forgot__form{display:flex;flex-direction:column;gap:16px;width:100%}.auth-forgot__success{width:100%;padding:12px 16px;background:#f0fdf4;border:1px solid #BBF7D0;border-radius:10px;font-size:14px;color:#166534;text-align:center;line-height:1.5}.auth-forgot__error{width:100%;padding:12px 16px;background:#fef2f2;border:1px solid #FECACA;border-radius:10px;font-size:14px;color:#dc2626;text-align:center;line-height:1.5}.auth-forgot__help{font-size:13px;color:#9ca3af;text-align:center;line-height:1.6;margin:0}@media(max-width:639px){.auth-forgot__icon{width:56px;height:56px}.auth-forgot__icon svg{width:28px;height:28px}}.auth-success{width:100%;display:flex;flex-direction:column;align-items:center;gap:20px}.auth-success__icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:50%;background-color:#2e7a3c;color:#fff;margin-bottom:4px;flex-shrink:0}.auth-success__icon svg{width:40px;height:40px}@media(prefers-reduced-motion:no-preference){.auth-success__icon{animation:successIconPop .5s cubic-bezier(.22,1,.36,1) both}}@keyframes successIconPop{0%{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}.auth-success__text{text-align:center;display:flex;flex-direction:column;gap:8px}.auth-success__title{font-size:22px;font-weight:700;color:#111827;margin:0;line-height:1.25;letter-spacing:-.01em}.auth-success__subtitle{font-size:15px;color:#6b7280;margin:0;line-height:1.55}.auth-success__btn{width:100%!important;height:52px!important;font-size:15px!important;font-weight:600!important;border-radius:12px!important}.auth-success__btn.button--primary{background-color:#2e7a3c!important;border-color:#2e7a3c!important;color:#fff!important;transition:background-color .2s ease,transform .15s ease,box-shadow .2s ease!important}.auth-success__btn.button--primary:hover:not(:disabled){background-color:#1d6b2c!important;border-color:#1d6b2c!important;transform:scale(1.01)!important;box-shadow:0 4px 14px #2e7a3c47!important}.auth-success__btn.button--primary:active:not(:disabled){transform:scale(.99)!important}.auth-success__help{font-size:13px;color:#9ca3af;text-align:center;line-height:1.5}.auth-success__help a{color:#2e7a3c;text-decoration:none;font-weight:500}.auth-success__help a:hover{text-decoration:underline;color:#1d6b2c}.auth-page-wrapper{display:flex;flex-direction:column;min-height:100vh;background-color:#f3f6f4}.auth-main{flex:1;display:flex;flex-direction:column}.auth-split{display:flex;flex-direction:column;flex:1;min-height:calc(100vh - var(--navbar-height, 72px))}@media(min-width:1024px){.auth-split{flex-direction:row}}.auth-split__visual{position:relative;overflow:hidden;background:linear-gradient(135deg,#2f7a3c,#45b35b 60%,#e9f5ec);min-height:220px;flex-shrink:0}@media(min-width:1024px){.auth-split__visual{flex:0 0 60%;min-height:unset}}.auth-split__form{display:flex;align-items:center;justify-content:center;padding:40px 24px;background-color:#f3f6f4}@media(min-width:1024px){.auth-split__form{flex:0 0 40%;padding:64px 48px}}.auth-container{width:100%;max-width:420px;background:#fff;border-radius:16px;box-shadow:0 4px 24px #00000014;padding:48px;display:flex;flex-direction:column}@media(max-width:639px){.auth-container{padding:32px 24px;border-radius:12px}}.auth-header{margin-bottom:32px}.auth-title{font-size:clamp(22px,3vw,28px)!important;font-weight:700!important;line-height:1.2!important;letter-spacing:-.02em!important;color:#1a1a1a!important;margin-bottom:6px!important}.auth-subtitle{color:#6b7280!important;font-size:14px!important;line-height:1.5!important}.auth-password-field{display:flex;flex-direction:column;gap:0}.auth-password-label{font-size:13px;font-weight:500;color:#6b7280;margin-bottom:6px;display:block}.auth-password-input-wrapper{position:relative;display:flex;align-items:center}.auth-password-field .input{padding-right:52px!important;min-height:48px!important;font-size:15px!important;border-color:#e2e8f0!important;border-radius:10px!important;transition:border-color .2s ease,box-shadow .2s ease!important}.auth-password-field .input:focus{border-color:#45b35b!important;box-shadow:0 0 0 3px #45b35b26!important;outline:none!important}.auth-password-toggle{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;padding:4px;cursor:pointer;color:#9ca3af;display:flex;align-items:center;justify-content:center;transition:color .2s ease;z-index:2;line-height:1}.auth-password-toggle:hover{color:#4b5563}.auth-password-toggle svg{width:18px;height:18px}.auth-forgot{display:flex;justify-content:flex-end;margin-top:-8px}.auth-forgot__link{font-size:13px;color:#45b35b;text-decoration:none;font-weight:500}.auth-forgot__link:hover{color:#2f7a3c;text-decoration:underline}.auth-submit{width:100%!important;height:48px!important;font-size:15px!important;font-weight:600!important;border-radius:10px!important;margin-top:4px}.auth-submit.button--primary{background-color:#2f7a3c!important;border-color:#2f7a3c!important;color:#fff!important}.auth-submit.button--primary:hover:not(:disabled){background-color:#1f6b2e!important;border-color:#1f6b2e!important}.auth-submit.button--primary:disabled{opacity:.65!important;cursor:not-allowed!important}.auth-alternate{text-align:center;margin-top:4px}.auth-alternate p,.auth-alternate .text{font-size:14px!important;color:#6b7280!important}.auth-alternate__link{color:#45b35b;font-weight:700;text-decoration:none}.auth-alternate__link:hover{color:#2f7a3c;text-decoration:underline}.auth-password-requirements{display:flex;flex-direction:column;gap:8px;padding:14px 16px;background:#f9fafb;border:1px solid #E5E7EB;border-radius:10px;margin-top:4px}.auth-requirement__header{display:flex;align-items:center;justify-content:space-between}.auth-terms-checkbox{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:13px;color:#6b7280;line-height:1.5;margin-top:4px}.auth-terms-checkbox input[type=checkbox]{width:16px;height:16px;min-width:16px;margin-top:2px;accent-color:#2F7A3C;cursor:pointer}.auth-terms-checkbox a{color:#45b35b;text-decoration:underline;font-weight:500}.auth-terms-checkbox a:hover{color:#2f7a3c}.auth-terms-error{font-size:12px!important;color:#dc2626!important;margin-top:-4px}.auth-name-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:480px){.auth-name-row{grid-template-columns:1fr}}.otp-group{width:100%;display:flex;flex-direction:column;align-items:center;gap:12px}.otp-group__error{font-size:13px;font-weight:500;color:#dc2626;text-align:center;margin:0;line-height:1.4}.forgot-password__back{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-small);color:var(--color-text-secondary);text-decoration:none;margin-bottom:var(--space-8);padding:var(--space-2) 0;transition:color var(--transition-base);align-self:flex-start}.forgot-password__back:hover{color:var(--color-primary)}.forgot-password__back svg{width:16px;height:16px}.forgot-password__icon-wrapper{display:flex;align-items:center;justify-content:center;width:64px;height:64px;margin:0 auto var(--space-6);background:linear-gradient(135deg,var(--color-background-primary) 0%,var(--color-primary-light) 100%);border-radius:var(--radius-xl);color:var(--color-primary)}.forgot-password__icon-wrapper svg{width:32px;height:32px}.forgot-password__icon-wrapper--success{background:linear-gradient(135deg,rgba(var(--color-primary-rgb),.1),rgba(var(--color-primary-rgb),.2));color:var(--color-success)}.forgot-password__help{text-align:center;margin-top:var(--space-6);line-height:1.6}.forgot-password__link{color:var(--color-primary);text-decoration:none;font-weight:var(--font-weight-medium);transition:color var(--transition-base)}.forgot-password__link:hover{color:var(--color-primary-hover);text-decoration:underline}.verify-otp__form{width:100%;display:flex;flex-direction:column;gap:var(--space-5);align-items:center}.verify-otp__timer{text-align:center}.verify-otp__resend{text-align:center;margin-top:var(--space-4)}.verify-otp__resend-button{background:none;border:none;padding:0;font-family:var(--font-family);font-size:inherit;font-weight:var(--font-weight-semibold);color:var(--color-primary);cursor:pointer;text-decoration:none;transition:color var(--transition-base)}.verify-otp__resend-button:hover:not(:disabled){color:var(--color-primary-hover);text-decoration:underline}.verify-otp__resend-button:disabled{color:var(--color-text-tertiary);cursor:not-allowed}.verify-otp__resend-countdown{font-weight:var(--font-weight-medium);color:var(--color-text-tertiary)}.verify-otp__demo{width:100%;margin-top:var(--space-8);border:var(--border-width) dashed var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.verify-otp__demo-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-4);background:var(--color-background-subtle);border:none;font-family:var(--font-family);font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:background-color var(--transition-base)}.verify-otp__demo-toggle:hover{background:var(--color-background-muted)}.verify-otp__demo-chevron{display:flex;align-items:center;justify-content:center;width:20px;height:20px;transition:transform var(--transition-base)}.verify-otp__demo-chevron svg{width:16px;height:16px}.verify-otp__demo-chevron--open{transform:rotate(180deg)}.verify-otp__demo-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-5);background:var(--color-background-elevated);text-align:center;animation:demoContentFadeIn .2s ease}@keyframes demoContentFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.verify-otp__demo-content strong{font-family:var(--font-mono, monospace);font-size:18px;letter-spacing:.1em;color:var(--color-text-primary)}@media(max-width:480px){.forgot-password__back{margin-bottom:var(--space-6)}.forgot-password__icon-wrapper{width:56px;height:56px;margin-bottom:var(--space-5)}.forgot-password__icon-wrapper svg{width:28px;height:28px}.verify-otp__demo-toggle{padding:var(--space-3)}.verify-otp__demo-content{padding:var(--space-4)}.verify-otp__demo-content strong{font-size:16px}}@media(prefers-reduced-motion:no-preference){.forgot-password__icon-wrapper{animation:iconWrapperPulse 2s ease-in-out infinite}@keyframes iconWrapperPulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.forgot-password__icon-wrapper--success{animation:successBounce .6s ease}@keyframes successBounce{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}}.profile-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--space-6);background:var(--color-background)}.profile-loading__spinner{width:48px;height:48px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.profile-page{min-height:100vh;background:var(--color-background)}.profile-main{padding-top:calc(var(--navbar-height) + var(--space-8));padding-bottom:var(--space-20);min-height:60vh}.profile-breadcrumb{display:block!important;margin:0 0 var(--space-6) 0;width:100%;clear:both}.profile-breadcrumb__list{display:flex;align-items:center;gap:var(--space-2);list-style:none;margin:0;padding:0}.profile-breadcrumb__item{display:flex;align-items:center;gap:var(--space-2)}.profile-breadcrumb__item svg{width:14px;height:14px;color:var(--color-text-tertiary)}.profile-breadcrumb__link{font-size:var(--font-size-small);color:var(--color-text-secondary);transition:color var(--transition-fast);text-decoration:none}.profile-breadcrumb__link:hover{color:var(--color-primary)}.profile-breadcrumb__current{font-size:var(--font-size-small);color:var(--color-text-tertiary)}.profile-header{display:block;margin-bottom:var(--space-6);padding:0 0 2rem;width:100%}.profile-header__content{display:block;width:100%}.profile-header__title{display:block!important;font-size:36px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--space-2) 0;line-height:1.2}.profile-header__subtitle{display:block;font-size:var(--font-size-large);color:var(--color-text-secondary);margin:0}.profile-layout{display:grid;grid-template-columns:320px 1fr;gap:var(--space-8);align-items:start}@media(max-width:1024px){.profile-layout{grid-template-columns:1fr}}.profile-sidebar{position:sticky;top:calc(var(--navbar-height) + var(--space-6))}@media(max-width:1024px){.profile-sidebar{position:static}}.profile-card{display:flex;flex-direction:column;align-items:center;background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8);width:100%;gap:1rem}.profile-card__avatar{width:96px;height:96px;margin:0;display:flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:var(--color-text-inverse);font-size:32px;font-weight:var(--font-weight-bold);box-shadow:0 4px 20px #2f5d4640;flex-shrink:0;overflow:hidden}.profile-card__avatar--has-image{background:none}.profile-card__avatar-img{width:100%;height:100%;object-fit:cover}.profile-card__name{font-size:22px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;text-align:center;width:100%}.profile-card__email{font-size:var(--font-size-small);color:var(--color-text-tertiary);margin:0;text-align:center;width:100%;word-break:break-word}.profile-card__meta{display:flex;flex-direction:column;align-items:center;gap:.25rem;margin:0;width:100%}.profile-card__family{font-size:var(--font-size-small);color:var(--color-text-secondary);text-align:center;margin:0}.profile-card__actions{display:flex;flex-direction:column;gap:var(--space-3);width:100%;margin:0}.profile-card__actions .button{width:100%;justify-content:center}.profile-card__actions .button svg{width:18px;height:18px}.profile-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);font-size:12px;font-weight:var(--font-weight-semibold);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em}.profile-badge--default{background:var(--color-background-subtle);color:var(--color-text-secondary)}.profile-badge--primary{background:var(--color-primary-light);color:var(--color-primary)}.profile-badge--success{background:#2f5d461a;color:var(--color-success)}.profile-badge--warning{background:#b7791f1a;color:var(--color-warning)}.profile-badge--danger{background:#ef44441a;color:var(--color-danger)}.profile-content{display:flex;flex-direction:column;gap:var(--space-6)}.profile-section-card{background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.profile-section-card__header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border-subtle);background:var(--color-background-subtle)}.profile-section-card__icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);background:var(--color-primary-light)}.profile-section-card__icon svg{width:18px;height:18px;color:var(--color-primary)}.profile-section-card__title{font-size:16px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.profile-section-card__content{padding:var(--space-5) var(--space-6)}.profile-section-card--danger .profile-section-card__header{background:#ef44440d;border-bottom-color:#ef44441a}.profile-section-card--danger .profile-section-card__icon{background:#ef44441a}.profile-section-card--danger .profile-section-card__icon svg{color:var(--color-danger)}.profile-section-card--danger .profile-section-card__title{color:var(--color-danger)}.profile-kv-group{display:flex;flex-direction:column}.profile-kv-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) 0;border-bottom:1px solid var(--color-border-subtle);gap:var(--space-4)}.profile-kv-row:last-child{border-bottom:none}.profile-kv-row__label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);flex-shrink:0}.profile-kv-row__icon{display:flex;align-items:center;justify-content:center}.profile-kv-row__icon svg{width:16px;height:16px;color:var(--color-text-tertiary)}.profile-kv-row__value{font-size:var(--font-size-body);color:var(--color-text-primary);text-align:right}.profile-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) 0;border-bottom:1px solid var(--color-border-subtle);gap:var(--space-4)}.profile-toggle-row:last-child{border-bottom:none}.profile-toggle-row--disabled{opacity:.6}.profile-toggle-row__content{display:flex;flex-direction:column;gap:2px}.profile-toggle-row__label{font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.profile-toggle-row__description{font-size:12px;color:var(--color-text-tertiary)}.profile-toggle-indicator{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);font-size:12px;font-weight:var(--font-weight-semibold);border-radius:var(--radius-full);background:var(--color-background-subtle);color:var(--color-text-tertiary)}.profile-toggle-indicator--on{background:var(--color-primary-light);color:var(--color-primary)}.profile-security-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) 0;border-bottom:1px solid var(--color-border-subtle)}.profile-security-row:last-child{border-bottom:none}.profile-security-link{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-primary);transition:color var(--transition-fast)}.profile-security-link:hover{color:var(--color-primary-hover)}.profile-security-link svg{width:16px;height:16px}.profile-danger-actions{display:flex;flex-direction:column;gap:var(--space-5)}.profile-danger-item{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-6);padding:var(--space-4);background:var(--color-background-subtle);border-radius:var(--radius-lg)}.profile-danger-item__content{flex:1}.profile-danger-item__content h4{font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.profile-danger-item__content p{font-size:var(--font-size-small);color:var(--color-text-tertiary);line-height:1.5}.profile-danger-item .button{flex-shrink:0}.profile-danger-item .button svg{width:16px;height:16px}.button--danger{background:var(--color-danger);color:#fff;border:none}.button--danger:hover:not(:disabled){background:#dc2626}.button--danger:disabled{background:var(--color-border);color:var(--color-text-tertiary);cursor:not-allowed}.profile-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--space-6);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.profile-modal{background:var(--color-background-elevated);border-radius:var(--radius-xl);padding:var(--space-8);max-width:420px;width:100%;text-align:center;box-shadow:var(--shadow-xl);animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.profile-modal__icon{width:64px;height:64px;margin:0 auto var(--space-5);display:flex;align-items:center;justify-content:center;border-radius:50%}.profile-modal__icon--danger{background:#ef44441a}.profile-modal__icon--danger svg{width:32px;height:32px;color:var(--color-danger)}.profile-modal__title{font-size:16px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-3)}.profile-modal__text{font-size:var(--font-size-body);color:var(--color-text-secondary);margin-bottom:var(--space-6);line-height:1.6}.profile-modal__actions{display:flex;gap:var(--space-3);justify-content:center}.profile-edit-form{display:flex;flex-direction:column;gap:var(--space-6)}.profile-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-5)}@media(max-width:640px){.profile-form-grid{grid-template-columns:1fr}}.profile-form-grid--single{grid-template-columns:1fr}.profile-form-field{display:flex;flex-direction:column;gap:var(--space-2)}.profile-form-field--full{grid-column:1 / -1}.profile-form-label{font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.profile-form-label--required:after{content:" *";color:var(--color-danger)}.profile-form-input{height:var(--input-height);padding:0 var(--input-padding-x);font-size:var(--font-size-body);color:var(--color-text-primary);background:var(--input-background);border:1px solid var(--input-border-color);border-radius:var(--input-radius);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.profile-form-input:focus{border-color:var(--input-border-color-focus);box-shadow:0 0 0 2px var(--color-focus-ring);outline:none}.profile-form-input:disabled{background:var(--color-background-subtle);color:var(--color-text-tertiary);cursor:not-allowed}.profile-form-hint{font-size:12px;color:var(--color-text-tertiary)}.profile-form-section-label{font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);padding-top:var(--space-2);border-top:1px solid var(--color-border);grid-column:1 / -1}.profile-form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);grid-column:1 / -1}@media(max-width:640px){.profile-form-row{grid-template-columns:1fr}}.profile-form-checkbox{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-small);color:var(--color-text-secondary);cursor:pointer;grid-column:1 / -1}.profile-form-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-primary);cursor:pointer}.profile-form-toggle{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);background:var(--color-background-subtle);border-radius:var(--radius-lg)}.profile-form-toggle__content{display:flex;flex-direction:column;gap:2px}.profile-form-toggle__label{font-size:var(--font-size-body);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.profile-form-toggle__description{font-size:12px;color:var(--color-text-tertiary)}.profile-toggle-switch{position:relative;width:48px;height:28px;background:var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-fast);border:none;padding:0}.profile-toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:24px;height:24px;background:#fff;border-radius:50%;transition:transform var(--transition-fast);box-shadow:var(--shadow-sm)}.profile-toggle-switch--active{background:var(--color-primary)}.profile-toggle-switch--active:after{transform:translate(20px)}.profile-form-actions{display:flex;flex-direction:row-reverse;gap:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border)}.profile-section-card--family .profile-section-card__header{background:linear-gradient(135deg,#2f5d4614,#2f5d460a);border-bottom-color:#2f5d461f}.profile-section-card--family .profile-section-card__icon{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%)}.profile-section-card--family .profile-section-card__icon svg{color:#fff}.profile-form-textarea{height:auto;min-height:100px;padding:var(--space-3) var(--input-padding-x);resize:vertical;font-family:inherit;line-height:1.5}.profile-family-actions{display:flex;justify-content:flex-end;gap:var(--space-4);padding-top:var(--space-5);margin-top:var(--space-4);border-top:1px solid var(--color-border-subtle)}.profile-toast{position:fixed;bottom:var(--space-6);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);background:var(--color-text-primary);color:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:1100;animation:toastSlideUp .3s ease}@keyframes toastSlideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.profile-toast--success{background:var(--color-success)}.profile-toast--error{background:var(--color-danger)}.profile-toast svg{width:20px;height:20px;flex-shrink:0}.profile-toast__message{font-size:var(--font-size-body);font-weight:var(--font-weight-medium)}@media(max-width:768px){.profile-main{padding:var(--space-6) 0 var(--space-16)}.profile-header{margin-bottom:var(--space-8)}.profile-card{padding:var(--space-6)}.profile-card__avatar{width:80px;height:80px;font-size:28px}.profile-section-card__header,.profile-section-card__content{padding:var(--space-4) var(--space-5)}.profile-danger-item{flex-direction:column;gap:var(--space-4)}.profile-danger-item .button{width:100%}.profile-modal{padding:var(--space-6);margin:var(--space-4)}.profile-modal__actions,.profile-form-actions{flex-direction:column}}@media(max-width:480px){.profile-kv-row{flex-direction:column;align-items:flex-start;gap:var(--space-1)}.profile-kv-row__value{text-align:left}.profile-toggle-row{flex-direction:column;align-items:flex-start;gap:var(--space-3)}}.billing-plan-card,.billing-payment-card{display:flex;flex-direction:column;gap:var(--space-6)}.billing-plan-header{display:flex;justify-content:space-between;align-items:flex-start}.billing-plan-name{font-size:18px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-2) 0}.billing-plan-price{display:flex;align-items:baseline;gap:2px}.billing-plan-amount{font-size:32px;font-weight:var(--font-weight-bold);color:var(--color-primary)}.billing-plan-interval{font-size:var(--font-size-small);color:var(--color-text-tertiary)}.billing-plan-details{padding:var(--space-4);background:var(--color-background-subtle);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:var(--space-2)}.billing-plan-detail{font-size:14px;color:var(--color-text-secondary);margin:0}.billing-plan-actions,.billing-payment-actions{display:flex;gap:var(--space-4)}.billing-payment-method{display:flex;gap:var(--space-5);padding:var(--space-5);background:var(--color-background-subtle);border:1px solid var(--color-border);border-radius:var(--radius-xl);align-items:center}.billing-card-brand{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);color:var(--color-text-tertiary)}.billing-card-brand svg{width:32px;height:32px}.billing-card-brand span{font-size:10px;font-weight:var(--font-weight-bold);text-transform:uppercase}.billing-card-details{display:flex;flex-direction:column;gap:var(--space-1)}.billing-card-number{font-size:16px;font-weight:var(--font-weight-medium);letter-spacing:.05em;margin:0}.billing-card-expiry{font-size:var(--font-size-small);color:var(--color-text-tertiary);margin:0}.billing-history{margin:0 -var(--space-6);overflow-x:auto}.billing-history-table{width:100%;border-collapse:collapse;min-width:600px}.billing-history-table th{text-align:left;padding:var(--space-3) var(--space-6);background:var(--color-background-subtle);color:var(--color-text-tertiary);font-size:12px;font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em}.billing-history-table td{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border-subtle);font-size:14px}.billing-history-table tr:last-child td{border-bottom:none}.billing-amount{font-weight:var(--font-weight-semibold)}.billing-download-link{display:inline-flex;align-items:center;gap:6px;color:var(--color-primary, #2F5D46);text-decoration:none;font-size:13px;font-weight:var(--font-weight-medium, 500);transition:opacity .2s ease;background:none;border:none;padding:0;cursor:pointer;font-family:inherit}.billing-download-link:hover:not(:disabled){opacity:.7}.billing-download-link:disabled{opacity:.5;cursor:default}.billing-download-link svg{width:14px;height:14px;flex-shrink:0}.billing-download-spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--color-primary, #2F5D46);border-top-color:transparent;border-radius:50%;animation:billing-spin .6s linear infinite;flex-shrink:0}@keyframes billing-spin{to{transform:rotate(360deg)}}.billing-info-box{display:flex;gap:var(--space-4);padding:var(--space-5);background:var(--color-background-warm);border-radius:var(--radius-xl);margin-top:var(--space-8)}.billing-info-box svg{width:24px;height:24px;color:var(--color-primary);flex-shrink:0}.billing-link{color:var(--color-primary);text-decoration:none;font-weight:var(--font-weight-medium)}.billing-link:hover{text-decoration:underline}@media(max-width:640px){.billing-plan-actions,.billing-payment-actions{flex-direction:column}.billing-payment-method{flex-direction:column;align-items:flex-start;gap:var(--space-4)}}.profile-table-wrapper{overflow-x:auto;margin:calc(var(--space-4) * -1)}.profile-table{width:100%;border-collapse:collapse;min-width:600px}.profile-table th{text-align:left;padding:var(--space-4);background:var(--color-background-subtle);font-size:13px;font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--color-border-subtle)}.profile-table td{padding:var(--space-4);border-bottom:1px solid var(--color-border-subtle);font-size:14px}.profile-table tr:last-child td{border-bottom:none}.profile-table tr:hover td{background:var(--color-background-muted)}.profile-invite-info{display:flex;flex-direction:column;gap:2px}.profile-invite-info__name{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.profile-invite-info__contact{font-size:12px;color:var(--color-text-tertiary)}.status-chip{display:inline-flex;padding:4px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:var(--font-weight-semibold);text-transform:capitalize}.status-chip--sent{background:#e0f2fe;color:#0369a1}.status-chip--accepted{background:var(--color-primary-light);color:var(--color-primary)}.status-chip--expired{background:#fee2e2;color:#b91c1c}.status-chip--scheduled{background:#fef3c7;color:#92400e}.status-chip--redeemed{background:#dcfce7;color:#166534}.profile-table-actions{display:flex;gap:var(--space-2);justify-content:flex-end}.action-icon-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-tertiary);cursor:pointer;transition:all .2s}.action-icon-btn:hover{background:var(--color-background-subtle);border-color:var(--color-primary);color:var(--color-primary)}.action-icon-btn svg{width:16px;height:16px}.profile-empty-state{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-12) 0;text-align:center}.profile-empty-state svg{width:64px;height:64px;color:var(--color-border-strong)}.profile-gift-plan{display:flex;flex-direction:column;gap:2px}.profile-gift-plan__name{font-size:var(--font-size-small);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.profile-gift-plan__cycle{font-size:11px;color:var(--color-text-tertiary);text-transform:capitalize}.profile-photo-section{display:flex;flex-direction:column;align-items:center;gap:var(--space-5);padding:var(--space-4) 0}.profile-photo-preview{position:relative;width:120px;height:120px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000001a}.profile-photo-preview__image{width:100%;height:100%;object-fit:cover}.profile-photo-preview__initials{font-size:40px;font-weight:var(--font-weight-bold);color:#fff;text-transform:uppercase}.profile-photo-preview__loading{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center}.profile-photo-loader{width:32px;height:32px;color:#fff;animation:spin 1s linear infinite}.profile-photo-actions{display:flex;gap:var(--space-3);align-items:center}.profile-photo-input{display:none}.profile-photo-button{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);font-size:var(--font-size-small);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);border:none}.profile-photo-button svg{width:16px;height:16px}.profile-photo-button--upload{background:var(--color-primary);color:#fff}.profile-photo-button--upload:hover{background:var(--color-primary);filter:brightness(.85)}.profile-photo-button--remove{background:transparent;color:var(--color-danger);border:1px solid var(--color-danger)}.profile-photo-button--remove:hover{background:var(--color-danger);color:#fff}.profile-photo-button--loading{opacity:.7;pointer-events:none}.profile-photo-button:disabled{opacity:.5;cursor:not-allowed}.profile-photo-hint{text-align:center;max-width:280px}@media(max-width:480px){.profile-photo-preview{width:100px;height:100px}.profile-photo-preview__initials{font-size:32px}.profile-photo-actions{flex-direction:column;width:100%}.profile-photo-button{width:100%;justify-content:center}}.billing-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-6);animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.billing-modal{background:var(--color-background-elevated);border-radius:var(--radius-xl);max-width:700px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040;animation:slideUp .3s ease}.billing-modal--sm{max-width:460px}.billing-modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border-subtle)}.billing-modal__header h3{font-size:20px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.billing-modal__close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-tertiary);cursor:pointer;transition:all var(--transition-fast)}.billing-modal__close:hover{background:var(--color-background-subtle);color:var(--color-text-primary)}.billing-modal__close svg{width:20px;height:20px}.billing-modal__body{padding:var(--space-6);overflow-y:auto}.billing-modal__footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-5) var(--space-6);border-top:1px solid var(--color-border-subtle);background:var(--color-background-subtle)}.billing-cycle-toggle{display:flex;justify-content:center;gap:var(--space-2);margin-bottom:var(--space-6);background:var(--color-background-subtle);padding:var(--space-1);border-radius:var(--radius-lg);width:fit-content;margin-left:auto;margin-right:auto}.billing-cycle-btn{padding:var(--space-2) var(--space-5);font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.billing-cycle-btn.active{background:var(--color-background-elevated);color:var(--color-primary);box-shadow:var(--shadow-sm)}.billing-cycle-btn:hover:not(.active){color:var(--color-text-primary)}.billing-plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4)}.billing-plan-option{position:relative;padding:var(--space-5);background:var(--color-background);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.billing-plan-option:hover{border-color:var(--color-primary-light);transform:translateY(-2px)}.billing-plan-option.selected{border-color:var(--color-primary);background:var(--color-primary-light)}.billing-plan-option.popular{border-color:var(--color-primary)}.billing-plan-badge{position:absolute;top:-10px;left:50%;transform:translate(-50%);padding:var(--space-1) var(--space-3);background:var(--color-primary);color:#fff;font-size:11px;font-weight:var(--font-weight-semibold);border-radius:var(--radius-full);white-space:nowrap}.billing-plan-option h4{font-size:16px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-2) 0}.billing-plan-option__price{margin-bottom:var(--space-3)}.billing-plan-option__price .amount{font-size:28px;font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.billing-plan-option__price .interval{font-size:var(--font-size-small);color:var(--color-text-tertiary)}.billing-plan-option__desc{font-size:13px;color:var(--color-text-secondary);margin:0 0 var(--space-3) 0;line-height:1.5}.billing-plan-option__features{list-style:none;padding:0;margin:0}.billing-plan-option__features li{display:flex;align-items:center;gap:var(--space-2);font-size:13px;color:var(--color-text-secondary);margin-bottom:var(--space-2)}.billing-plan-option__features li svg{width:14px;height:14px;color:var(--color-success);flex-shrink:0}.billing-no-plan{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-8) var(--space-4)}.billing-no-plan__icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary-light) 0%,rgba(47,93,70,.1) 100%);border-radius:50%;margin-bottom:var(--space-5)}.billing-no-plan__icon svg{width:32px;height:32px;color:var(--color-primary)}.billing-no-plan__title{font-size:20px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-3) 0}.billing-no-plan__description{font-size:var(--font-size-body);color:var(--color-text-secondary);max-width:400px;line-height:1.6;margin:0 0 var(--space-6) 0}.billing-cancel-warning{display:flex;align-items:flex-start;gap:var(--space-4);padding:var(--space-5);background:#ef44440d;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-lg)}.billing-cancel-warning svg{width:24px;height:24px;color:var(--color-danger);flex-shrink:0}.billing-cancel-warning p{margin:0;font-size:var(--font-size-body);color:var(--color-text-primary);line-height:1.6}.btn-danger{background:var(--color-danger)!important;border-color:var(--color-danger)!important}.btn-danger:hover:not(:disabled){background:#dc2626!important;border-color:#dc2626!important}@media(max-width:640px){.billing-plans-grid{grid-template-columns:1fr}.billing-modal{margin:var(--space-4);max-height:calc(100vh - var(--space-8))}.billing-modal__body{padding:var(--space-4)}}.billing-payment-loading{padding:var(--space-6);text-align:center}.billing-no-payment-methods{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8) 0;gap:var(--space-4);color:var(--color-text-tertiary);text-align:center}.billing-no-payment-methods svg{width:48px;height:48px;stroke-width:1.5;opacity:.5}.billing-no-payment-methods button{display:flex;align-items:center;gap:var(--space-2)}.billing-no-payment-methods button svg{width:20px;height:20px;opacity:1}.billing-payment-list{display:flex;flex-direction:column;gap:var(--space-3)}.billing-payment-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);background:var(--color-background);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);transition:border-color var(--transition-fast);width:100%}.billing-payment-item:hover{border-color:var(--color-border)}.billing-payment-item--default{border-color:var(--color-primary);background:var(--color-primary-light)}.billing-payment-item .billing-payment-item__content{display:flex;align-items:center;gap:var(--space-4);flex:1}.billing-payment-icon{display:flex;align-items:center;justify-content:center;width:48px;height:32px;background:var(--color-background-subtle);border-radius:var(--radius-sm);border:1px solid var(--color-border-subtle);color:var(--color-text-secondary)}.billing-payment-icon svg{width:20px;height:20px}.billing-payment-info{display:flex;flex-direction:column;gap:2px;flex:1}.billing-payment-title-row{display:flex;align-items:center;gap:var(--space-3)}.billing-payment-title{font-weight:var(--font-weight-medium);color:var(--color-text-primary);font-size:15px}.billing-payment-subtitle{font-size:13px;color:var(--color-text-tertiary)}.billing-payment-item-actions{display:flex;align-items:center;gap:var(--space-2)}.billing-icon-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);color:var(--color-text-tertiary);transition:all var(--transition-fast);border:none;background:transparent;cursor:pointer}.billing-icon-btn:hover{background:var(--color-background-subtle);color:var(--color-text-primary)}.billing-icon-btn--danger:hover{background:#ef44441a;color:var(--color-danger)}.billing-icon-btn svg{width:18px;height:18px}.billing-payment-actions{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border-subtle)}@media(max-width:480px){.billing-payment-item{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.billing-payment-item-actions{width:100%;justify-content:flex-end}}.payment-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-6);animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.payment-modal{background:var(--color-background-elevated);border-radius:var(--radius-xl);max-width:440px;width:100%;overflow:hidden;box-shadow:0 25px 50px -12px #00000040;animation:slideUp .3s ease}.payment-modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border-subtle);background:var(--color-background-subtle)}.payment-modal__header-content{display:flex;align-items:center;gap:var(--space-3)}.payment-modal__header-content svg{width:24px;height:24px;color:var(--color-primary)}.payment-modal__header h3{font-size:18px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.payment-modal__close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-tertiary);cursor:pointer;transition:all var(--transition-fast)}.payment-modal__close:hover{background:var(--color-background);color:var(--color-text-primary)}.payment-modal__close svg{width:20px;height:20px}.payment-modal__form{padding:var(--space-6)}.payment-form__field{margin-bottom:var(--space-4)}.payment-form__label{display:block;font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.payment-form__input-wrapper{padding:var(--space-3) var(--space-4);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.payment-form__input-wrapper:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.payment-form__stripe-input{width:100%}.payment-form__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.payment-form__error{padding:var(--space-3) var(--space-4);background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);color:var(--color-danger);font-size:var(--font-size-small);margin-bottom:var(--space-4)}.payment-form__security{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4);background:var(--color-background-subtle);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.payment-form__security svg{width:16px;height:16px;color:var(--color-success)}.payment-form__security span{font-size:13px;color:var(--color-text-tertiary)}.payment-modal__footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-4);border-top:1px solid var(--color-border-subtle);margin-top:var(--space-2)}.payment-btn{padding:var(--space-3) var(--space-5);font-size:var(--font-size-small);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none}.payment-btn--primary{background:var(--color-primary);color:#fff}.payment-btn--primary:hover:not(:disabled){background:var(--color-primary-hover)}.payment-btn--primary:disabled{opacity:.6;cursor:not-allowed}.payment-btn--secondary{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}.payment-btn--secondary:hover:not(:disabled){background:var(--color-background-subtle)}@media(max-width:480px){.payment-form__row{grid-template-columns:1fr}.payment-modal{margin:var(--space-4)}}.referrals-page{min-height:100vh;background-color:var(--color-bg-subtle, #f8f9fa);padding-top:var(--navbar-height, 80px)}.referrals-main{padding:3rem 0}.referrals-header{margin-bottom:2.5rem;max-width:800px}.referrals-header h1{font-size:2.5rem;margin-bottom:.5rem;background:linear-gradient(135deg,var(--color-primary, #4a6cf7) 0%,var(--color-accent, #6366f1) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.referrals-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2.5rem}.stat-card{display:flex;align-items:center;gap:1.25rem;padding:1.5rem;border-radius:1rem;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-4px);box-shadow:0 10px 25px -5px #0000000d}.stat-card__icon{display:flex;align-items:center;justify-content:center;width:3.5rem;height:3.5rem;border-radius:1rem;flex-shrink:0}.stat-card__icon svg{width:1.5rem;height:1.5rem}.stat-card__icon--blue{background:#3b82f61a;color:#3b82f6}.stat-card__icon--green{background:#22c55e1a;color:#22c55e}.stat-card__icon--purple{background:#a855f71a;color:#a855f7}.stat-card__icon--pink{background:#ec48991a;color:#ec4899}.stat-card__value{display:block;font-size:1.75rem;font-weight:700;line-height:1.2;color:var(--color-text-primary, #111827)}.referrals-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:2rem}@media(max-width:992px){.referrals-grid{grid-template-columns:1fr}}.referrals-column{display:flex;flex-direction:column;gap:2rem}.referral-link-card{padding:2rem;border-radius:1.25rem}.link-input-group{display:flex;gap:.75rem;margin-top:1.5rem}.link-input{flex:1;background:var(--color-bg-subtle, #f3f4f6);padding:.75rem 1rem;border-radius:.75rem;font-family:monospace;font-size:.9rem;color:var(--color-text-secondary, #4b5563);border:1px solid var(--color-border, #e5e7eb);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.copy-button{min-width:100px}.tier-ladder-card{padding:2rem;border-radius:1.25rem}.progress-container{margin:2rem 0}.progress-bar{height:10px;background:var(--color-bg-subtle, #f3f4f6);border-radius:5px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary, #4a6cf7),var(--color-accent, #6366f1));border-radius:5px;transition:width .6s cubic-bezier(.4,0,.2,1)}.progress-labels{display:flex;justify-content:space-between}.tiers-list{display:flex;flex-direction:column;gap:1rem}.tier-item{display:flex;gap:1.25rem;padding:1.25rem;border-radius:1rem;border:1px solid var(--color-border, #e5e7eb);transition:all .2s ease}.tier-item--achieved{background:#22c55e0d;border-color:#22c55e33}.tier-item--next{border-color:var(--color-primary, #4a6cf7);box-shadow:0 0 0 2px #4a6cf71a}.tier-item__checkbox{width:1.5rem;height:1.5rem;border-radius:50%;border:2px solid var(--color-border, #e5e7eb);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.25rem}.tier-item--achieved .tier-item__checkbox{background:#22c55e;border-color:#22c55e;color:#fff}.tier-item__checkbox svg{width:.9rem;height:.9rem}.tier-item__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem}.tier-badge{font-size:.75rem;font-weight:600;padding:.2rem .6rem;border-radius:2rem;background:var(--color-bg-subtle, #f3f4f6);color:var(--color-text-secondary, #4b5563)}.tier-item--achieved .tier-badge{background:#22c55e1a;color:#166534}.activity-card{border-radius:1.25rem;overflow:hidden}.activity-header{padding:1.5rem 2rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--color-border, #e5e7eb)}.filter-chips{display:flex;gap:.5rem}.filter-chip{padding:.5rem 1rem;border-radius:2rem;font-size:.875rem;font-weight:500;background:var(--color-bg-subtle, #f3f4f6);color:var(--color-text-secondary, #4b5563);border:none;cursor:pointer;transition:all .2s ease}.filter-chip--active{background:var(--color-primary, #4a6cf7);color:#fff}.activity-table-container{padding:0}.activity-table{width:100%;border-collapse:collapse}.activity-table th{text-align:left;padding:1rem 2rem;font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--color-text-tertiary, #9ca3af);border-bottom:1px solid var(--color-border, #e5e7eb)}.activity-table td{padding:1.25rem 2rem;border-bottom:1px solid var(--color-border, #f3f4f6)}.table-user{display:flex;align-items:center;gap:1rem}.table-user__avatar{width:2.25rem;height:2.25rem;border-radius:50%;background:var(--color-bg-subtle, #f3f4f6);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--color-primary, #4a6cf7);font-size:.875rem}.status-badge{font-size:.75rem;font-weight:600;padding:.25rem .75rem;border-radius:2rem;text-transform:capitalize}.status-badge--pending{background:#f59e0b1a;color:#d97706}.status-badge--qualified{background:#22c55e1a;color:#166534}.empty-state{padding:5rem 2rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.empty-state__icon{font-size:3rem}.simulation-section{margin-top:1rem;display:flex;justify-content:center}.mb-4{margin-bottom:1rem}.mt-4{margin-top:1rem}.keepsakes-page{min-height:100vh;background:#fafafa}.keepsakes-main{padding:40px 0 80px}.keepsakes-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:40px}.keepsakes-header h1{margin:0 0 8px}.keepsakes-controls{margin-bottom:32px}.filter-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:#fff;padding:8px 16px;border-radius:40px;border:1px solid #eee;width:fit-content}.filter-icon{color:#999;margin-right:8px}.filter-icon svg{width:18px;height:18px}.filter-pill{background:none;border:none;padding:8px 16px;border-radius:20px;font-size:.875rem;font-weight:500;color:#666;cursor:pointer;transition:all .2s}.filter-pill:hover{background:#f5f5f5;color:#333}.filter-pill.active{background:#0d9488;color:#fff}.keepsakes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}.keepsake-card{cursor:pointer;transition:transform .2s,box-shadow .2s;height:100%}.keepsake-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001a}.keepsake-image{position:relative;aspect-ratio:16/9;overflow:hidden;border-radius:12px 12px 0 0}.keepsake-image img{width:100%;height:100%;object-fit:cover}.keepsake-type-badge{position:absolute;top:12px;right:12px;background:#ffffffe6;padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:600;color:#0d9488}.keepsake-info{padding:16px;position:relative}.keepsake-title{margin:0 0 4px;font-size:1.125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:60px}.keepsake-card-actions{position:absolute;top:16px;right:16px;display:flex;gap:4px}.card-action-btn{background:none;border:none;color:#999;padding:6px;cursor:pointer;border-radius:6px;transition:all .2s}.card-action-btn:hover{background:#f5f5f5;color:#333}.card-action-btn.danger:hover{background:#fef2f2;color:#ef4444}.card-action-btn svg{width:18px;height:18px}.keepsakes-empty{text-align:center;padding:80px 0;background:#fff;border-radius:20px;border:2px dashed #eee}.mt-4{margin-top:24px}.preview-modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:3000;padding:40px}.preview-modal{background:#fff;border-radius:20px;width:100%;max-width:800px;overflow:hidden;animation:modalIn .3s cubic-bezier(.16,1,.3,1)}@keyframes modalIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.preview-modal-header{padding:24px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #f0f0f0}.preview-modal-content{padding:32px}.full-preview-img{width:100%;border-radius:12px;margin-bottom:24px;box-shadow:0 8px 16px #0000001a}.preview-details{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.detail-item{display:flex;flex-direction:column;gap:4px}.privacy-badge{background:#f1f5f9;padding:2px 8px;border-radius:4px;font-size:.875rem;width:fit-content}.preview-modal-footer{padding:24px;border-top:1px solid #f0f0f0;display:flex;justify-content:flex-end;gap:12px;background:#fafafa}@media(max-width:640px){.keepsakes-header{flex-direction:column;align-items:flex-start;gap:20px}.preview-details{grid-template-columns:1fr}.preview-modal-overlay{padding:20px}}.gift-page{min-height:100vh;background-color:var(--color-background);display:flex;flex-direction:column}.gift-main{flex:1;padding-top:var(--space-12);padding-bottom:var(--space-20)}.gift-steps{display:flex;align-items:center;justify-content:center;gap:var(--space-4);margin-bottom:var(--space-12)}.gift-step{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);opacity:.4;transition:all var(--transition-base)}.gift-step--active{opacity:1}.gift-step__number{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--color-background-subtle);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-small);font-weight:var(--font-weight-bold);color:var(--color-text-tertiary)}.gift-step--active .gift-step__number{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-inverse);box-shadow:0 0 0 4px #2f5d461a}.gift-step__label{font-size:12px;font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.gift-step-divider{width:40px;height:1px;background:var(--color-border);margin-top:-16px}.gift-flow-container{background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:var(--space-10);box-shadow:var(--shadow-xl);min-height:500px;display:flex;flex-direction:column}.gift-flow-header{margin-bottom:var(--space-10)}.gift-flow-header h2{margin-bottom:var(--space-2)}.gift-billing-toggle-wrapper{display:flex;justify-content:center;margin-bottom:var(--space-8)}.gift-plans-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6)}.gift-plan-card{background:var(--color-background-subtle);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8);transition:all var(--transition-base);cursor:pointer;display:flex;flex-direction:column}.gift-plan-card:hover{border-color:var(--color-border-strong);transform:translateY(-2px)}.gift-plan-card--selected{border-color:var(--color-primary);background:linear-gradient(to bottom,rgba(47,93,70,.03) 0%,transparent 100%);box-shadow:0 0 0 1px var(--color-primary)}.gift-plan-card__header{text-align:center;padding-bottom:var(--space-6);border-bottom:1px solid var(--color-border-subtle);margin-bottom:var(--space-6)}.gift-plan-card__price-wrapper{display:flex;align-items:baseline;justify-content:center;gap:4px;margin-bottom:var(--space-2)}.gift-plan-card__price{font-size:clamp(32px,4vw,40px);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.gift-plan-card__period{font-size:var(--font-size-small);color:var(--color-text-tertiary)}.gift-plan-card__features{flex:1;display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-8)}.gift-plan-card__features li{display:flex;align-items:center;gap:var(--space-3);color:var(--color-text-secondary)}.gift-plan-card__features svg{width:18px;height:18px;color:var(--color-primary);flex-shrink:0}.gift-form{max-width:600px;margin:0 auto;width:100%}.gift-form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);margin-bottom:var(--space-4)}.gift-form-group{margin-bottom:var(--space-6);display:flex;flex-direction:column;gap:var(--space-2)}.gift-form-group label{font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.gift-form-group input,.gift-form-group textarea{padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-background-subtle);color:var(--color-text-primary);font-size:var(--font-size-body);transition:all var(--transition-base)}.gift-form-group input:focus,.gift-form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2f5d461a}.gift-delivery-options{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.gift-delivery-option{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base)}.gift-delivery-option:hover{border-color:var(--color-border-strong)}.gift-delivery-option--active{border-color:var(--color-primary);background:#2f5d460d}.gift-delivery-option input{width:18px;height:18px;margin:0}.gift-delivery-option span{font-size:var(--font-size-body);font-weight:var(--font-weight-medium)}.gift-scheduled-date{margin-top:var(--space-3)}.gift-form-actions{display:flex;justify-content:space-between;margin-top:var(--space-10);padding-top:var(--space-6);border-top:1px solid var(--color-border-subtle)}.gift-payment-content{max-width:500px;margin:0 auto;width:100%;display:flex;flex-direction:column;gap:var(--space-8)}.gift-summary-card{background:var(--color-background-subtle);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6)}.gift-summary-row{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-4)}.gift-summary-row--total{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border-subtle);color:var(--color-text-primary)}.gift-summary-item{display:flex;flex-direction:column}.gift-payment-card-ui{display:flex;flex-direction:column;gap:var(--space-4)}.mock-card{background:linear-gradient(135deg,#1e1e1e,#333);border-radius:var(--radius-xl);padding:var(--space-6);color:#fff;box-shadow:var(--shadow-lg)}.mock-card__header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-6);opacity:.9}.mock-card__header svg{width:24px;height:24px}.mock-card__field label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;opacity:.6}.mock-card__field input{width:100%;background:transparent;border:none;color:#fff;font-size:18px;font-family:monospace;letter-spacing:.1em;padding:0}.mock-card__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);margin-top:var(--space-6)}.payment-note{margin-top:var(--space-2);font-style:italic}.gift-confirmation{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-10) 0}.gift-success-icon{width:100px;height:100px;background:var(--color-primary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:var(--space-8);box-shadow:0 0 0 10px #2f5d460d}.gift-success-icon-svg{width:50px;height:50px}.gift-redemption-box{margin-top:var(--space-10);padding:var(--space-6);background:var(--color-background-subtle);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:500px}.gift-link-copy{display:flex;align-items:center;justify-content:space-between;background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);margin-top:var(--space-4)}.gift-link-copy code{font-family:monospace;font-size:var(--font-size-small);color:var(--color-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:var(--space-4)}.gift-link-copy button{background:transparent;border:none;color:var(--color-text-tertiary);cursor:pointer;transition:color var(--transition-base);display:flex;align-items:center}.gift-link-copy button:hover{color:var(--color-primary)}.gift-link-copy svg{width:20px;height:20px}.gift-confirmation-actions{display:flex;gap:var(--space-4);margin-top:var(--space-10)}.animate-fade-in{animation:fadeIn .4s ease-out forwards}.animate-scale-in{animation:scaleIn .5s cubic-bezier(.16,1,.3,1) forwards}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media(max-width:768px){.gift-plans-grid,.gift-form-row{grid-template-columns:1fr}.gift-flow-container{padding:var(--space-6)}.gift-confirmation-actions{flex-direction:column;width:100%}.gift-confirmation-actions button{width:100%}}@keyframes obCardIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.ob-card{width:100%;max-width:420px;background:#fff;border-radius:20px;box-shadow:0 10px 40px #0000000f;padding:48px 48px 40px;display:flex;flex-direction:column;gap:0}@media(prefers-reduced-motion:no-preference){.ob-card{animation:obCardIn .45s cubic-bezier(.22,1,.36,1) both}}@media(max-width:639px){.ob-card{padding:36px 24px 32px;border-radius:16px;max-width:100%}}.ob-steps{display:flex;align-items:center;gap:8px;margin-bottom:28px}.ob-step{width:8px;height:8px;border-radius:50%;background:#e2e8f0;transition:background-color .25s ease,transform .25s ease;flex-shrink:0}.ob-step--active{background:#2e7a3c;transform:scale(1.25)}.ob-step--done{background:#86c49a}.ob-card__header{margin-bottom:28px}.ob-card__title{font-size:26px;font-weight:700;line-height:1.2;letter-spacing:-.02em;color:#111827;margin:0 0 6px}@media(max-width:639px){.ob-card__title{font-size:22px}}.ob-card__subtitle{font-size:15px;color:#6b7280;line-height:1.5;margin:0}.ob-card__form{display:flex;flex-direction:column;gap:20px;width:100%}.ob-card__form .input{min-height:48px!important;font-size:15px!important;border-color:#e2e8f0!important;border-radius:10px!important;transition:border-color .2s ease,box-shadow .2s ease!important}.ob-card__form .input:focus{border-color:#45b35b!important;box-shadow:0 0 0 3px #45b35b26!important;outline:none!important}.ob-card__form .input-wrapper--error .input{border-color:#fca5a5!important}.ob-card__form .input-wrapper--error .input:focus{box-shadow:0 0 0 3px #ef44441f!important}.ob-card__form .input__label{font-size:13px!important;font-weight:500!important;color:#6b7280!important;margin-bottom:6px!important}.ob-card__form .input__error{font-size:12px!important;color:#dc2626!important;margin-top:5px!important}.ob-card__form .input__helper{font-size:12px!important;color:#9ca3af!important;margin-top:4px!important}.ob-card__name-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media(max-width:479px){.ob-card__name-row{grid-template-columns:1fr}}.ob-card__cta{width:100%;height:52px;padding:0 24px;font-family:inherit;font-size:15px;font-weight:600;color:#fff;background-color:#2e7a3c;border:none;border-radius:12px;cursor:pointer;transition:background-color .2s ease,transform .15s ease,box-shadow .2s ease;margin-top:4px}.ob-card__cta:hover:not(:disabled){background-color:#1d6b2c;transform:scale(1.01);box-shadow:0 4px 14px #2e7a3c4d}.ob-card__cta:active:not(:disabled){transform:scale(.99)}.ob-card__cta:disabled{opacity:.65;cursor:not-allowed}.ob-card__error{padding:12px 16px;background:#fef2f2;border:1px solid #FECACA;border-radius:10px;font-size:13px;color:#dc2626;line-height:1.4}.ob-card__back{margin:20px 0 0;text-align:center}.ob-card__back-btn{background:none;border:none;padding:0;font-family:inherit;font-size:13px;font-weight:500;color:#9ca3af;cursor:pointer;transition:color .2s ease;text-decoration:underline;text-underline-offset:2px}.ob-card__back-btn:hover{color:#4b5563}.ob-page{min-height:100vh;display:flex;flex-direction:column;background:#f4f6f5}.ob-main{flex:1;display:flex;align-items:flex-start;padding:3rem 0 4rem}.ob-container{max-width:960px;margin:0 auto;width:100%;padding:0 1.5rem}.ob-header{text-align:center;margin-bottom:3rem}.ob-progress-chip{display:inline-flex;align-items:center;padding:.375rem 1rem;background:#e9f5ec;color:#2e7a3c;font-size:.875rem;font-weight:600;border-radius:100px;margin-bottom:1rem}.ob-title{font-size:2.25rem;font-weight:700;color:var(--color-text-primary);margin:0 0 .75rem;line-height:1.2}.ob-subtitle{font-size:1.0625rem;color:var(--color-text-secondary);margin:0;line-height:1.6}.ob-grid{display:grid;grid-template-columns:3fr 2fr;gap:2rem;align-items:start}@media(max-width:768px){.ob-grid{grid-template-columns:1fr}}.ob-form-card{background:#fff;border:1px solid var(--color-border);border-radius:16px;padding:2rem}.ob-form{display:flex;flex-direction:column;gap:1.75rem}.ob-form-section{display:flex;flex-direction:column;gap:1rem}.ob-form-section__title{font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);margin:0;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.ob-form-section__row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media(max-width:480px){.ob-form-section__row{grid-template-columns:1fr}}.ob-form-field{display:flex;flex-direction:column;gap:.375rem}.ob-form-field__label{font-size:.9375rem;font-weight:500;color:var(--color-text-primary)}.ob-form-field__optional{color:var(--color-text-tertiary);font-weight:400}.ob-form .input{min-height:48px;font-size:.9375rem;border-radius:10px}.ob-form .input:focus{border-color:#2e7a3c;box-shadow:0 0 0 3px #2e7a3c26}.ob-textarea{width:100%;min-height:80px;padding:.75rem 1rem;font-size:.9375rem;font-family:inherit;line-height:1.5;border:1px solid var(--color-border);border-radius:10px;background:var(--color-background);color:var(--color-text-primary);resize:vertical;transition:border-color .2s ease,box-shadow .2s ease}.ob-textarea:focus{outline:none;border-color:#2e7a3c;box-shadow:0 0 0 3px #2e7a3c26}.ob-textarea::placeholder{color:var(--color-text-tertiary)}.ob-cta{margin-top:.5rem}.ob-cta.button--primary{background-color:#2e7a3c;border-color:#2e7a3c}.ob-cta.button--primary:hover:not(:disabled){background-color:#1f6b2e;border-color:#1f6b2e}.ob-cta.button--primary:active:not(:disabled){background-color:#196028;border-color:#196028}.ob-error{padding:.875rem 1rem;background:#fef2f2;border:1px solid #FECACA;border-radius:8px}.ob-error .text{color:#dc2626}.ob-preview{background:#f9fbfa;border:1px solid var(--color-border);border-radius:16px;padding:2rem}.ob-preview__title{font-size:1.125rem;font-weight:600;color:var(--color-text-primary);margin:0 0 1.25rem}.ob-preview__items{display:flex;flex-direction:column;gap:.75rem}.ob-preview-item{display:flex;align-items:flex-start;gap:.875rem;padding:1rem;background:#fff;border:1px solid var(--color-border);border-radius:12px;transition:border-color .2s ease,box-shadow .2s ease}.ob-preview-item:hover{border-color:#2e7a3c;box-shadow:0 2px 8px #0000000a}.ob-preview-item__icon{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#e9f5ec;border-radius:10px}.ob-preview-item__icon svg{width:20px;height:20px;color:#2e7a3c}.ob-preview-item__content{display:flex;flex-direction:column;gap:.125rem}.ob-preview-item__title{font-size:.9375rem;font-weight:600;color:var(--color-text-primary)}.ob-preview-item__desc{font-size:.8125rem;color:var(--color-text-tertiary);line-height:1.4}@media(max-width:768px){.ob-main{padding:2rem 0 3rem}.ob-header{margin-bottom:2rem}.ob-title{font-size:1.75rem}.ob-form-card,.ob-preview{padding:1.5rem}}@media(max-width:480px){.ob-container{padding:0 1rem}.ob-title{font-size:1.5rem}.ob-subtitle{font-size:.9375rem}.ob-form-card,.ob-preview{padding:1.25rem}.ob-preview-item{padding:.875rem}.ob-preview-item__icon{width:36px;height:36px}.ob-preview-item__icon svg{width:18px;height:18px}}@keyframes fh-fade-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fh-visual-in{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.family-hero{background-color:#f6f1e8;padding-top:var(--space-20);padding-bottom:var(--space-20);overflow:hidden}.family-hero__container{max-width:1200px;margin:0 auto;padding:0 24px}.family-hero__grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}@media(min-width:1024px){.family-hero__grid{grid-template-columns:55fr 45fr;gap:56px}}.family-hero__content{display:flex;flex-direction:column;align-items:flex-start}@media(max-width:1023px){.family-hero__content{align-items:center;text-align:center}}.family-hero__animate{opacity:0;animation:fh-fade-up .6s ease forwards}.family-hero__animate--1{animation-delay:.05s}.family-hero__animate--2{animation-delay:.18s}.family-hero__animate--3{animation-delay:.3s}.family-hero__animate--4{animation-delay:.42s}.family-hero__animate--5{animation-delay:.54s}.family-hero__animate--visual{animation:fh-visual-in .75s ease forwards;animation-delay:.28s}@media(prefers-reduced-motion:reduce){.family-hero__animate,.family-hero__animate--visual{animation:none;opacity:1;transform:none}}.family-hero__name{font-size:clamp(32px,5vw,48px);font-weight:800;color:var(--color-text-primary);line-height:1.1;letter-spacing:-.02em;margin:0 0 16px}.family-hero__subtitle{font-size:18px;color:var(--color-text-secondary);line-height:1.6;margin:0 0 24px;max-width:440px}@media(max-width:1023px){.family-hero__subtitle{max-width:100%}}.family-hero__location{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:#0000000f;border-radius:var(--radius-full);font-size:13px;color:var(--color-text-tertiary);font-weight:500;white-space:nowrap;line-height:1.4}.family-hero__location svg{flex-shrink:0;color:var(--color-text-tertiary)}.family-hero__stats{display:flex;gap:32px;margin-top:24px;flex-wrap:wrap}@media(max-width:1023px){.family-hero__stats{justify-content:center}}.family-hero__stat{display:flex;flex-direction:column;gap:2px}.family-hero__stat-value{font-size:32px;font-weight:700;color:var(--color-text-primary);line-height:1.1;letter-spacing:-.01em}.family-hero__stat-label{font-size:13px;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.04em;font-weight:500}.family-hero__actions{display:flex;gap:12px;margin-top:32px;flex-wrap:wrap}@media(max-width:1023px){.family-hero__actions{justify-content:center}}.family-hero__btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 28px;border-radius:var(--radius-lg);font-weight:600;font-size:14px;cursor:pointer;white-space:nowrap;transition:background-color var(--transition-base),color var(--transition-base),border-color var(--transition-base),box-shadow var(--transition-base),transform var(--transition-base);text-decoration:none;line-height:1}.family-hero__btn:active{transform:translateY(0)!important;box-shadow:none!important}.family-hero__btn--outline{background-color:transparent;border:1.5px solid var(--color-text-primary);color:var(--color-text-primary)}.family-hero__btn--outline:hover{background-color:var(--color-text-primary);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #1a1a1a2e}.family-hero__btn--solid{background-color:#2e7a3c;color:#fff;border:1.5px solid transparent}.family-hero__btn--solid:hover{background-color:#256832;transform:translateY(-1px);box-shadow:0 4px 16px #2e7a3c4d}.family-hero__visual{display:flex;align-items:center;justify-content:center}@media(max-width:1023px){.family-hero__visual{order:2;width:100%;max-width:340px;margin:0 auto}}.family-hero__collage{position:relative;width:100%;padding-bottom:100%;max-width:400px;margin:0 auto}@media(max-width:1023px){.family-hero__collage{max-width:320px}}.family-hero__collage-photo{position:absolute;border-radius:50%;object-fit:cover;border:3px solid #ffffff;box-shadow:var(--shadow-md);z-index:1;transition:transform var(--transition-base),box-shadow var(--transition-base)}.family-hero__collage-photo:hover{transform:scale(1.06);box-shadow:var(--shadow-lg);z-index:2}.about-family.reveal{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease}.about-family.reveal.revealed{opacity:1;transform:translateY(0)}@media(prefers-reduced-motion:reduce){.about-family.reveal{opacity:1;transform:none;transition:none}}.about-family{background-color:var(--color-background);padding-top:var(--space-20);padding-bottom:var(--space-20)}.about-family__container{max-width:1100px;margin:0 auto;padding:0 24px}.about-family__grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:center}@media(min-width:768px){.about-family__grid{grid-template-columns:1fr 1fr;gap:48px}}.about-family__content{display:flex;flex-direction:column}.about-family__eyebrow{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#2e7a3c;margin:0 0 12px;line-height:1.4}.about-family__heading{font-size:32px;font-weight:700;color:var(--color-text-primary);line-height:1.2;margin:0 0 24px;letter-spacing:-.01em}@media(max-width:639px){.about-family__heading{font-size:26px}}.about-family__body{display:flex;flex-direction:column}.about-family__paragraph{font-size:16px;color:var(--color-text-secondary);line-height:1.7;margin:0 0 16px}.about-family__paragraph:last-child{margin-bottom:0}.about-family__image-wrap{width:100%}@media(max-width:767px){.about-family__image-wrap{order:1}.about-family__content{order:-1}}.about-family__image{display:block;width:100%;aspect-ratio:4 / 3;object-fit:cover;border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.tree-preview{padding:80px 0;background:var(--color-background-subtle)}.tree-preview__container{max-width:1200px;margin:0 auto;padding:0 24px}.tree-preview__header{text-align:center;margin-bottom:48px}.tree-preview__heading{font-size:32px;font-weight:700;color:var(--color-text-primary);margin:0 0 12px;letter-spacing:-.02em;line-height:1.15}.tree-preview__subtitle{font-size:16px;color:var(--color-text-secondary);line-height:1.6;margin:0}.tree-preview__canvas-wrap{position:relative;max-width:800px;margin:0 auto;aspect-ratio:8 / 4;background:var(--color-background-elevated);border-radius:var(--radius-xl);border:1px solid var(--color-border);overflow:hidden}@media(max-width:639px){.tree-preview__canvas-wrap{overflow-x:auto;overflow-y:hidden;aspect-ratio:unset;height:260px}.tree-preview__svg{min-width:600px}}.tree-preview__svg{display:block;width:100%;height:100%}.tree-preview__conn-spouse{stroke:var(--color-border);stroke-width:1.5}.tree-preview__conn-parent{stroke:#c5c5c5;stroke-width:1.5}.tree-preview__node{cursor:default}.tree-preview__tooltip-bg{fill:#2d2d2d;opacity:0;pointer-events:none;transition:opacity .15s ease}.tree-preview__tooltip-text{font-family:var(--font-family, "Inter", sans-serif);font-size:11px;font-weight:500;fill:#fff;opacity:0;pointer-events:none;transition:opacity .15s ease}.tree-preview__node:hover .tree-preview__tooltip-bg,.tree-preview__node:hover .tree-preview__tooltip-text{opacity:1}.tree-preview__node:hover circle:last-of-type{filter:drop-shadow(0 0 6px rgba(0,0,0,.18))}@media(prefers-reduced-motion:reduce){.tree-preview__tooltip-bg,.tree-preview__tooltip-text{transition:none}}.tree-preview__cta-row{display:flex;justify-content:center;margin-top:32px}.tree-preview__cta-btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 28px;background:#2e7a3c;color:#fff;font-size:14px;font-weight:600;border:none;border-radius:var(--radius-lg);cursor:pointer;text-decoration:none;line-height:1;transition:background-color var(--transition-base),transform var(--transition-base),box-shadow var(--transition-base)}.tree-preview__cta-btn:hover{background:#256832;transform:translateY(-1px);box-shadow:0 4px 16px #2e7a3c4d}.tree-preview__cta-btn:active{transform:translateY(0);box-shadow:none}.tree-preview__cta-btn:focus-visible{outline:2px solid #2E7A3C;outline-offset:3px}@media(max-width:639px){.tree-preview{padding:56px 0}.tree-preview__heading{font-size:26px}.tree-preview__cta-btn{width:100%;max-width:280px}}.featured-memories{padding:80px 0;background:var(--color-background)}.featured-memories__container{max-width:1200px;margin:0 auto;padding:0 24px}.featured-memories__header{text-align:center;margin-bottom:48px}.featured-memories__heading{font-size:32px;font-weight:700;color:var(--color-text-primary);margin:0 0 12px;letter-spacing:-.02em;line-height:1.15}.featured-memories__subtitle{font-size:16px;color:var(--color-text-secondary);max-width:520px;margin:0 auto;line-height:1.6}.featured-memories__grid{display:grid;grid-template-columns:1fr;gap:24px}@media(min-width:640px){.featured-memories__grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.featured-memories__grid{grid-template-columns:repeat(3,1fr)}}.featured-memories__card{background:var(--color-background-elevated);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden;transition:transform var(--transition-base),box-shadow var(--transition-base);cursor:pointer;display:flex;flex-direction:column;height:100%}.featured-memories__card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.featured-memories__image-wrap{position:relative;aspect-ratio:4 / 3;overflow:hidden;flex-shrink:0}.featured-memories__image{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}.featured-memories__card:hover .featured-memories__image{transform:scale(1.05)}.featured-memories__overlay{position:absolute;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-base)}.featured-memories__card:hover .featured-memories__overlay{opacity:1}.featured-memories__overlay-label{font-size:14px;font-weight:600;color:#fff;letter-spacing:.01em}.featured-memories__body{padding:16px;display:flex;flex-direction:column;flex:1}.featured-memories__title{font-size:15px;font-weight:600;color:var(--color-text-primary);margin:0 0 4px;line-height:1.3}.featured-memories__date{font-size:13px;color:var(--color-text-tertiary);margin:0 0 12px}.featured-memories__stats{display:flex;gap:16px;margin-top:auto}.featured-memories__stat{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--color-text-tertiary)}.featured-memories__stat svg{flex-shrink:0}@media(max-width:639px){.featured-memories{padding:56px 0}.featured-memories__heading{font-size:26px}}.history-timeline{padding:80px 0;background:var(--color-background-elevated)}.history-timeline__container{max-width:800px;margin:0 auto;padding:0 24px}.history-timeline__header{text-align:center;margin-bottom:48px}.history-timeline__heading{font-size:32px;font-weight:700;color:var(--color-text-primary);margin:0 0 12px;letter-spacing:-.02em;line-height:1.15}.history-timeline__subtitle{font-size:16px;color:var(--color-text-secondary);margin:0;line-height:1.6}.history-timeline__items{position:relative;padding-left:48px}.history-timeline__items:before{content:"";position:absolute;left:19px;top:0;bottom:0;width:2px;background:var(--color-border)}.history-timeline__item{position:relative;padding-bottom:40px}.history-timeline__item--last{padding-bottom:0}.history-timeline__dot{position:absolute;left:-35px;top:3px;width:14px;height:14px;border-radius:50%;background:#2e7a3c;border:3px solid var(--color-background-elevated);box-shadow:0 0 0 2px var(--color-border);flex-shrink:0}.history-timeline__year{font-size:14px;font-weight:700;color:#2e7a3c;margin:0 0 4px;line-height:1.4}.history-timeline__event-title{font-size:18px;font-weight:600;color:var(--color-text-primary);margin:0 0 8px;line-height:1.3}.history-timeline__description{font-size:15px;color:var(--color-text-secondary);margin:0;line-height:1.6}@media(max-width:639px){.history-timeline{padding:56px 0}.history-timeline__heading{font-size:26px}.history-timeline__items{padding-left:36px}.history-timeline__items:before{left:15px}.history-timeline__dot{left:-27px}.history-timeline__event-title{font-size:16px}}.family-connections{padding:80px 0;background:var(--color-background-subtle)}.family-connections__container{max-width:1200px;margin:0 auto;padding:0 24px}.family-connections__header{text-align:center;margin-bottom:48px}.family-connections__heading{font-size:32px;font-weight:700;color:var(--color-text-primary);margin:0 0 12px;letter-spacing:-.02em;line-height:1.15}.family-connections__subtitle{font-size:16px;color:var(--color-text-secondary);line-height:1.6;margin:0 auto;max-width:480px}.family-connections__grid{display:grid;grid-template-columns:1fr;gap:24px}@media(min-width:640px){.family-connections__grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.family-connections__grid{grid-template-columns:repeat(4,1fr)}}.connections__card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px;background:var(--color-background-elevated);border-radius:var(--radius-lg);border:1px solid var(--color-border);transition:transform var(--transition-base),box-shadow var(--transition-base);height:100%}.connections__card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.connections__avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;border:2px solid var(--color-border);margin:0 auto 16px;display:block;flex-shrink:0}.connections__name{font-size:16px;font-weight:600;color:var(--color-text-primary);margin:0 0 4px;line-height:1.3}.connections__relationship{font-size:13px;color:var(--color-text-tertiary);margin:0 0 8px;line-height:1.4}.connections__shared{font-size:13px;color:var(--color-text-secondary);margin:0 0 16px;line-height:1.4}.connections__shared-count{font-weight:700;color:#2e7a3c}.connections__discover-link{display:inline-flex;align-items:center;gap:4px;margin-top:auto;font-size:14px;font-weight:600;color:#2e7a3c;text-decoration:none;transition:color var(--transition-base);line-height:1}.connections__discover-link:hover{text-decoration:underline;color:#256832}.connections__discover-link svg{flex-shrink:0;transition:transform var(--transition-base)}.connections__discover-link:hover svg{transform:translate(2px)}.connections__discover-link:focus-visible{outline:2px solid #2E7A3C;outline-offset:3px;border-radius:2px}@media(max-width:639px){.family-connections{padding:56px 0}.family-connections__heading{font-size:26px}.connections__card{padding:20px}}.family-cta{padding:80px 0;background:#2e7a3c;width:100%}.family-cta__inner{max-width:600px;margin:0 auto;padding:0 24px;text-align:center}.family-cta__heading{font-size:clamp(28px,4vw,36px);font-weight:700;color:#fff;margin:0 0 16px;line-height:1.2;letter-spacing:-.01em}.family-cta__subtitle{font-size:17px;color:#ffffffd9;line-height:1.6;margin:0 0 32px}.family-cta__btn{display:inline-block;padding:14px 36px;background:#fff;color:#2e7a3c;font-size:15px;font-weight:600;border-radius:var(--radius-lg);text-decoration:none;line-height:1;transition:background-color var(--transition-base),transform var(--transition-base)}.family-cta__btn:hover{background:#f0f0f0;transform:translateY(-1px)}.family-cta__btn:active{transform:translateY(0)}.family-cta__btn:focus-visible{outline:2px solid #ffffff;outline-offset:3px}.family-cta__note{font-size:13px;color:#fff9;margin:16px 0 0;line-height:1.4}@media(max-width:639px){.family-cta{padding:64px 0}.family-cta__subtitle{font-size:15px}.family-cta__btn{display:block;width:100%;max-width:280px;margin:0 auto;text-align:center}}.view-family{min-height:100vh;display:flex;flex-direction:column}.view-family main{flex:1}.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}.reveal.revealed{opacity:1;transform:translateY(0)}@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}.story-detail-page{min-height:100vh;background-color:var(--color-background);display:flex;flex-direction:column}.story-not-found{flex:1;display:flex;align-items:center;justify-content:center;text-align:center;padding:var(--space-20) 0}.story-not-found__content{display:flex;flex-direction:column;align-items:center;gap:var(--space-6);max-width:400px}.story-not-found__icon{width:80px;height:80px;border-radius:50%;background:var(--color-background-subtle);display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary)}.story-not-found__icon svg{width:36px;height:36px}.story-detail-header{background-color:var(--color-background-elevated);border-bottom:1px solid var(--color-border);padding:var(--space-8) 0 var(--space-10)}.story-detail-header__content{display:flex;flex-direction:column;gap:var(--space-6)}.story-breadcrumb{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-small);color:var(--color-text-tertiary)}.story-breadcrumb__link{color:var(--color-primary);text-decoration:none;font-weight:var(--font-weight-medium);transition:color var(--transition-fast)}.story-breadcrumb__link:hover{color:var(--color-primary-hover);text-decoration:underline}.story-breadcrumb svg{width:14px;height:14px}.story-breadcrumb__current{color:var(--color-text-secondary);max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.story-detail-header__row{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-8)}.story-detail-header__title-section{flex:1}.story-detail__title{font-size:clamp(28px,4vw,42px);font-weight:var(--font-weight-bold);line-height:1.2;color:var(--color-text-primary);margin-bottom:var(--space-4);letter-spacing:var(--letter-spacing-tight)}.story-detail__meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);font-size:var(--font-size-small);color:var(--color-text-secondary)}.story-detail__meta-divider{color:var(--color-text-tertiary)}.story-detail__category{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);background:var(--color-primary-light);color:var(--color-primary);border-radius:var(--radius-full);font-size:11px;font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.05em}.story-detail__date,.story-detail__read-time{display:inline-flex;align-items:center;gap:var(--space-1)}.story-detail__date svg,.story-detail__read-time svg{width:14px;height:14px;color:var(--color-text-tertiary)}.story-detail__author{display:inline-flex;align-items:center;gap:var(--space-2)}.author-avatar-small{width:22px;height:22px;border-radius:50%;background:var(--color-primary);color:var(--color-text-inverse);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:var(--font-weight-bold)}.story-detail-header__actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.story-overflow-menu{position:relative}.story-overflow-btn{width:40px;height:40px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-background-elevated);color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.story-overflow-btn:hover{background:var(--color-background-subtle);border-color:var(--color-border-strong)}.story-overflow-btn svg{width:20px;height:20px}.story-overflow-dropdown{position:absolute;top:calc(100% + var(--space-2));right:0;min-width:160px;background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(-8px);transition:all var(--transition-fast);z-index:var(--z-dropdown)}.story-overflow-menu:hover .story-overflow-dropdown,.story-overflow-menu:focus-within .story-overflow-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.overflow-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);background:none;border:none;font-size:var(--font-size-small);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.overflow-item:hover{background:var(--color-background-subtle);color:var(--color-text-primary)}.overflow-item:first-child{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.overflow-item:last-child{border-radius:0 0 var(--radius-lg) var(--radius-lg)}.overflow-item svg{width:16px;height:16px}.overflow-item--danger{color:var(--color-error)}.overflow-item--danger:hover{background:#c5303014;color:var(--color-error)}.story-hero-section{padding:0 0 var(--space-12)}.story-hero{margin-top:calc(var(--space-8) * -1)}.story-hero__image-wrapper{position:relative;border-radius:var(--radius-xl);overflow:hidden;background:var(--color-background-subtle)}.story-hero__image{width:100%;height:auto;max-height:500px;object-fit:cover;display:block}.story-hero__caption{margin-top:var(--space-3);font-size:var(--font-size-small);color:var(--color-text-tertiary);font-style:italic;text-align:center}.story-content-section{padding:0 0 var(--space-16)}.story-layout{display:grid;grid-template-columns:1fr 340px;gap:var(--space-12);align-items:start}.story-content{min-width:0}.story-body{max-width:720px;font-size:18px;line-height:1.75;color:var(--color-text-primary);overflow-wrap:break-word;word-break:break-word}.story-body p{margin-bottom:var(--space-6)}.story-body img,.story-body video,.story-body iframe{max-width:100%;height:auto;border-radius:var(--radius-md)}.story-body h2{font-size:24px;font-weight:var(--font-weight-bold);margin-top:var(--space-10);margin-bottom:var(--space-4);color:var(--color-text-primary);letter-spacing:var(--letter-spacing-tight)}.story-body blockquote{margin:var(--space-8) 0;padding:var(--space-6) var(--space-8);background:var(--color-background-warm);border-left:4px solid var(--color-primary);border-radius:0 var(--radius-lg) var(--radius-lg) 0;font-size:20px;font-style:italic;color:var(--color-text-secondary);line-height:1.6}.story-body ul{margin:var(--space-6) 0;padding-left:var(--space-6)}.story-body li{margin-bottom:var(--space-2);position:relative}.story-body li::marker{color:var(--color-primary)}.story-memory-links{margin-top:var(--space-12);padding-top:var(--space-8);border-top:1px solid var(--color-border)}.story-memory-links__title{font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-4)}.story-memory-links__chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.memory-chip{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-background-subtle);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-small);color:var(--color-text-secondary);text-decoration:none;transition:all var(--transition-fast)}.memory-chip:hover{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.memory-chip__avatar{width:20px;height:20px;border-radius:50%;background:var(--color-background);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:var(--font-weight-bold)}.story-comments{margin-top:var(--space-12);padding-top:var(--space-8);border-top:1px solid var(--color-border)}.story-comments__title{font-size:20px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-6)}.comment-composer{display:flex;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-8)}.comment-composer__avatar{width:40px;height:40px;border-radius:50%;background:var(--color-primary);color:var(--color-text-inverse);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:var(--font-weight-bold);flex-shrink:0;overflow:hidden}.comment-composer__avatar .avatar-img,.comment__avatar .avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.comment-composer__input-wrapper{flex:1;position:relative}.comment-composer__input{width:100%;padding:var(--space-3) var(--space-12) var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-body);background:var(--color-background-elevated);transition:all var(--transition-fast)}.comment-composer__input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-focus-ring)}.comment-composer__input::placeholder{color:var(--color-text-tertiary)}.comment-composer__send{position:absolute;right:var(--space-2);top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:50%;border:none;background:var(--color-primary);color:var(--color-text-inverse);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.comment-composer__send:hover{background:var(--color-primary-hover);transform:translateY(-50%) scale(1.05)}.comment-composer__send svg{width:14px;height:14px}.comments-list{display:flex;flex-direction:column;gap:var(--space-6)}.comment{display:flex;gap:var(--space-3)}.comment__avatar{width:40px;height:40px;border-radius:50%;background:var(--color-background-subtle);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:var(--font-weight-bold);color:var(--color-text-secondary);flex-shrink:0;overflow:hidden}.comment__content{flex:1;background:var(--color-background-subtle);padding:var(--space-4);border-radius:var(--radius-lg)}.comment__header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.comment__author{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-size:var(--font-size-small)}.comment__date{font-size:12px;color:var(--color-text-tertiary)}.comment__text{font-size:var(--font-size-body);color:var(--color-text-secondary);line-height:1.5}.comment__actions{display:flex;gap:var(--space-4);margin-top:var(--space-3)}.comment__action{display:inline-flex;align-items:center;gap:var(--space-1);background:none;border:none;font-size:12px;color:var(--color-text-tertiary);cursor:pointer;transition:color var(--transition-fast)}.comment__action:hover{color:var(--color-primary)}.comment__action svg{width:14px;height:14px}.comment-thread{display:flex;flex-direction:column;gap:var(--space-1)}.comment__action--active{color:var(--color-error)!important}.comment__action--active svg{fill:var(--color-error)}.comment__action--danger:hover{color:var(--color-error)!important}.comment__edited{font-size:11px;color:var(--color-text-tertiary);font-style:italic;margin-left:var(--space-1)}.comment__edit-form{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-2)}.comment__edit-input{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--color-primary);border-radius:var(--radius-md);font-size:var(--font-size-body);background:var(--color-background-elevated);box-shadow:0 0 0 3px var(--color-focus-ring)}.comment__edit-input:focus{outline:none}.comment__edit-actions{display:flex;gap:var(--space-2)}.comment__edit-btn{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border:none;border-radius:var(--radius-md);font-size:12px;font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast)}.comment__edit-btn svg{width:12px;height:12px}.comment__edit-btn--save{background:var(--color-primary);color:var(--color-text-inverse)}.comment__edit-btn--save:hover{background:var(--color-primary-hover)}.comment__edit-btn--cancel{background:var(--color-background-subtle);color:var(--color-text-secondary)}.comment__edit-btn--cancel:hover{background:var(--color-border)}.comment-replies{margin-left:52px;display:flex;flex-direction:column;gap:var(--space-3);padding-left:var(--space-4);border-left:2px solid var(--color-border-subtle)}.comment--reply{gap:var(--space-2)}.comment__avatar--small{width:28px;height:28px;font-size:10px}.reply-composer{display:flex;align-items:flex-start;gap:var(--space-2);margin-left:52px;padding-left:var(--space-4);margin-top:var(--space-2)}.story-sidebar{display:flex;flex-direction:column;gap:var(--space-6);position:sticky;top:calc(var(--navbar-height) + var(--space-6))}.story-sidebar-card{padding:var(--space-6)}.sidebar-card__title{font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-5);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border-subtle)}.sidebar-info-row{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) 0}.sidebar-info-row+.sidebar-info-row{border-top:1px solid var(--color-border-subtle)}.sidebar-info-icon{width:32px;height:32px;border-radius:var(--radius-md);background:var(--color-background-subtle);display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);flex-shrink:0}.sidebar-info-icon svg{width:16px;height:16px}.sidebar-info-label{display:block;font-size:12px;color:var(--color-text-tertiary);margin-bottom:2px}.sidebar-info-value{display:block;font-size:var(--font-size-small);color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.tagged-people-list{display:flex;flex-direction:column;gap:var(--space-2)}.tagged-person{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2);border-radius:var(--radius-md);text-decoration:none;transition:background var(--transition-fast)}.tagged-person:hover{background:var(--color-background-subtle)}.tagged-person__avatar{width:32px;height:32px;border-radius:50%;background:var(--color-primary-light);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:var(--font-weight-bold);color:var(--color-primary)}.tagged-person__name{font-size:var(--font-size-small);color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.related-memories-list{display:flex;flex-direction:column;gap:var(--space-3)}.related-memory{display:flex;gap:var(--space-3);padding:var(--space-2);border-radius:var(--radius-md);text-decoration:none;transition:background var(--transition-fast)}.related-memory:hover{background:var(--color-background-subtle)}.related-memory__image{width:60px;height:45px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.related-memory__info{display:flex;flex-direction:column;gap:2px;overflow:hidden}.related-memory__title{font-size:var(--font-size-small);color:var(--color-text-primary);font-weight:var(--font-weight-medium);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.related-memory__date{font-size:12px;color:var(--color-text-tertiary)}@media(max-width:1024px){.story-layout{grid-template-columns:1fr}.story-sidebar{position:static;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-6)}}@media(max-width:768px){.story-detail-header{padding:var(--space-6) 0 var(--space-8)}.story-detail-header__row{flex-direction:column;gap:var(--space-6)}.story-detail-header__actions{width:100%;justify-content:flex-start}.story-detail__meta{gap:var(--space-2) var(--space-3)}.story-hero__image{max-height:300px}.story-body{font-size:16px}.story-body h2{font-size:20px}.story-body blockquote{font-size:17px;padding:var(--space-4) var(--space-5)}.story-sidebar{grid-template-columns:1fr}.story-comments{margin-top:var(--space-8);padding-top:var(--space-6)}}@media(max-width:480px){.story-detail__title{font-size:24px}.story-detail__meta{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.story-detail__meta-divider{display:none}.comment{flex-direction:column}.comment__avatar{width:32px;height:32px}.comment-replies,.reply-composer{margin-left:var(--space-6);padding-left:var(--space-3)}}.ql-container{box-sizing:border-box;font-family:Helvetica,Arial,sans-serif;font-size:13px;height:100%;margin:0;position:relative}.ql-container.ql-disabled .ql-tooltip{visibility:hidden}.ql-container:not(.ql-disabled) li[data-list=checked]>.ql-ui,.ql-container:not(.ql-disabled) li[data-list=unchecked]>.ql-ui{cursor:pointer}.ql-clipboard{left:-100000px;height:1px;overflow-y:hidden;position:absolute;top:50%}.ql-clipboard p{margin:0;padding:0}.ql-editor{box-sizing:border-box;counter-reset:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;line-height:1.42;height:100%;outline:none;overflow-y:auto;padding:12px 15px;tab-size:4;-moz-tab-size:4;text-align:left;white-space:pre-wrap;word-wrap:break-word}.ql-editor>*{cursor:text}.ql-editor p,.ql-editor ol,.ql-editor pre,.ql-editor blockquote,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{margin:0;padding:0}@supports (counter-set:none){.ql-editor p,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{counter-set:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor p,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{counter-reset:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor table{border-collapse:collapse}.ql-editor td{border:1px solid #000;padding:2px 5px}.ql-editor ol{padding-left:1.5em}.ql-editor li{list-style-type:none;padding-left:1.5em;position:relative}.ql-editor li>.ql-ui:before{display:inline-block;margin-left:-1.5em;margin-right:.3em;text-align:right;white-space:nowrap;width:1.2em}.ql-editor li[data-list=checked]>.ql-ui,.ql-editor li[data-list=unchecked]>.ql-ui{color:#777}.ql-editor li[data-list=bullet]>.ql-ui:before{content:"•"}.ql-editor li[data-list=checked]>.ql-ui:before{content:"☑"}.ql-editor li[data-list=unchecked]>.ql-ui:before{content:"☐"}@supports (counter-set:none){.ql-editor li[data-list]{counter-set:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list]{counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered]{counter-increment:list-0}.ql-editor li[data-list=ordered]>.ql-ui:before{content:counter(list-0,decimal) ". "}.ql-editor li[data-list=ordered].ql-indent-1{counter-increment:list-1}.ql-editor li[data-list=ordered].ql-indent-1>.ql-ui:before{content:counter(list-1,lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-1{counter-set:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-1{counter-reset:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-2{counter-increment:list-2}.ql-editor li[data-list=ordered].ql-indent-2>.ql-ui:before{content:counter(list-2,lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-2{counter-set:list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-2{counter-reset:list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-3{counter-increment:list-3}.ql-editor li[data-list=ordered].ql-indent-3>.ql-ui:before{content:counter(list-3,decimal) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-3{counter-set:list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-3{counter-reset:list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-4{counter-increment:list-4}.ql-editor li[data-list=ordered].ql-indent-4>.ql-ui:before{content:counter(list-4,lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-4{counter-set:list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-4{counter-reset:list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-5{counter-increment:list-5}.ql-editor li[data-list=ordered].ql-indent-5>.ql-ui:before{content:counter(list-5,lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-5{counter-set:list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-5{counter-reset:list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-6{counter-increment:list-6}.ql-editor li[data-list=ordered].ql-indent-6>.ql-ui:before{content:counter(list-6,decimal) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-6{counter-set:list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-6{counter-reset:list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-7{counter-increment:list-7}.ql-editor li[data-list=ordered].ql-indent-7>.ql-ui:before{content:counter(list-7,lower-alpha) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-7{counter-set:list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-7{counter-reset:list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-8{counter-increment:list-8}.ql-editor li[data-list=ordered].ql-indent-8>.ql-ui:before{content:counter(list-8,lower-roman) ". "}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-8{counter-set:list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-8{counter-reset:list-9}}.ql-editor li[data-list=ordered].ql-indent-9{counter-increment:list-9}.ql-editor li[data-list=ordered].ql-indent-9>.ql-ui:before{content:counter(list-9,decimal) ". "}.ql-editor .ql-indent-1:not(.ql-direction-rtl){padding-left:3em}.ql-editor li.ql-indent-1:not(.ql-direction-rtl){padding-left:4.5em}.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:3em}.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:4.5em}.ql-editor .ql-indent-2:not(.ql-direction-rtl){padding-left:6em}.ql-editor li.ql-indent-2:not(.ql-direction-rtl){padding-left:7.5em}.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:6em}.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:7.5em}.ql-editor .ql-indent-3:not(.ql-direction-rtl){padding-left:9em}.ql-editor li.ql-indent-3:not(.ql-direction-rtl){padding-left:10.5em}.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:9em}.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:10.5em}.ql-editor .ql-indent-4:not(.ql-direction-rtl){padding-left:12em}.ql-editor li.ql-indent-4:not(.ql-direction-rtl){padding-left:13.5em}.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:12em}.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:13.5em}.ql-editor .ql-indent-5:not(.ql-direction-rtl){padding-left:15em}.ql-editor li.ql-indent-5:not(.ql-direction-rtl){padding-left:16.5em}.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:15em}.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:16.5em}.ql-editor .ql-indent-6:not(.ql-direction-rtl){padding-left:18em}.ql-editor li.ql-indent-6:not(.ql-direction-rtl){padding-left:19.5em}.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:18em}.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:19.5em}.ql-editor .ql-indent-7:not(.ql-direction-rtl){padding-left:21em}.ql-editor li.ql-indent-7:not(.ql-direction-rtl){padding-left:22.5em}.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:21em}.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:22.5em}.ql-editor .ql-indent-8:not(.ql-direction-rtl){padding-left:24em}.ql-editor li.ql-indent-8:not(.ql-direction-rtl){padding-left:25.5em}.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:24em}.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:25.5em}.ql-editor .ql-indent-9:not(.ql-direction-rtl){padding-left:27em}.ql-editor li.ql-indent-9:not(.ql-direction-rtl){padding-left:28.5em}.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:27em}.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:28.5em}.ql-editor li.ql-direction-rtl{padding-right:1.5em}.ql-editor li.ql-direction-rtl>.ql-ui:before{margin-left:.3em;margin-right:-1.5em;text-align:left}.ql-editor table{table-layout:fixed;width:100%}.ql-editor table td{outline:none}.ql-editor .ql-code-block-container{font-family:monospace}.ql-editor .ql-video{display:block;max-width:100%}.ql-editor .ql-video.ql-align-center{margin:0 auto}.ql-editor .ql-video.ql-align-right{margin:0 0 0 auto}.ql-editor .ql-bg-black{background-color:#000}.ql-editor .ql-bg-red{background-color:#e60000}.ql-editor .ql-bg-orange{background-color:#f90}.ql-editor .ql-bg-yellow{background-color:#ff0}.ql-editor .ql-bg-green{background-color:#008a00}.ql-editor .ql-bg-blue{background-color:#06c}.ql-editor .ql-bg-purple{background-color:#93f}.ql-editor .ql-color-white{color:#fff}.ql-editor .ql-color-red{color:#e60000}.ql-editor .ql-color-orange{color:#f90}.ql-editor .ql-color-yellow{color:#ff0}.ql-editor .ql-color-green{color:#008a00}.ql-editor .ql-color-blue{color:#06c}.ql-editor .ql-color-purple{color:#93f}.ql-editor .ql-font-serif{font-family:Georgia,Times New Roman,serif}.ql-editor .ql-font-monospace{font-family:Monaco,Courier New,monospace}.ql-editor .ql-size-small{font-size:.75em}.ql-editor .ql-size-large{font-size:1.5em}.ql-editor .ql-size-huge{font-size:2.5em}.ql-editor .ql-direction-rtl{direction:rtl;text-align:inherit}.ql-editor .ql-align-center{text-align:center}.ql-editor .ql-align-justify{text-align:justify}.ql-editor .ql-align-right{text-align:right}.ql-editor .ql-ui{position:absolute}.ql-editor.ql-blank:before{color:#0009;content:attr(data-placeholder);font-style:italic;left:15px;pointer-events:none;position:absolute;right:15px}.ql-snow.ql-toolbar:after,.ql-snow .ql-toolbar:after{clear:both;content:"";display:table}.ql-snow.ql-toolbar button,.ql-snow .ql-toolbar button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:28px}.ql-snow.ql-toolbar button svg,.ql-snow .ql-toolbar button svg{float:left;height:100%}.ql-snow.ql-toolbar button:active:hover,.ql-snow .ql-toolbar button:active:hover{outline:none}.ql-snow.ql-toolbar input.ql-image[type=file],.ql-snow .ql-toolbar input.ql-image[type=file]{display:none}.ql-snow.ql-toolbar button:hover,.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar button:focus,.ql-snow .ql-toolbar button:focus,.ql-snow.ql-toolbar button.ql-active,.ql-snow .ql-toolbar button.ql-active,.ql-snow.ql-toolbar .ql-picker-label:hover,.ql-snow .ql-toolbar .ql-picker-label:hover,.ql-snow.ql-toolbar .ql-picker-label.ql-active,.ql-snow .ql-toolbar .ql-picker-label.ql-active,.ql-snow.ql-toolbar .ql-picker-item:hover,.ql-snow .ql-toolbar .ql-picker-item:hover,.ql-snow.ql-toolbar .ql-picker-item.ql-selected,.ql-snow .ql-toolbar .ql-picker-item.ql-selected{color:#06c}.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow .ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button:focus .ql-fill,.ql-snow .ql-toolbar button:focus .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill{fill:#06c}.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow .ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button:focus .ql-stroke,.ql-snow .ql-toolbar button:focus .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-toolbar button.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow.ql-toolbar button:hover .ql-stroke-miter,.ql-snow .ql-toolbar button:hover .ql-stroke-miter,.ql-snow.ql-toolbar button:focus .ql-stroke-miter,.ql-snow .ql-toolbar button:focus .ql-stroke-miter,.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter{stroke:#06c}@media(pointer:coarse){.ql-snow.ql-toolbar button:hover:not(.ql-active),.ql-snow .ql-toolbar button:hover:not(.ql-active){color:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill{fill:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter{stroke:#444}}.ql-snow,.ql-snow *{box-sizing:border-box}.ql-snow .ql-hidden{display:none}.ql-snow .ql-out-bottom,.ql-snow .ql-out-top{visibility:hidden}.ql-snow .ql-tooltip{position:absolute;transform:translateY(10px)}.ql-snow .ql-tooltip a{cursor:pointer;text-decoration:none}.ql-snow .ql-tooltip.ql-flip{transform:translateY(-10px)}.ql-snow .ql-formats{display:inline-block;vertical-align:middle}.ql-snow .ql-formats:after{clear:both;content:"";display:table}.ql-snow .ql-stroke{fill:none;stroke:#444;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.ql-snow .ql-stroke-miter{fill:none;stroke:#444;stroke-miterlimit:10;stroke-width:2}.ql-snow .ql-fill,.ql-snow .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-empty{fill:none}.ql-snow .ql-even{fill-rule:evenodd}.ql-snow .ql-thin,.ql-snow .ql-stroke.ql-thin{stroke-width:1}.ql-snow .ql-transparent{opacity:.4}.ql-snow .ql-direction svg:last-child{display:none}.ql-snow .ql-direction.ql-active svg:last-child{display:inline}.ql-snow .ql-direction.ql-active svg:first-child{display:none}.ql-snow .ql-editor h1{font-size:2em}.ql-snow .ql-editor h2{font-size:1.5em}.ql-snow .ql-editor h3{font-size:1.17em}.ql-snow .ql-editor h4{font-size:1em}.ql-snow .ql-editor h5{font-size:.83em}.ql-snow .ql-editor h6{font-size:.67em}.ql-snow .ql-editor a{text-decoration:underline}.ql-snow .ql-editor blockquote{border-left:4px solid #ccc;margin-bottom:5px;margin-top:5px;padding-left:16px}.ql-snow .ql-editor code,.ql-snow .ql-editor .ql-code-block-container{background-color:#f0f0f0;border-radius:3px}.ql-snow .ql-editor .ql-code-block-container{margin-bottom:5px;margin-top:5px;padding:5px 10px}.ql-snow .ql-editor code{font-size:85%;padding:2px 4px}.ql-snow .ql-editor .ql-code-block-container{background-color:#23241f;color:#f8f8f2;overflow:visible}.ql-snow .ql-editor img{max-width:100%}.ql-snow .ql-picker{color:#444;display:inline-block;float:left;font-size:14px;font-weight:500;height:24px;position:relative;vertical-align:middle}.ql-snow .ql-picker-label{cursor:pointer;display:inline-block;height:100%;padding-left:8px;padding-right:2px;position:relative;width:100%}.ql-snow .ql-picker-label:before{display:inline-block;line-height:22px}.ql-snow .ql-picker-options{background-color:#fff;display:none;min-width:100%;padding:4px 8px;position:absolute;white-space:nowrap}.ql-snow .ql-picker-options .ql-picker-item{cursor:pointer;display:block;padding-bottom:5px;padding-top:5px}.ql-snow .ql-picker.ql-expanded .ql-picker-label{color:#ccc;z-index:2}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill{fill:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke{stroke:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-options{display:block;margin-top:-1px;top:100%;z-index:1}.ql-snow .ql-color-picker,.ql-snow .ql-icon-picker{width:28px}.ql-snow .ql-color-picker .ql-picker-label,.ql-snow .ql-icon-picker .ql-picker-label{padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-label svg,.ql-snow .ql-icon-picker .ql-picker-label svg{right:4px}.ql-snow .ql-icon-picker .ql-picker-options{padding:4px 0}.ql-snow .ql-icon-picker .ql-picker-item{height:24px;width:24px;padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-options{padding:3px 5px;width:152px}.ql-snow .ql-color-picker .ql-picker-item{border:1px solid transparent;float:left;height:16px;margin:2px;padding:0;width:16px}.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg{position:absolute;margin-top:-9px;right:0;top:50%;width:18px}.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=""]):before{content:attr(data-label)}.ql-snow .ql-picker.ql-header{width:98px}.ql-snow .ql-picker.ql-header .ql-picker-label:before,.ql-snow .ql-picker.ql-header .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{content:"Heading 1"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{content:"Heading 2"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{content:"Heading 3"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{content:"Heading 4"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{content:"Heading 5"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{content:"Heading 6"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{font-size:2em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{font-size:1.5em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{font-size:1.17em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{font-size:1em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{font-size:.83em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{font-size:.67em}.ql-snow .ql-picker.ql-font{width:108px}.ql-snow .ql-picker.ql-font .ql-picker-label:before,.ql-snow .ql-picker.ql-font .ql-picker-item:before{content:"Sans Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{content:"Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{content:"Monospace"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{font-family:Georgia,Times New Roman,serif}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{font-family:Monaco,Courier New,monospace}.ql-snow .ql-picker.ql-size{width:98px}.ql-snow .ql-picker.ql-size .ql-picker-label:before,.ql-snow .ql-picker.ql-size .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{content:"Small"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{content:"Large"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{content:"Huge"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{font-size:10px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{font-size:18px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{font-size:32px}.ql-snow .ql-color-picker.ql-background .ql-picker-item{background-color:#fff}.ql-snow .ql-color-picker.ql-color .ql-picker-item{background-color:#000}.ql-code-block-container{position:relative}.ql-code-block-container .ql-ui{right:5px;top:5px}.ql-toolbar.ql-snow{border:1px solid #ccc;box-sizing:border-box;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;padding:8px}.ql-toolbar.ql-snow .ql-formats{margin-right:15px}.ql-toolbar.ql-snow .ql-picker-label{border:1px solid transparent}.ql-toolbar.ql-snow .ql-picker-options{border:1px solid transparent;box-shadow:#0003 0 2px 8px}.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label,.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options{border-color:#ccc}.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover{border-color:#000}.ql-toolbar.ql-snow+.ql-container.ql-snow{border-top:0}.ql-snow .ql-tooltip{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 5px #ddd;color:#444;padding:5px 12px;white-space:nowrap}.ql-snow .ql-tooltip:before{content:"Visit URL:";line-height:26px;margin-right:8px}.ql-snow .ql-tooltip input[type=text]{display:none;border:1px solid #ccc;font-size:13px;height:26px;margin:0;padding:3px 5px;width:170px}.ql-snow .ql-tooltip a.ql-preview{display:inline-block;max-width:200px;overflow-x:hidden;text-overflow:ellipsis;vertical-align:top}.ql-snow .ql-tooltip a.ql-action:after{border-right:1px solid #ccc;content:"Edit";margin-left:16px;padding-right:8px}.ql-snow .ql-tooltip a.ql-remove:before{content:"Remove";margin-left:8px}.ql-snow .ql-tooltip a{line-height:26px}.ql-snow .ql-tooltip.ql-editing a.ql-preview,.ql-snow .ql-tooltip.ql-editing a.ql-remove{display:none}.ql-snow .ql-tooltip.ql-editing input[type=text]{display:inline-block}.ql-snow .ql-tooltip.ql-editing a.ql-action:after{border-right:0;content:"Save";padding-right:0}.ql-snow .ql-tooltip[data-mode=link]:before{content:"Enter link:"}.ql-snow .ql-tooltip[data-mode=formula]:before{content:"Enter formula:"}.ql-snow .ql-tooltip[data-mode=video]:before{content:"Enter video:"}.ql-snow a{color:#06c}.ql-container.ql-snow{border:1px solid #ccc}.new-story-page{min-height:100vh;background-color:var(--color-background);display:flex;flex-direction:column}.new-story-main{flex:1;display:flex;flex-direction:column}.new-story-header{background-color:var(--color-background-elevated);border-bottom:1px solid var(--color-border);padding:var(--space-8) 0}.new-story-header__content{display:flex;justify-content:space-between;align-items:center;gap:var(--space-8)}.new-story-header__left{display:flex;align-items:center;gap:var(--space-6)}.back-button{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:var(--radius-lg);background:var(--color-background-subtle);border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base)}.back-button:hover{background:var(--color-background-muted);border-color:var(--color-border-strong);color:var(--color-text-primary)}.back-button svg{width:20px;height:20px}.header-text{display:flex;flex-direction:column;gap:var(--space-1)}.header-text h1{font-size:28px;margin-bottom:0}.header-actions{display:flex;gap:var(--space-3)}.new-story-form-section{padding:var(--space-10) 0 var(--space-16)}.new-story-layout{display:grid;grid-template-columns:400px 1fr;gap:var(--space-8);align-items:flex-start}.story-basics-card{background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-6);position:sticky;top:calc(var(--navbar-height) + var(--space-6))}.section-title{font-size:16px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border-subtle)}.form-grid{display:flex;flex-direction:column;gap:var(--space-5)}.form-field{display:flex;flex-direction:column;gap:var(--space-2)}.select-input{width:100%;height:var(--input-height);padding:0 var(--input-padding-x);font-size:var(--input-font-size);font-weight:var(--font-weight-regular);color:var(--color-text-primary);background-color:var(--input-background);border:var(--border-width) solid var(--input-border-color);border-radius:var(--input-radius);cursor:pointer;transition:all var(--transition-base);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23757575' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}.select-input:hover{border-color:var(--color-border-strong)}.select-input:focus{outline:none;border-color:var(--input-border-color-focus);box-shadow:0 0 0 3px var(--color-focus-ring)}.cover-upload-section{display:flex;flex-direction:column;gap:var(--space-2)}.cover-upload-zone{position:relative;width:100%;height:180px;border:2px dashed var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);overflow:hidden}.cover-upload-zone:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.cover-upload-zone.has-image{border-style:solid;border-color:var(--color-border)}.cover-upload-zone.has-image:hover{border-color:var(--color-primary)}.cover-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:var(--space-2);color:var(--color-text-tertiary)}.cover-placeholder svg{width:32px;height:32px;opacity:.6}.cover-placeholder span{font-size:14px}.cover-preview{width:100%;height:100%;object-fit:cover}.hidden-file-input{position:absolute;opacity:0;pointer-events:none}.people-tags-section{display:flex;flex-direction:column;gap:var(--space-3)}.people-tags-section .input__label{display:flex;align-items:center;gap:var(--space-2)}.people-tags-section .input__label svg{width:16px;height:16px;color:var(--color-text-tertiary)}.people-chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.people-chips.compact{gap:var(--space-2)}.person-chip{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-background-subtle);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:13px;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base)}.person-chip:hover{background:var(--color-background-muted);border-color:var(--color-border-strong)}.person-chip.selected{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-inverse)}.person-chip.selected:hover{background:var(--color-primary-hover)}.person-chip.small{padding:6px 10px;font-size:12px}.chip-avatar{width:22px;height:22px;border-radius:50%;background:var(--color-background-elevated);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:var(--font-weight-bold);color:var(--color-text-secondary)}.person-chip.selected .chip-avatar{background:#fff3;color:var(--color-text-inverse)}.person-chip.small .chip-avatar{width:18px;height:18px;font-size:9px}.person-chip svg{width:14px;height:14px}.location-field{margin-top:var(--space-1)}.related-memories-section{display:flex;flex-direction:column;gap:var(--space-3)}.memory-select{width:100%;height:var(--input-height);padding:0 var(--input-padding-x);font-size:var(--input-font-size);color:var(--color-text-primary);background-color:var(--input-background);border:var(--border-width) solid var(--input-border-color);border-radius:var(--input-radius);cursor:pointer;transition:all var(--transition-base)}.memory-select:focus{outline:none;border-color:var(--input-border-color-focus);box-shadow:0 0 0 3px var(--color-focus-ring)}.related-memory-chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.related-memory-chip{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);background:var(--color-primary-light);border:1px solid var(--color-primary);border-radius:var(--radius-full);font-size:13px;color:var(--color-primary);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chip-remove{display:flex;align-items:center;justify-content:center;width:16px;height:16px;padding:0;border:none;background:transparent;color:var(--color-primary);cursor:pointer;flex-shrink:0;opacity:.7;transition:opacity var(--transition-base)}.chip-remove:hover{opacity:1}.chip-remove svg{width:12px;height:12px}.editor-section-card{background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-6);min-height:600px}.mode-toggle{display:flex;gap:var(--space-2);padding:var(--space-1);background:var(--color-background-subtle);border-radius:var(--radius-lg)}.mode-toggle-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:transparent;border:none;border-radius:var(--radius-md);font-size:15px;font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base)}.mode-toggle-btn:hover{color:var(--color-text-primary)}.mode-toggle-btn.active{background:var(--color-background-elevated);color:var(--color-primary);box-shadow:var(--shadow-sm)}.mode-toggle-btn svg{width:18px;height:18px}.write-mode{display:flex;flex-direction:column;flex:1;gap:var(--space-3)}.formatting-toolbar{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2);background:var(--color-background-subtle);border-radius:var(--radius-md)}.toolbar-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base)}.toolbar-btn:hover{background:var(--color-background-muted);color:var(--color-text-primary)}.toolbar-btn svg{width:18px;height:18px}.toolbar-divider{width:1px;height:20px;background:var(--color-border);margin:0 var(--space-2)}.story-textarea{flex:1;min-height:400px;padding:var(--space-5);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-family:var(--font-family);font-size:17px;line-height:1.75;color:var(--color-text-primary);resize:vertical;transition:all var(--transition-base)}.story-textarea::placeholder{color:var(--color-text-tertiary)}.story-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-focus-ring)}.story-textarea.has-error{border-color:var(--color-error)}.story-textarea.has-error:focus{box-shadow:0 0 0 3px #c5303033}.editor-error{font-size:13px;color:var(--color-error)}.editor-footer{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-3);border-top:1px solid var(--color-border-subtle)}.word-count{font-size:13px;color:var(--color-text-tertiary)}.autosave-status{display:flex;align-items:center;gap:var(--space-1);font-size:13px;color:var(--color-text-tertiary)}.autosave-status svg{width:14px;height:14px}.quick-actions{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4);background:var(--color-background-primary);border-radius:var(--radius-lg);margin-top:var(--space-2)}.quick-actions__label{font-size:13px;font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.quick-actions__buttons{display:flex;flex-wrap:wrap;gap:var(--space-2)}.quick-action-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:13px;font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base)}.quick-action-btn:hover:not(:disabled){background:var(--color-background-muted);border-color:var(--color-primary);color:var(--color-primary)}.quick-action-btn:disabled{opacity:.6;cursor:not-allowed}.quick-action-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-inverse)}.quick-action-btn svg{width:14px;height:14px}.refining-indicator{display:flex;align-items:center;gap:var(--space-2);font-size:13px;color:var(--color-primary)}.ai-mode{display:flex;flex-direction:column;flex:1}.ai-prompt-card{display:flex;flex-direction:column;gap:var(--space-5);padding:var(--space-6);background:linear-gradient(135deg,#f0f5f2,#e8f0eb);border:1px solid rgba(47,93,70,.15);border-radius:var(--radius-xl)}.ai-prompt-header{display:flex;align-items:center;gap:var(--space-3)}.ai-prompt-header svg{width:24px;height:24px;color:var(--color-primary)}.ai-prompt-header h3{margin:0;font-size:20px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.ai-prompt-description{margin:0;font-size:15px;color:var(--color-text-secondary);line-height:1.5}.ai-form{display:flex;flex-direction:column;gap:var(--space-5)}.ai-form .input__label{display:flex;align-items:center;gap:var(--space-2);font-size:14px;font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--space-2)}.ai-form .input__label svg,.form-field .input__label svg{width:16px;height:16px;color:var(--color-text-tertiary);flex-shrink:0}.tone-selector{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2)}.tone-btn{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4);background:var(--color-background-elevated);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base)}.tone-btn:hover{border-color:var(--color-border-strong)}.tone-btn.active{border-color:var(--color-primary);background:var(--color-primary-light)}.tone-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;color:var(--color-text-secondary)}.tone-icon svg{width:20px;height:20px}.tone-btn.active .tone-icon{color:var(--color-primary)}.tone-btn span:last-child{font-size:13px;font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.tone-btn.active span:last-child{color:var(--color-primary)}.ai-details-textarea{width:100%;min-height:100px;padding:var(--space-4);background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-family:var(--font-family);font-size:15px;line-height:1.6;color:var(--color-text-primary);resize:vertical;transition:all var(--transition-base)}.ai-details-textarea::placeholder{color:var(--color-text-tertiary)}.ai-details-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-focus-ring)}.spinner{width:16px;height:16px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .75s linear infinite}.quill-wrapper,.quill-wrapper .quill{flex:1;display:flex;flex-direction:column}.quill-wrapper .ql-toolbar.ql-snow{border:1px solid var(--color-border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:var(--color-background-subtle)}.quill-wrapper .ql-container.ql-snow{flex:1;border:1px solid var(--color-border);border-top:none;border-radius:0 0 var(--radius-lg) var(--radius-lg);font-family:var(--font-family);font-size:17px;min-height:400px}.quill-wrapper .ql-editor{line-height:1.75;color:var(--color-text-primary);padding:var(--space-5)}.quill-wrapper .ql-editor.ql-blank:before{color:var(--color-text-tertiary);font-style:normal}.quill-wrapper.has-error .ql-container.ql-snow,.quill-wrapper.has-error .ql-toolbar.ql-snow{border-color:var(--color-error)}@media(max-width:1024px){.new-story-layout{grid-template-columns:1fr}.story-basics-card{position:static}.tone-selector{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.new-story-header__content{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.header-actions{width:100%}.header-actions .button{flex:1}.new-story-header__left{flex-wrap:wrap}.header-text h1{font-size:24px}.editor-section-card{min-height:400px}.story-textarea{min-height:300px}.quick-actions__buttons{flex-direction:column}.quick-action-btn{justify-content:center}}.ai-wizard-page{min-height:100vh;background:linear-gradient(180deg,var(--color-background-warm) 0%,var(--color-background) 50%);display:flex;flex-direction:column}.ai-wizard-main{flex:1;padding:var(--space-10) 0 var(--space-16)}.ai-wizard-layout{display:grid;grid-template-columns:1fr 280px;gap:var(--space-8);max-width:1100px;margin:0 auto}.ai-wizard-card{background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:var(--space-10);position:relative;min-height:500px;display:flex;flex-direction:column}.wizard-top-actions{position:absolute;top:var(--space-6);right:var(--space-6);display:flex;align-items:center;gap:var(--space-3)}.save-exit-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-background-subtle);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:13px;font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base)}.save-exit-btn:hover{background:var(--color-background-muted);color:var(--color-text-primary);border-color:var(--color-border-strong)}.save-exit-btn svg{width:14px;height:14px}.cancel-exit-btn{display:inline-flex;align-items:center;padding:var(--space-2) var(--space-4);background:none;border:none;border-radius:var(--radius-full);font-size:13px;font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);cursor:pointer;transition:all var(--transition-base)}.cancel-exit-btn:hover{color:var(--color-error)}.ai-wizard-tips{position:sticky;top:calc(var(--navbar-height) + var(--space-6));height:fit-content}.tips-toggle{width:100%;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4);background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:14px;font-weight:var(--font-weight-medium);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-base)}.tips-toggle:hover{border-color:var(--color-border-strong)}.tips-toggle svg:first-child{color:var(--color-primary)}.tips-toggle svg{width:16px;height:16px}.tips-toggle span{flex:1;text-align:left}.tips-content{margin-top:var(--space-3);padding:var(--space-5);background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.tips-content ul{list-style:none;display:flex;flex-direction:column;gap:var(--space-3)}.tips-content li{font-size:14px;color:var(--color-text-secondary);line-height:1.5;padding-left:var(--space-5);position:relative}.tips-content li:before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;background:var(--color-primary);border-radius:50%}.wizard-intro{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-8)}.wizard-intro__icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0f5f2,#e8f0eb);border-radius:50%;margin-bottom:var(--space-6)}.wizard-intro__icon svg{width:40px;height:40px;color:var(--color-primary)}.wizard-intro h1{margin-bottom:var(--space-4)}.wizard-intro__text{max-width:480px;margin-bottom:var(--space-8)}.wizard-intro__actions{display:flex;flex-direction:column;gap:var(--space-3);width:100%;max-width:280px}.wizard-type-topics{display:flex;flex-direction:column;gap:var(--space-8)}.wizard-section{display:flex;flex-direction:column;gap:var(--space-3)}.wizard-section__label{font-size:16px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.wizard-section__hint{margin-bottom:var(--space-1)}.subject-toggle{display:flex;gap:0;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;width:fit-content;margin-bottom:var(--space-3)}.subject-toggle__btn{padding:var(--space-2) var(--space-5);border:none;background:var(--color-background-elevated);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all .15s ease}.subject-toggle__btn:not(:last-child){border-right:1px solid var(--color-border)}.subject-toggle__btn:hover:not(.active):not(:disabled){background:var(--color-background-subtle)}.subject-toggle__btn.active{background:var(--color-primary);color:var(--color-text-inverse)}.subject-toggle__btn:disabled{opacity:.45;cursor:not-allowed}.subject-dropdown{max-width:360px;margin-bottom:var(--space-2)}.subject-select__control{border-color:var(--color-border)!important;border-radius:var(--radius-md)!important;min-height:40px!important;box-shadow:none!important;font-size:var(--font-size-sm)}.subject-select__control--is-focused{border-color:var(--color-primary)!important;box-shadow:0 0 0 1px var(--color-primary)!important}.subject-select__option--is-selected{background-color:var(--color-primary)!important}.subject-select__option--is-focused{background-color:var(--color-primary-light)!important}.subject-select__placeholder{color:var(--color-text-tertiary)!important;font-size:var(--font-size-sm)}.subject-empty-hint{margin-top:var(--space-1);font-style:italic}.story-type-pills{display:flex;flex-wrap:wrap;gap:var(--space-2)}.type-pill{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:var(--color-background-subtle);border:2px solid transparent;border-radius:var(--radius-full);font-size:14px;font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base)}.type-pill:hover{background:var(--color-background-muted);color:var(--color-text-primary)}.type-pill.active{background:var(--color-primary);color:var(--color-text-inverse);border-color:var(--color-primary)}.type-pill svg{width:18px;height:18px}.topic-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-3)}.topic-card{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4);background:var(--color-background);border:2px solid var(--color-border);border-radius:var(--radius-lg);text-align:left;cursor:pointer;transition:all var(--transition-base)}.topic-card:hover{border-color:var(--color-border-strong);background:var(--color-background-subtle)}.topic-card.active{border-color:var(--color-primary);background:var(--color-primary-light)}.topic-card__header{display:flex;justify-content:space-between;align-items:center}.topic-card__label{font-size:15px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.topic-card__check{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:var(--color-primary);border-radius:50%;color:var(--color-text-inverse)}.topic-card__check svg{width:12px;height:12px}.topic-card__desc{font-size:13px;color:var(--color-text-tertiary);line-height:1.4}.topic-card.active .topic-card__label{color:var(--color-primary)}.estimated-time{display:flex;justify-content:center}.estimated-time__badge{display:inline-flex;padding:var(--space-2) var(--space-4);background:var(--color-background-primary);border-radius:var(--radius-full);font-size:13px;font-weight:var(--font-weight-medium);color:var(--color-primary)}.wizard-questions{display:flex;flex-direction:column;gap:var(--space-6);flex:1}.question-progress{display:flex;flex-direction:column;gap:var(--space-2)}.question-progress__text{font-size:13px;font-weight:var(--font-weight-medium);color:var(--color-text-tertiary)}.question-progress__bar{height:4px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden}.question-progress__fill{height:100%;background:var(--color-primary);border-radius:var(--radius-full);transition:width var(--transition-base)}.question-content{flex:1;display:flex;flex-direction:column;gap:var(--space-4)}.question-category{display:inline-flex;padding:var(--space-1) var(--space-3);background:var(--color-background-primary);border-radius:var(--radius-full);font-size:12px;font-weight:var(--font-weight-semibold);color:var(--color-primary);text-transform:uppercase;letter-spacing:.05em;width:fit-content}.question-title{font-size:24px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:1.3;margin:0}.answer-tabs{display:flex;gap:var(--space-1);padding:var(--space-1);background:var(--color-background-subtle);border-radius:var(--radius-md);width:fit-content}.answer-tab{padding:var(--space-2) var(--space-4);background:transparent;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base)}.answer-tab:hover{color:var(--color-text-primary)}.answer-tab.active{background:var(--color-background-elevated);color:var(--color-primary);box-shadow:var(--shadow-sm)}.answer-textarea{width:100%;min-height:160px;padding:var(--space-5);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-family:var(--font-family);font-size:16px;line-height:1.6;color:var(--color-text-primary);resize:vertical;transition:all var(--transition-base)}.answer-textarea::placeholder{color:var(--color-text-tertiary)}.answer-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-focus-ring)}.answer-textarea.bullets{font-family:var(--font-family)}.hint-toggle{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:13px;color:var(--color-text-tertiary);cursor:pointer;transition:all var(--transition-base);width:fit-content}.hint-toggle:hover{background:var(--color-background-subtle);color:var(--color-text-secondary)}.hint-toggle svg{width:14px;height:14px}.hint-toggle svg:first-child{color:var(--color-warning)}.hint-panel{padding:var(--space-5);background:linear-gradient(135deg,#fff9e6,#fffdf5);border:1px solid rgba(183,121,31,.2);border-radius:var(--radius-lg)}.hint-panel h4{font-size:14px;font-weight:var(--font-weight-semibold);color:var(--color-warning);margin:0 0 var(--space-2)}.hint-panel p{font-size:14px;color:var(--color-text-secondary);margin:0 0 var(--space-3)}.hint-panel ul{list-style:none;display:flex;flex-direction:column;gap:var(--space-2)}.hint-panel li{font-size:14px;color:var(--color-text-secondary);padding-left:var(--space-4);position:relative}.hint-panel li:before{content:"•";position:absolute;left:0;color:var(--color-warning)}.wizard-step-actions{display:flex;justify-content:space-between;gap:var(--space-4);padding-top:var(--space-6);border-top:1px solid var(--color-border-subtle);margin-top:auto}.wizard-generating{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-16)}.generating-spinner{width:48px;height:48px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:var(--space-6)}@keyframes spin{to{transform:rotate(360deg)}}.wizard-preview{display:flex;flex-direction:column;gap:var(--space-6)}.preview-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:linear-gradient(135deg,#f0f5f2,#e8f0eb);border:1px solid rgba(47,93,70,.2);border-radius:var(--radius-full);font-size:13px;font-weight:var(--font-weight-medium);color:var(--color-primary);width:fit-content}.preview-badge svg{width:14px;height:14px}.preview-field{display:flex;flex-direction:column;gap:var(--space-2)}.preview-field>label{font-size:13px;font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em}.preview-title{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-lg);transition:all var(--transition-base)}.preview-title.editable{cursor:pointer}.preview-title.editable:hover{background:var(--color-background-subtle)}.preview-title h2{font-size:28px;margin:0;flex:1}.preview-title svg{width:18px;height:18px;color:var(--color-text-tertiary);opacity:0;transition:opacity var(--transition-base)}.preview-title.editable:hover svg{opacity:1}.preview-title-input{width:100%;padding:var(--space-3);font-size:28px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);background:var(--color-background-subtle);border:2px solid var(--color-primary);border-radius:var(--radius-lg)}.preview-cover{position:relative;width:100%;height:200px;border-radius:var(--radius-xl);overflow:hidden;cursor:pointer;border:2px dashed var(--color-border)}.preview-cover img{width:100%;height:100%;object-fit:cover}.preview-cover .cover-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:var(--space-2);color:var(--color-text-tertiary)}.preview-cover .cover-placeholder svg{width:32px;height:32px}.cover-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);background:#00000080;color:#fff;opacity:0;transition:opacity var(--transition-base)}.preview-cover:hover .cover-overlay{opacity:1}.cover-overlay svg{width:24px;height:24px}.cover-picker-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--space-6)}.cover-picker{background:var(--color-background-elevated);border-radius:var(--radius-xl);max-width:600px;width:100%;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.cover-picker__header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border)}.cover-picker__header h3{font-size:18px;margin:0}.cover-picker__header button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--color-background-subtle);border:none;border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer}.cover-picker__header button svg{width:18px;height:18px}.cover-picker__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);padding:var(--space-6);overflow-y:auto}.cover-option{position:relative;aspect-ratio:16/10;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;border:3px solid transparent;transition:all var(--transition-base)}.cover-option:hover{border-color:var(--color-border-strong)}.cover-option.active{border-color:var(--color-primary)}.cover-option img{width:100%;height:100%;object-fit:cover}.cover-option__check{position:absolute;top:var(--space-2);right:var(--space-2);width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--color-primary);border-radius:50%;color:#fff}.cover-option__check svg{width:14px;height:14px}.preview-sections{display:flex;flex-direction:column;gap:var(--space-5)}.preview-section{display:flex;flex-direction:column;gap:var(--space-2)}.section-label{font-size:13px;font-weight:var(--font-weight-medium);color:var(--color-text-tertiary)}.section-textarea{width:100%;min-height:120px;padding:var(--space-4);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-family:var(--font-family);font-size:15px;line-height:1.7;color:var(--color-text-primary);resize:vertical;transition:all var(--transition-base)}.section-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-focus-ring)}.preview-metadata{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);padding:var(--space-5);background:var(--color-background-subtle);border-radius:var(--radius-lg)}.metadata-item{display:flex;flex-direction:column;gap:var(--space-2)}.metadata-label{font-size:12px;font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em}.metadata-value{font-size:14px;color:var(--color-text-primary)}.visibility-toggle{display:flex;gap:var(--space-2)}.visibility-btn{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:13px;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base)}.visibility-btn:hover{border-color:var(--color-border-strong)}.visibility-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-inverse)}.visibility-btn svg{width:14px;height:14px}.preview-actions{border-top:none;padding-top:0}.wizard-success{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-8)}.success-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#d4edda,#c3e6cb);border-radius:50%;margin-bottom:var(--space-6)}.success-icon svg{width:40px;height:40px;color:var(--color-success)}.wizard-success h1{margin-bottom:var(--space-4)}.success-text{max-width:400px;margin-bottom:var(--space-8)}.success-actions{display:flex;gap:var(--space-3)}@media(max-width:1024px){.ai-wizard-layout{grid-template-columns:1fr;max-width:700px}.ai-wizard-tips{position:static;order:-1}.tips-content{margin-top:0;border-top:none}.topic-cards{grid-template-columns:repeat(2,1fr)}.preview-metadata{grid-template-columns:1fr;gap:var(--space-3)}.cover-picker__grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.ai-wizard-card{padding:var(--space-6)}.save-exit-btn{top:var(--space-4);right:var(--space-4)}.wizard-intro{padding:var(--space-4)}.wizard-intro__icon{width:64px;height:64px}.wizard-intro__icon svg{width:32px;height:32px}.story-type-pills{gap:var(--space-2)}.type-pill{padding:var(--space-2) var(--space-4);font-size:13px}.type-pill svg{width:16px;height:16px}.topic-cards{grid-template-columns:1fr}.question-title{font-size:20px}.wizard-step-actions{flex-direction:column-reverse}.wizard-step-actions .button{width:100%}.preview-title h2,.preview-title-input{font-size:22px}.success-actions{flex-direction:column;width:100%}.success-actions .button{width:100%}}@media(max-width:480px){.ai-wizard-main{padding:var(--space-6) 0 var(--space-10)}.ai-wizard-card{padding:var(--space-5);border-radius:var(--radius-xl)}.answer-tabs{width:100%}.answer-tab{flex:1;text-align:center}.cover-picker__grid{grid-template-columns:repeat(2,1fr);padding:var(--space-4)}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4)}.modal-content{background:var(--color-background-elevated);border-radius:var(--radius-xl);padding:var(--space-8);max-width:400px;width:100%;box-shadow:var(--shadow-xl)}.modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-6)}.validation-modal{text-align:center;max-width:400px}.validation-modal__icon{width:56px;height:56px;margin:0 auto var(--space-4);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fff9e6,#fffdf5);border-radius:50%}.validation-modal__icon svg{width:28px;height:28px;color:var(--color-warning)}.validation-modal h3{margin-bottom:var(--space-6);font-size:18px}.validation-modal .modal-actions{justify-content:center}.confirmation-modal{text-align:center;max-width:420px}.confirmation-modal__icon{width:56px;height:56px;margin:0 auto var(--space-4);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0f5f2,#e8f0eb);border-radius:50%}.confirmation-modal__icon svg{width:28px;height:28px;color:var(--color-primary)}.confirmation-modal h3{margin-bottom:var(--space-3);font-size:18px}.confirmation-modal__text{margin-bottom:var(--space-6)}.confirmation-modal .modal-actions{justify-content:center}.modal-actions--stacked{flex-direction:column;align-items:stretch}.discard-btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-2) var(--space-4);background:none;border:none;font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-error);cursor:pointer;transition:all var(--transition-fast);opacity:.8}.discard-btn:hover{opacity:1;text-decoration:underline}.draft-prompt-modal{text-align:center;max-width:440px}.draft-prompt-modal__icon{width:56px;height:56px;margin:0 auto var(--space-4);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fff8e1,#fff3c4);border-radius:50%}.draft-prompt-modal__icon svg{width:28px;height:28px;color:#f59e0b}.draft-prompt-modal h3{margin-bottom:var(--space-3);font-size:18px}.draft-prompt-modal__text{margin-bottom:var(--space-6)}.draft-prompt-modal .modal-actions{justify-content:center}.accept-invite-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6);background:var(--color-background)}.accept-invite-card{width:100%;max-width:440px;background:var(--color-background-elevated);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden}.accept-invite-header{padding:var(--space-6) var(--space-6) var(--space-4);text-align:center}.accept-invite-logo{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.accept-invite-body{padding:0 var(--space-6) var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}.accept-invite-details{padding:var(--space-4);background:var(--color-background-subtle);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:var(--space-3)}.accept-invite-detail-row{display:flex;justify-content:space-between;align-items:center}.accept-invite-actions{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-2)}.accept-invite-expiry{text-align:center}.accept-invite-loading{padding:var(--space-8);text-align:center}.accept-invite-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);z-index:600;animation:accept-invite-toast-in .3s ease}.accept-invite-toast--error{border-left:3px solid var(--color-error);background:#fee2e2;color:#991b1b}.accept-invite-toast--success{border-left:3px solid var(--color-success);background:#d1fae5;color:#065f46}@keyframes accept-invite-toast-in{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.shared-tree-page{min-height:100vh;display:flex;flex-direction:column;background:var(--color-background, #f9f7f4)}.shared-tree-page__header{position:fixed;top:var(--navbar-height, 64px);left:0;right:0;z-index:10;display:flex;align-items:center;gap:12px;padding:10px 24px;background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--color-border, #e5e1dc)}.shared-tree-page__title{font-size:18px;font-weight:600;color:var(--color-text-primary, #1a1a1a);margin:0}.shared-tree-page__badge{display:inline-flex;align-items:center;padding:3px 10px;font-size:11px;font-weight:500;border-radius:12px;background:var(--color-background-subtle, #f0ece6);color:var(--color-text-secondary, #666)}.shared-tree-page__canvas{position:fixed;top:calc(var(--navbar-height, 64px) + 44px);left:0;right:0;bottom:0;overflow:hidden}.shared-tree-page__status{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 24px;text-align:center;color:var(--color-text-secondary, #666)}.shared-tree-page__status h2{font-size:20px;font-weight:600;color:var(--color-text-primary, #1a1a1a);margin:0}.shared-tree-page__status p{font-size:14px;margin:0;max-width:400px}.shared-tree-page__error-icon{color:var(--color-text-tertiary, #999);margin-bottom:8px}.shared-tree-page__home-btn{margin-top:12px;padding:10px 24px;font-size:14px;font-weight:500;border:none;border-radius:8px;background:var(--color-primary, #2F5D46);color:#fff;cursor:pointer;transition:background .15s}.shared-tree-page__home-btn:hover{background:var(--color-primary-hover, #264d3a)}.shared-tree-page__spinner{width:32px;height:32px;border:3px solid var(--color-border, #e5e1dc);border-top-color:var(--color-primary, #2F5D46);border-radius:50%;animation:shared-tree-spin .7s linear infinite}@keyframes shared-tree-spin{to{transform:rotate(360deg)}}.sfp--desktop{display:none}@media(min-width:1025px){.sfp--desktop{display:block;width:280px;flex-shrink:0;position:sticky;top:calc(var(--navbar-height) + 80px);align-self:flex-start;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 8px #0000000f;overflow:hidden}}.sfp--mobile{position:fixed;top:0;left:0;bottom:0;width:300px;max-width:90vw;background:#fff;z-index:500;overflow-y:auto;box-shadow:4px 0 24px #0000001f;transform:translate(-100%);transition:transform .28s ease}.sfp--mobile-open{transform:translate(0)}.sfp__backdrop{position:fixed;inset:0;background:#0006;z-index:499;animation:sfpBackdropIn .2s ease forwards}@keyframes sfpBackdropIn{0%{opacity:0}to{opacity:1}}.sfp__mobile-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid #f3f4f6}.sfp__mobile-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:none;border:none;border-radius:50%;cursor:pointer;color:#6b7280;padding:0;transition:background .15s ease,color .15s ease}.sfp__mobile-close:hover{background:#f3f4f6;color:#1a1a1a}.sfp__mobile-close:focus-visible{outline:2px solid #45b35b;outline-offset:2px}.sfp__content{display:flex;flex-direction:column}.sfp__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid #f3f4f6}.sfp--mobile .sfp__header{display:none}.sfp__header-title{font-size:15px;font-weight:600;color:#1a1a1a}.sfp__clear-all{font-size:13px;font-weight:500;color:#6b7280;background:none;border:none;cursor:pointer;padding:2px 4px;border-radius:4px;transition:color .15s ease;text-decoration:underline;text-underline-offset:2px}.sfp__clear-all:hover{color:#dc2626}.sfp__clear-all:focus-visible{outline:2px solid #45b35b;outline-offset:2px}.sfp__section{padding:14px 20px}.sfp__section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#9ca3af;margin:0 0 10px}.sfp__divider{height:1px;background:#f3f4f6;margin:0}.sfp__type-tabs{display:flex;gap:4px;background:#f3f4f6;border-radius:20px;padding:3px}.sfp__type-tab{flex:1;height:32px;background:none;border:none;border-radius:18px;font-family:inherit;font-size:12px;font-weight:500;color:#6b7280;cursor:pointer;transition:background .15s ease,color .15s ease,box-shadow .15s ease}.sfp__type-tab--active{background:#fff;color:#2f7a3c;box-shadow:0 1px 3px #00000014}.sfp__type-tab:hover:not(.sfp__type-tab--active){color:#1a1a1a}.sfp__type-tab:focus-visible{outline:2px solid #45b35b;outline-offset:1px}.sfp__toggle-label{display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;user-select:none}.sfp__toggle-text{font-size:14px;color:#1a1a1a}.sfp__toggle{position:relative;width:40px;height:22px;background:#d1d5db;border:none;border-radius:11px;cursor:pointer;padding:0;transition:background .2s ease;flex-shrink:0}.sfp__toggle--on{background:#45b35b}.sfp__toggle:focus-visible{outline:2px solid #45b35b;outline-offset:2px}.sfp__toggle-thumb{position:absolute;top:3px;left:3px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .2s ease;box-shadow:0 1px 3px #00000026;pointer-events:none}.sfp__toggle--on .sfp__toggle-thumb{transform:translate(18px)}.sfp__radio-group{display:flex;flex-direction:column;gap:8px}.sfp__radio-label{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.sfp__radio-input{position:absolute;opacity:0;width:0;height:0}.sfp__radio-custom{width:18px;height:18px;border:2px solid #d1d5db;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .15s ease}.sfp__radio-custom:after{content:"";width:8px;height:8px;border-radius:50%;background:#45b35b;opacity:0;transition:opacity .15s ease}.sfp__radio-input:checked+.sfp__radio-custom{border-color:#45b35b}.sfp__radio-input:checked+.sfp__radio-custom:after{opacity:1}.sfp__radio-input:focus-visible+.sfp__radio-custom{outline:2px solid #45b35b;outline-offset:2px}.sfp__radio-text{font-size:14px;color:#1a1a1a}.sfp__year-range{display:flex;align-items:center;gap:8px}.sfp__year-input{width:80px;height:36px;padding:0 10px;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:8px;font-family:inherit;font-size:13px;color:#1a1a1a;outline:none;transition:border-color .15s ease,box-shadow .15s ease;-moz-appearance:textfield}.sfp__year-input::-webkit-outer-spin-button,.sfp__year-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.sfp__year-input:focus{border-color:#45b35b;box-shadow:0 0 0 3px #45b35b1f;background:#fff}.sfp__year-sep{color:#9ca3af;font-size:14px}.sfp__text-input{width:100%;height:38px;padding:0 12px;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:8px;font-family:inherit;font-size:13px;color:#1a1a1a;outline:none;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease;box-sizing:border-box}.sfp__text-input::placeholder{color:#9ca3af}.sfp__text-input:focus{border-color:#45b35b;box-shadow:0 0 0 3px #45b35b1f;background:#fff}.src{display:flex;align-items:flex-start;gap:16px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;transition:transform .18s ease,box-shadow .18s ease;cursor:default}.src:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.src__avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:600;color:#fff}.src__avatar--lg{width:56px;height:56px;font-size:18px}.src__avatar--male{background:#1d2842}.src__avatar--female{background:#d4869e}.src__avatar--unknown{background:#9ca3af}.src__avatar--family{background:linear-gradient(135deg,#45b35b,#2f7a3c);color:#fff}.src__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.src__name{font-size:17px;font-weight:700;color:#1a1a1a;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.src__life-years{font-size:13px;color:#6b7280;margin:0}.src__location{display:flex;align-items:center;gap:5px;font-size:13px;color:#6b7280;margin:0}.src__icon{flex-shrink:0;color:#9ca3af}.src__badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}.src__badge{display:inline-flex;align-items:center;height:22px;padding:0 8px;border-radius:11px;font-size:11px;font-weight:500;white-space:nowrap}.src__badge--family{background:#eef7ef;color:#2f7a3c}.src__badge--hints{background:#fef3c7;color:#b45309}.src__badge--tag{background:#f3f4f6;color:#4b5563}.src__stats-row{display:flex;flex-wrap:wrap;gap:4px 12px;margin-top:2px}.src__stat{font-size:13px;color:#6b7280}.src__stat+.src__stat:before{content:"•";margin-right:12px;color:#d1d5db}.src__actions{display:flex;flex-direction:column;gap:8px;flex-shrink:0;min-width:110px;align-items:stretch}.src__btn{height:34px;padding:0 14px;border-radius:8px;font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease;white-space:nowrap}.src__btn--outline{background:#fff;border:1.5px solid #45b35b;color:#45b35b}.src__btn--outline:hover{background:#eef7ef;border-color:#2f7a3c;color:#2f7a3c}.src__btn--ghost{background:none;border:none;color:#45b35b;padding:0;height:auto;text-decoration:underline;text-underline-offset:2px;font-size:13px;font-weight:500}.src__btn--ghost:hover{color:#2f7a3c}.src__btn:focus-visible{outline:2px solid #45b35b;outline-offset:2px}@media(max-width:640px){.src{flex-wrap:wrap}.src__actions{flex-direction:row;min-width:0;width:100%;margin-top:4px}.src__btn--outline{flex:1}}.srl{display:flex;flex-direction:column;gap:12px;flex:1;min-width:0}.srl__count{font-size:14px;color:#6b7280;margin:0 0 4px}.srl__count strong{color:#1a1a1a;font-weight:600}.srl__list{display:flex;flex-direction:column;gap:12px}.srl__empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:64px 24px;gap:16px}.srl__empty-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;background:#f9fafb;border-radius:50%}.srl__empty-heading{font-size:16px;font-weight:500;color:#1a1a1a;margin:0;max-width:320px}.srl__empty-heading strong{font-weight:700}.srl__empty-tips{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.srl__empty-tips li{font-size:14px;color:#6b7280;position:relative;padding-left:16px}.srl__empty-tips li:before{content:"–";position:absolute;left:0;color:#d1d5db}@keyframes srlPulse{0%,to{opacity:1}50%{opacity:.45}}.srl__skeleton{display:flex;align-items:flex-start;gap:16px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;animation:srlPulse 1.6s ease-in-out infinite}.srl__skeleton-avatar{width:56px;height:56px;border-radius:50%;background:#e5e7eb;flex-shrink:0}.srl__skeleton-body{flex:1;display:flex;flex-direction:column;gap:8px;padding-top:4px}.srl__skeleton-line{height:12px;border-radius:6px;background:#e5e7eb}.srl__skeleton-line--title{width:55%;height:16px}.srl__skeleton-line--sub{width:40%}.srl__skeleton-line--narrow{width:28%}.srl__skeleton-actions{display:flex;flex-direction:column;gap:8px;flex-shrink:0;min-width:100px}.srl__skeleton-btn{height:34px;border-radius:8px;background:#e5e7eb}.srl__skeleton-btn--ghost{height:14px;width:70%;border-radius:7px;background:#f3f4f6;align-self:center}.afc{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.afc__chip{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 10px 0 12px;background:#eef7ef;border:1px solid #c3e8ca;border-radius:20px;font-size:13px;font-weight:500;color:#2f7a3c;white-space:nowrap}.afc__chip-label{line-height:1}.afc__chip-remove{display:flex;align-items:center;justify-content:center;width:18px;height:18px;background:none;border:none;border-radius:50%;cursor:pointer;padding:0;color:#45b35b;flex-shrink:0;transition:background .12s ease,color .12s ease}.afc__chip-remove:hover{background:#c3e8ca;color:#1d6b2a}.afc__chip-remove:focus-visible{outline:2px solid #45b35b;outline-offset:1px}.afc__clear-all{height:30px;padding:0 10px;background:none;border:none;font-family:inherit;font-size:13px;font-weight:500;color:#9ca3af;cursor:pointer;border-radius:20px;transition:color .15s ease,background .15s ease;text-decoration:underline;text-underline-offset:2px}.afc__clear-all:hover{color:#dc2626;background:#dc26260f}.afc__clear-all:focus-visible{outline:2px solid #45b35b;outline-offset:2px}.ppp__backdrop{position:fixed;inset:0;background:#0006;z-index:990;opacity:0;pointer-events:none;transition:opacity .28s ease}.ppp__backdrop--visible{opacity:1;pointer-events:auto}.ppp{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:100vw;background:#fff;z-index:1000;box-shadow:-4px 0 32px #0000001f;transform:translate(100%);transition:transform .3s ease;display:flex;flex-direction:column}.ppp--open{transform:translate(0)}@media(max-width:480px){.ppp{width:100%}}.ppp__close{position:absolute;top:16px;right:16px;display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#f3f4f6;border:none;border-radius:50%;cursor:pointer;color:#6b7280;z-index:1;transition:background .15s ease,color .15s ease}.ppp__close:hover{background:#e5e7eb;color:#1a1a1a}.ppp__close:focus-visible{outline:2px solid #45b35b;outline-offset:2px}.ppp__scroll{flex:1;overflow-y:auto;padding:28px 24px 32px;scrollbar-width:thin;scrollbar-color:#d1d5db transparent}.ppp__scroll::-webkit-scrollbar{width:5px}.ppp__scroll::-webkit-scrollbar-track{background:transparent}.ppp__scroll::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.ppp__header{display:flex;align-items:center;gap:16px;padding-top:8px;padding-right:40px}.ppp__header-info{flex:1;min-width:0}.ppp__avatar{width:80px;height:80px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:700;color:#fff}.ppp__avatar--male{background:#1d2842}.ppp__avatar--female{background:#d4869e}.ppp__avatar--unknown{background:#9ca3af}.ppp__avatar--family{background:linear-gradient(135deg,#45b35b,#2f7a3c)}.ppp__name{font-size:20px;font-weight:700;color:#1a1a1a;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ppp__life-years{font-size:14px;color:#6b7280;margin:4px 0 0}.ppp__origin{display:flex;align-items:center;gap:5px;font-size:14px;color:#6b7280;margin:4px 0 0}.ppp__divider{height:1px;background:#f3f4f6;margin:20px 0}.ppp__info-section{display:flex;flex-direction:column;gap:14px}.ppp__info-row{display:flex;align-items:flex-start;gap:8px}.ppp__info-label{width:80px;flex-shrink:0;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#9ca3af;padding-top:2px}.ppp__info-value{flex:1;font-size:14px;color:#1a1a1a;display:flex;align-items:flex-start;gap:5px}.ppp__info-icon{flex-shrink:0;color:#9ca3af;margin-top:1px}.ppp__tags{display:flex;flex-wrap:wrap;gap:6px}.ppp__tag{display:inline-flex;align-items:center;height:22px;padding:0 8px;background:#f3f4f6;border-radius:11px;font-size:11px;font-weight:500;color:#4b5563}.ppp__stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.ppp__stat-box{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:16px 12px;background:#f9fafb;border:1px solid #f3f4f6;border-radius:10px;text-align:center}.ppp__stat-value{font-size:22px;font-weight:700;color:#1a1a1a;line-height:1}.ppp__stat-label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:#9ca3af}.ppp__ctas{display:flex;flex-direction:column;gap:10px}.ppp__btn{width:100%;height:44px;border-radius:10px;font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.ppp__btn--primary{background:#45b35b;border:none;color:#fff}.ppp__btn--primary:hover{background:#2f7a3c}.ppp__btn--outline{background:#fff;border:1.5px solid #45b35b;color:#45b35b}.ppp__btn--outline:hover{background:#eef7ef;border-color:#2f7a3c;color:#2f7a3c}.ppp__btn--ghost{background:none;border:none;color:#6b7280;font-weight:500;text-decoration:underline;text-underline-offset:3px;height:auto;padding:4px 0}.ppp__btn--ghost:hover{color:#1a1a1a}.ppp__btn:focus-visible{outline:2px solid #45b35b;outline-offset:2px}.polm{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 24px}.polm__count{font-size:14px;color:#6b7280;margin:0;text-align:center}.polm__count strong{color:#1a1a1a;font-weight:600}.polm__btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:44px;padding:0 32px;background:#fff;border:1.5px solid #45b35b;border-radius:22px;font-family:inherit;font-size:14px;font-weight:600;color:#45b35b;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease,opacity .15s ease;white-space:nowrap;min-width:140px}.polm__btn:hover:not(:disabled){background:#eef7ef;border-color:#2f7a3c;color:#2f7a3c}.polm__btn:disabled,.polm__btn--loading{opacity:.7;cursor:not-allowed}.polm__btn:focus-visible{outline:2px solid #45b35b;outline-offset:3px}@keyframes polmSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.polm__spinner{animation:polmSpin .8s linear infinite;color:currentColor;flex-shrink:0}.polm__end{font-size:13px;color:#9ca3af;margin:0;text-align:center}.search-page{min-height:100vh;background:#f5f3f0;display:flex;flex-direction:column}.search-page__header{position:sticky;top:var(--navbar-height);z-index:50;background:var(--color-background-elevated);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);padding:var(--space-4) 0}.search-page__header-inner{max-width:var(--container-max-width);margin:0 auto;padding:0 var(--container-padding-x);display:flex;align-items:center;gap:var(--space-4)}.search-page__input-wrap{flex:1;position:relative;display:flex;align-items:center}.search-page__input-icon{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%);color:var(--color-text-tertiary);pointer-events:none;display:flex;align-items:center}.search-page__input{width:100%;height:48px;padding:0 var(--space-12) 0 var(--space-12);font-size:var(--font-size-body);font-family:var(--font-family);color:var(--color-text-primary);background:var(--color-background-subtle);border:1px solid var(--color-border);border-radius:var(--radius-full);outline:none;transition:border-color var(--transition-base),box-shadow var(--transition-base);-webkit-appearance:none;appearance:none}.search-page__input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-focus-ring);background:var(--color-background-elevated)}.search-page__input::placeholder{color:var(--color-text-tertiary)}.search-page__input::-webkit-search-cancel-button{display:none}.search-page__input-clear{position:absolute;right:var(--space-4);top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:none;border:none;cursor:pointer;color:var(--color-text-tertiary);border-radius:50%;padding:0;transition:color var(--transition-fast),background-color var(--transition-fast)}.search-page__input-clear:hover{color:var(--color-text-primary);background:var(--color-background-muted)}.search-page__body{flex:1;max-width:var(--container-max-width);width:100%;margin:0 auto;padding:var(--space-8) var(--container-padding-x) var(--space-16);display:grid;grid-template-columns:280px 1fr;gap:var(--space-8);align-items:start}.search-page__main{min-width:0}.search-page__filter-toggle{display:none;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--font-size-small);font-weight:var(--font-weight-medium);font-family:var(--font-family);color:var(--color-text-secondary);background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;white-space:nowrap}.search-page__filter-toggle:hover{color:var(--color-primary);border-color:var(--color-primary);background:var(--color-primary-light)}.search-page__filter-toggle-badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;font-size:11px;font-weight:var(--font-weight-semibold);color:var(--color-text-inverse);background:var(--color-primary);border-radius:50%;margin-left:var(--space-1)}.search-page__active-filters{margin-bottom:var(--space-4)}@media(max-width:1024px){.search-page__body{grid-template-columns:1fr}.search-page__filter-toggle{display:flex}}@media(max-width:768px){.search-page__body{padding:var(--space-6) var(--space-4) var(--space-12);gap:var(--space-4)}.search-page__header-inner{padding:0 var(--space-4);gap:var(--space-2)}.search-page__input{font-size:16px}}.search-page__coming-soon{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 24px 120px;max-width:480px;margin:0 auto}.search-page__coming-soon-icon{width:96px;height:96px;border-radius:50%;background:#edf7ef;display:flex;align-items:center;justify-content:center;margin-bottom:24px}.search-page__coming-soon-title{font-size:28px;font-weight:700;color:var(--color-text-primary);margin:0 0 12px}.search-page__coming-soon-text{font-size:16px;color:var(--color-text-secondary);line-height:1.6;margin:0 0 32px}.search-page__coming-soon-btn{display:inline-flex;align-items:center;padding:12px 28px;background:#2e7a3c;color:#fff;font-size:14px;font-weight:600;border-radius:var(--radius-lg);text-decoration:none;transition:background-color .2s ease}.search-page__coming-soon-btn:hover{background:#256832}.cookie-consent{position:fixed;bottom:0;left:0;right:0;z-index:var(--z-toast);background-color:var(--color-background-elevated);box-shadow:0 -4px 24px #0000001a;border-top:1px solid var(--color-border)}.cookie-consent__inner{max-width:1200px;margin:0 auto;padding:20px 24px;display:flex;align-items:center;gap:24px;flex-wrap:wrap}.cookie-consent__text{flex:1;min-width:280px;font-size:var(--font-size-small);line-height:var(--line-height-body);color:var(--color-text-secondary);display:flex;align-items:flex-start;gap:8px}.cookie-consent__icon{display:inline-flex;align-items:center;flex-shrink:0;margin-top:2px;color:var(--color-primary)}.cookie-consent__text a{color:var(--color-primary-text);text-decoration:underline;text-underline-offset:2px}.cookie-consent__text a:hover{color:var(--color-primary)}.cookie-consent__text a:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px;border-radius:2px}.cookie-consent__actions{display:flex;align-items:center;gap:12px;flex-shrink:0}.cookie-consent__btn-primary{padding:10px 20px;background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);font-size:var(--font-size-small);font-family:var(--font-family);cursor:pointer;transition:background-color var(--transition-base),transform var(--transition-base),box-shadow var(--transition-base);white-space:nowrap;line-height:1.4}.cookie-consent__btn-primary:hover{background-color:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.3)}.cookie-consent__btn-primary:active{transform:translateY(0);background-color:var(--color-primary-active)}.cookie-consent__btn-primary:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.cookie-consent__btn-secondary{padding:10px 20px;background-color:transparent;border:1px solid var(--color-border-strong);border-radius:var(--radius-md);font-weight:var(--font-weight-medium);font-size:var(--font-size-small);font-family:var(--font-family);color:var(--color-text-primary);cursor:pointer;transition:background-color var(--transition-base),border-color var(--transition-base),transform var(--transition-base);white-space:nowrap;line-height:1.4}.cookie-consent__btn-secondary:hover{background-color:var(--color-background-subtle);border-color:var(--color-text-tertiary)}.cookie-consent__btn-secondary:active{transform:translateY(0)}.cookie-consent__btn-secondary:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.cookie-consent__btn-link{background:none;border:none;padding:4px 2px;color:var(--color-primary-text);font-size:var(--font-size-small);font-family:var(--font-family);font-weight:var(--font-weight-medium);cursor:pointer;text-decoration:underline;text-underline-offset:2px;white-space:nowrap;transition:color var(--transition-base)}.cookie-consent__btn-link:hover{color:var(--color-primary)}.cookie-consent__btn-link:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px;border-radius:2px}.cookie-consent__preferences{width:100%;padding-top:20px;border-top:1px solid var(--color-border);margin-top:8px;overflow:hidden}.cookie-consent__preferences-intro{font-size:var(--font-size-small);line-height:var(--line-height-body);color:var(--color-text-secondary);margin:0 0 16px}.cookie-consent__toggle-row{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--color-border-subtle);gap:16px}.cookie-consent__toggle-row:last-of-type{border-bottom:none}.cookie-consent__toggle-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.cookie-consent__toggle-label{display:flex;align-items:center;gap:8px;font-size:var(--font-size-small);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.cookie-consent__always-on{font-size:11px;font-weight:var(--font-weight-regular);color:var(--color-primary-text);background-color:var(--color-background-primary);padding:2px 7px;border-radius:var(--radius-full);white-space:nowrap}.cookie-consent__toggle-desc{font-size:12px;line-height:1.5;color:var(--color-text-tertiary)}.cookie-consent__toggle{position:relative;display:inline-flex;align-items:center;width:44px;height:24px;border-radius:12px;border:none;padding:0;cursor:pointer;background-color:var(--color-border);transition:background-color .2s ease;flex-shrink:0}.cookie-consent__toggle--on{background-color:var(--color-primary)}.cookie-consent__toggle--disabled{opacity:.5;cursor:not-allowed}.cookie-consent__toggle:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.cookie-consent__toggle-thumb{position:absolute;left:3px;top:3px;width:18px;height:18px;border-radius:50%;background-color:#fff;box-shadow:0 1px 3px #00000026;transition:left .2s ease}.cookie-consent__toggle--on .cookie-consent__toggle-thumb{left:23px}.cookie-consent__preferences-footer{display:flex;align-items:center;gap:12px;padding-top:20px;flex-wrap:wrap}@media(max-width:640px){.cookie-consent__inner{flex-direction:column;align-items:stretch;gap:16px;padding:16px}.cookie-consent__text{min-width:unset}.cookie-consent__actions{flex-direction:column;width:100%;gap:8px}.cookie-consent__btn-primary,.cookie-consent__btn-secondary{width:100%;text-align:center;justify-content:center}.cookie-consent__btn-link{text-align:center;width:100%;padding:8px 2px}.cookie-consent__preferences-footer{flex-direction:column;gap:8px}.cookie-consent__preferences-footer .cookie-consent__btn-primary,.cookie-consent__preferences-footer .cookie-consent__btn-secondary{width:100%}.cookie-consent__toggle-row{padding:12px 0}}.help-page{min-height:100vh;background-color:#f4f6f5}.help-section-heading{font-size:26px;font-weight:700;color:#1a1a1a;margin-bottom:32px;text-align:center}.help-hero{padding:80px 0 56px;background:#f6f1e8;text-align:center}.help-hero__title{font-size:42px;font-weight:700;color:#1a1a1a;margin-bottom:12px;line-height:1.15}.help-hero__subtitle{font-size:18px;color:#5a5a5a;margin-bottom:36px;max-width:480px;margin-left:auto;margin-right:auto;line-height:1.6}.help-hero__search{max-width:540px;margin:0 auto;position:relative}.help-hero__search-icon{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:#999;pointer-events:none;display:flex;align-items:center;z-index:2}.help-hero__search input{width:100%;padding:16px 20px 16px 50px;border:1px solid #e0dcd6;border-radius:16px;font-size:16px;background:#fff;color:#1a1a1a;box-shadow:0 2px 12px #0000000f;transition:border-color .2s,box-shadow .2s;box-sizing:border-box;font-family:inherit;outline:none}.help-hero__search input:focus{border-color:#2e7a3c;box-shadow:0 2px 12px #2e7a3c1a}.help-hero__search input::placeholder{color:#aaa}.help-hero__suggestions{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border-radius:14px;box-shadow:0 6px 24px #0000001a;list-style:none;padding:8px 0;margin:0;z-index:10;overflow:hidden}.help-hero__suggestions li button{display:flex;align-items:center;gap:12px;width:100%;padding:12px 18px;background:none;border:none;cursor:pointer;font-size:14px;color:#444;text-align:left;font-family:inherit;transition:background .15s}.help-hero__suggestions li button:hover{background:#f6f1e8}.help-hero__suggestions li button svg{color:#999;flex-shrink:0}.help-hero__quick-links{display:flex;justify-content:center;flex-wrap:wrap;gap:8px 16px;margin-top:28px}.help-hero__quick-link{font-size:13px;font-weight:500;color:#2e7a3c;text-decoration:none;padding:6px 14px;border-radius:20px;background:#2e7a3c14;transition:background .2s,color .2s}.help-hero__quick-link:hover{background:#2e7a3c26;color:#236b30}.help-topics{padding:100px 0;background:#f4f6f5}.help-topics__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.help-topic-card{background:#fff;border-radius:18px;padding:24px;border:none;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease;text-decoration:none;display:flex;align-items:flex-start;gap:16px;box-shadow:0 1px 4px #0000000a}.help-topic-card:hover{transform:translateY(-3px);box-shadow:0 8px 28px #00000014;background:#e8f3ec}.help-topic-card__icon{color:#2e7a3c;flex-shrink:0;margin-top:2px}.help-topic-card__text{min-width:0}.help-topic-card__title{font-size:15px;font-weight:600;color:#1a1a1a;margin-bottom:4px}.help-topic-card__description{font-size:13px;color:#777;line-height:1.5}.help-faq{padding:100px 0;background:#f6f1e8}.help-faq__list{max-width:720px;margin:0 auto}.help-faq__item{border-bottom:1px solid #e0dcd6}.help-faq__question{display:flex;justify-content:space-between;align-items:center;width:100%;padding:22px 0;background:none;border:none;cursor:pointer;font-size:16px;font-weight:500;color:#1a1a1a;text-align:left;gap:16px;font-family:inherit;transition:color .2s}.help-faq__question:hover,.help-faq__item--open .help-faq__question{color:#2e7a3c}.help-faq__chevron{flex-shrink:0;color:#999;transition:transform .22s ease,color .22s ease}.help-faq__item--open .help-faq__chevron{color:#2e7a3c}.help-faq__answer{padding:0 0 22px 16px;font-size:15px;line-height:1.75;color:#5a5a5a;margin:0}.help-journey{padding:100px 0;background:#f6f1e8}.help-journey__subtext{font-size:16px;color:#5a5a5a;text-align:center;max-width:480px;margin:-16px auto 48px;line-height:1.6}.help-journey__steps{display:flex;justify-content:center;align-items:flex-start;max-width:1100px;margin:0 auto}.help-journey__step-wrapper{display:flex;align-items:center;flex:1;max-width:320px}.help-journey__card{display:flex;flex-direction:column;align-items:center;text-align:center;background:#fff;padding:36px 28px 32px;border-radius:20px;text-decoration:none;position:relative;flex:1;gap:10px;box-shadow:0 2px 12px #0000000f;transition:transform .2s ease,box-shadow .2s ease}.help-journey__card:hover{transform:translateY(-4px);box-shadow:0 8px 28px #0000001a}.help-journey__step-number{position:absolute;top:-14px;left:-14px;width:34px;height:34px;border-radius:50%;background:#2e7a3c;color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #2e7a3c40}.help-journey__card-icon{color:#2e7a3c;margin-bottom:4px}.help-journey__card-title{font-size:16px;font-weight:600;color:#1a1a1a;margin:0}.help-journey__card-description{font-size:14px;color:#777;line-height:1.6;margin:0}.help-journey__card-cta{display:inline-flex;padding:10px 24px;background:#2e7a3c;color:#fff;border-radius:10px;font-size:14px;font-weight:600;margin-top:6px;transition:background .2s}.help-journey__card:hover .help-journey__card-cta{background:#266e33}.help-journey__connector{width:48px;flex-shrink:0;border-top:2px dashed #ccc;align-self:center}.help-contact{padding:100px 0;background:#f4f6f5}.help-contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;max-width:1100px;margin:0 auto}.help-contact__title{font-size:26px;font-weight:700;color:#1a1a1a;margin-bottom:8px}.help-contact__subtitle{font-size:16px;color:#777;margin-bottom:28px;line-height:1.6}.help-contact__bullets{list-style:none;padding:0;margin:0 0 32px;display:flex;flex-direction:column;gap:14px}.help-contact__bullet-item{display:flex;align-items:center;gap:12px;font-size:15px;color:#4a4a4a}.help-contact__bullet-icon{width:28px;height:28px;border-radius:50%;background:#2e7a3c1a;color:#2e7a3c;display:flex;align-items:center;justify-content:center;flex-shrink:0}.help-contact__cta{display:inline-flex;align-items:center;padding:14px 32px;background:#2e7a3c;color:#fff;border-radius:12px;font-size:15px;font-weight:600;text-decoration:none;transition:background .2s,transform .2s,box-shadow .2s}.help-contact__cta:hover{background:#266e33;transform:translateY(-1px);box-shadow:0 4px 12px #2e7a3c33}.help-contact__testimonial{margin:28px 0 0;padding:20px 0 0;border-top:1px solid #e0dcd6}.help-contact__testimonial p{font-size:15px;font-style:italic;color:#5a5a5a;line-height:1.6;margin:0}.help-contact__testimonial cite{display:block;font-size:13px;color:#999;font-style:normal;margin-top:6px}.help-contact__visual{display:flex;justify-content:center}.help-contact__illustration{width:100%;max-width:420px;height:auto;border-radius:20px;display:block;box-shadow:0 4px 20px #2e7a3c1a,0 1px 4px #0000000a;transition:transform .28s ease,box-shadow .28s ease}.help-contact__illustration:hover{transform:translateY(-3px) scale(1.01);box-shadow:0 10px 36px #2e7a3c24,0 2px 8px #0000000f}.help-explore-divider{padding:32px 0;text-align:center;background:#f4f6f5;border-top:1px solid #e8e6e3}.help-explore-divider p{font-size:14px;color:#777;margin:0}.help-explore-divider__link{color:#2e7a3c;font-weight:500;text-decoration:underline;text-underline-offset:2px;transition:color .2s}.help-explore-divider__link:hover{color:#236b30}.help-empty{font-size:15px;color:#999;padding:24px 0;text-align:center}@media(max-width:1024px){.help-topics__grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.help-hero{padding:60px 0 40px}.help-hero__title{font-size:30px}.help-hero__subtitle{font-size:15px;margin-bottom:28px}.help-section-heading{font-size:22px;margin-bottom:24px}.help-topics,.help-faq,.help-journey,.help-contact{padding:64px 0}.help-journey__steps{flex-direction:column;align-items:center;gap:0}.help-journey__step-wrapper{flex-direction:column;max-width:340px;width:100%}.help-journey__connector{width:2px;height:32px;border-top:none;border-left:2px dashed #ccc}.help-contact__grid{grid-template-columns:1fr;gap:40px}.help-contact__visual{order:-1}.help-contact__illustration{max-width:320px;margin:0 auto}.help-contact__title{font-size:22px}}@media(max-width:640px){.help-topics__grid{grid-template-columns:1fr}.help-hero__quick-links{gap:6px 10px}.help-hero__quick-link{font-size:12px;padding:5px 12px}.help-journey__card{padding:28px 20px 24px}.help-contact__cta{width:100%;justify-content:center}}.cookie-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:24px 0;border-radius:8px;border:1px solid var(--color-border)}.cookie-table{width:100%;border-collapse:collapse;min-width:520px}.cookie-table th{text-align:left;padding:12px 16px;background:var(--color-background-subtle);font-size:13px;font-weight:600;color:var(--color-text-primary);border-bottom:2px solid var(--color-border);white-space:nowrap}.cookie-table td{padding:12px 16px;font-size:14px;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border-subtle, var(--color-border));vertical-align:top}.cookie-table tbody tr:last-child td{border-bottom:none}.cookie-table tbody tr:hover td{background:var(--color-background-subtle)}.cookie-table__code{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:12px;background:var(--color-background-subtle);padding:2px 6px;border-radius:4px;color:var(--color-primary-text, var(--color-primary));white-space:nowrap}.cookie-pref-btn{display:inline-flex;align-items:center;padding:12px 24px;margin-top:8px;background:var(--color-primary);color:#fff;font-weight:600;font-size:14px;border-radius:10px;border:none;cursor:pointer;font-family:inherit;transition:background .2s,transform .15s}.cookie-pref-btn:hover{background:var(--color-primary-hover, #3aa050);transform:translateY(-1px)}.cookie-pref-btn:active{transform:translateY(0)}@media(max-width:640px){.cookie-table th,.cookie-table td{padding:10px 12px}}
