@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: 36px;--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: #FDFCFB;--color-background-elevated: #FFFFFF;--color-background-subtle: #F7F6F4;--color-background-muted: #F0EFED;--color-background-warm: #FBF9F6;--color-background-cool: #F5F7F9;--color-background-primary: #F0F5F2;--color-background-primary-gradient: linear-gradient(135deg, #F5FAF7 0%, #EDF4F0 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: #2F5D46;--color-primary-hover: #264A38;--color-primary-active: #1E3C2D;--color-primary-light: rgba(47, 93, 70, .08);--color-border: #E8E6E3;--color-border-strong: #D6D4D1;--color-border-subtle: #F2F0ED;--color-success: #2F5D46;--color-error: #C53030;--color-warning: #B7791F;--color-info: #2B6CB0;--color-danger: #EF4444;--color-danger-rgb: 239, 68, 68;--color-focus-ring: rgba(47, 93, 70, .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, 249, 247, .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)}.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: 32px;--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)}.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:#2f5d4626}.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}.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)}}.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-small);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)}.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__actions{display:flex;align-items:center;gap:var(--space-4)}.navbar__sign-in{font-size:var(--font-size-small);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)}.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)}.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}.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}.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__copyright{margin:0}.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)}}.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:var(--color-border-strong);background-color:var(--color-background-subtle)}.otp-input__digit:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-focus-ring);transform:translateY(-2px)}.otp-input__digit:hover:not(:focus):not(:disabled){border-color:var(--color-text-tertiary)}.otp-input--error .otp-input__digit{border-color:var(--color-error);background-color:#c530300a}.otp-input--error .otp-input__digit:focus{border-color:var(--color-error);box-shadow:0 0 0 3px #c5303033}.otp-input__error{font-size:var(--font-size-small);color:var(--color-error);text-align:center;margin:0;animation:otpErrorShake .4s ease}@keyframes otpErrorShake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.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}}.coming-soon-overlay{position:fixed;inset:0;background:#0006;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:opacity var(--transition-base),visibility var(--transition-base);z-index:var(--z-modal-backdrop)}.coming-soon-overlay--visible{opacity:1;visibility:visible}.coming-soon-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);z-index:var(--z-modal);width:100%;max-width:480px;background:var(--color-background-elevated);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transition:opacity var(--transition-slow),visibility var(--transition-slow),transform var(--transition-slow);overflow:hidden}.coming-soon-modal--open{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}@media(max-width:540px){.coming-soon-modal{max-width:calc(100% - 32px);margin:0 16px}}.coming-soon-modal__close{position:absolute;top:var(--space-4);right:var(--space-4);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);z-index:2}.coming-soon-modal__close:hover{background:var(--color-background-subtle);color:var(--color-text-primary)}.coming-soon-modal__close:focus-visible{outline:none;box-shadow:0 0 0 3px var(--color-focus-ring)}.coming-soon-modal__close svg{width:20px;height:20px}.coming-soon-modal__content{display:flex;flex-direction:column;align-items:center;padding:var(--space-8);text-align:center}@media(max-width:540px){.coming-soon-modal__content{padding:var(--space-6);padding-top:var(--space-8)}}.coming-soon-modal__graphic{width:200px;height:160px;display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-6);position:relative}.coming-soon-modal__illustration{width:100%;height:100%;animation:float 4s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.coming-soon-modal__graphic--placeholder{border:2px dashed var(--color-border);border-radius:var(--radius-lg);background:var(--color-background-subtle)}.coming-soon-modal__title{font-family:var(--font-family);font-size:24px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--space-4);line-height:var(--line-height-heading);letter-spacing:var(--letter-spacing-tight)}.coming-soon-modal__subtitle{font-family:var(--font-family);font-size:15px;font-weight:var(--font-weight-regular);color:var(--color-text-secondary);margin:0 0 var(--space-4);line-height:var(--line-height-body);max-width:380px}.coming-soon-modal__body{font-family:var(--font-family);font-size:14px;font-weight:var(--font-weight-regular);color:var(--color-text-tertiary);margin:0 0 var(--space-6);line-height:var(--line-height-body);max-width:340px}.coming-soon-modal__cta{min-width:160px}.coming-soon-modal__cta:hover{transform:translateY(-1px);box-shadow:0 4px 12px #2f5d4640}.coming-soon-modal--open .coming-soon-modal__graphic{animation:slideUp .4s ease-out .1s both,float 4s ease-in-out .5s infinite}.coming-soon-modal--open .coming-soon-modal__title{animation:slideUp .4s ease-out .2s both}.coming-soon-modal--open .coming-soon-modal__subtitle{animation:slideUp .4s ease-out .25s both}.coming-soon-modal--open .coming-soon-modal__body{animation:slideUp .4s ease-out .3s both}.coming-soon-modal--open .coming-soon-modal__cta{animation:slideUp .4s ease-out .35s both}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.coming-soon-modal:before{content:"";position:absolute;top:0;left:0;right:0;height:180px;background:linear-gradient(135deg,#2f5d4608,#2f5d460f,#2f5d4605);pointer-events:none;z-index:0}.coming-soon-modal__content{position:relative;z-index:1}.hero{overflow:hidden;background:var(--color-background-cream)}.hero__grid{display:grid;grid-template-columns:1fr;gap:var(--space-12);align-items:center}@media(min-width:1024px){.hero__grid{grid-template-columns:1fr 1fr;gap:var(--space-16)}}.hero__content{max-width:560px}.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:.1em;font-size:13px}.hero__title{margin-bottom:var(--space-6);letter-spacing:-.03em}.hero__subtitle{margin-bottom:var(--space-8);max-width:480px}.hero__actions{display:flex;gap:var(--space-4);flex-wrap:wrap;margin-bottom:var(--space-10)}.hero__trust{display:flex;align-items:center;gap:var(--space-8);flex-wrap:wrap}.hero__trust-item{display:flex;align-items:center;gap:var(--space-2)}.hero__trust-item svg{width:18px;height:18px;color:var(--color-primary)}.hero__visual{position:relative}.hero__image-wrapper{position:relative;border-radius:var(--radius-2xl);overflow:hidden;box-shadow:var(--shadow-lg);background-color:var(--color-background-subtle)}.hero__image-wrapper:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--color-primary-light) 0%,transparent 50%);z-index:1;pointer-events:none}.hero__image{width:100%;height:auto;display:block;aspect-ratio:4 / 3;object-fit:cover;transform:scale(1.02)}.hero__badge{position:absolute;bottom:20px;left:-10px;background:#fffffff2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:12px 18px;border-radius:14px;box-shadow:0 8px 24px #2f5d461f,0 2px 8px #0000000f;display:flex;align-items:center;gap:12px;z-index:2;animation:float-badge 4s ease-in-out infinite;border:1px solid rgba(255,255,255,.6)}@keyframes float-badge{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.hero__badge-icon{width:38px;height:38px;background:var(--color-primary-light);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-primary);flex-shrink:0}.hero__badge-icon svg{width:18px;height:18px;fill:currentColor}.hero__badge-text{display:flex;flex-direction:column}.hero__badge-text span{font-weight:700;font-size:.9rem;color:var(--color-text-primary);line-height:1.2}.hero__badge-text small{font-size:.75rem;color:var(--color-text-secondary)}@media(max-width:1023px){.hero__content{text-align:center;max-width:100%;margin:0 auto}.hero__subtitle{max-width:100%;margin-left:auto;margin-right:auto}.hero__actions,.hero__trust{justify-content:center}}.value-prop{background:var(--color-background-primary)}.value-prop__content{text-align:center}.value-prop__text{max-width:700px;margin:var(--space-6) auto 0}.features{background:var(--color-background)}.features__header{margin-bottom:var(--space-12);max-width:600px}.features__subtitle{margin-top:var(--space-4)}.features__grid{display:grid;grid-template-columns:1fr;gap:var(--space-6)}@media(min-width:640px){.features__grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.features__grid{grid-template-columns:repeat(4,1fr)}}.feature-card{text-align:left}.feature-card__icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background-color:var(--color-primary-light);border-radius:var(--radius-lg);margin-bottom:var(--space-5)}.feature-card__icon svg{width:28px;height:28px;color:var(--color-primary)}.feature-card__title{margin-bottom:var(--space-3);font-size:22px}.feature-card__text{font-size:var(--font-size-small);line-height:1.6}.memory-gallery{background:var(--color-background-warm)}.gallery__header{text-align:center;max-width:600px;margin:0 auto var(--space-12)}.gallery__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-4);letter-spacing:.1em;font-size:13px}.gallery__subtitle{margin-top:var(--space-4)}.gallery__grid{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(3,1fr);gap:var(--space-4);aspect-ratio:16 / 12}@media(min-width:768px){.gallery__grid{grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,1fr);aspect-ratio:2 / 1}}.gallery__item{position:relative;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;background-color:var(--color-background-subtle)}.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow);transform:scale(1.02)}.gallery__item:hover img{transform:scale(1.08)}.gallery__overlay{position:absolute;bottom:0;left:0;right:0;padding:var(--space-4);background:linear-gradient(to top,rgba(0,0,0,.7),transparent);opacity:0;transition:opacity var(--transition-base)}.gallery__item:hover .gallery__overlay{opacity:1}.gallery__item--large{grid-column:span 2;grid-row:span 2}@media(min-width:768px){.gallery__item--large{grid-column:span 2;grid-row:span 2}}.gallery__cta{text-align:center;margin-top:var(--space-12)}.tree-preview__grid{display:grid;grid-template-columns:1fr;gap:var(--space-12);align-items:center}@media(min-width:1024px){.tree-preview__grid{grid-template-columns:1fr 1fr;gap:var(--space-16)}}.tree-preview__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-4);letter-spacing:.1em;font-size:13px}.tree-preview__text{margin:var(--space-4) 0 var(--space-8)}.tree-preview__features{list-style:none;margin:0 0 var(--space-8);padding:0}.tree-preview__features li{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0}.tree-preview__features li svg{width:20px;height:20px;color:var(--color-primary);flex-shrink:0}.tree-preview__visual{display:flex;justify-content:center;align-items:center;padding:var(--space-12);background:linear-gradient(145deg,#fff,#f8f9fa,#f0f2f4);border-radius:var(--radius-2xl);border:var(--border-width) solid var(--color-border-subtle);box-shadow:0 4px 20px #2f5d460f,0 1px 3px #0000000a,inset 0 1px #fffc;position:relative;overflow:hidden}.tree-preview__visual:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 20%,rgba(47,93,70,.03) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(47,93,70,.02) 0%,transparent 40%);pointer-events:none}.tree-diagram{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);position:relative;z-index:1}.tree-level{display:flex;justify-content:center;gap:var(--space-6)}.tree-connector{width:1px;height:32px;background:linear-gradient(180deg,#2f5d4680,#2f5d4640);position:relative}.tree-connector:after{content:"";display:block;width:320px;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(47,93,70,.3) 10%,rgba(47,93,70,.3) 90%,transparent 100%);margin-top:15px;margin-left:-159px}.tree-connector--partial:after{width:140px;margin-left:-69px}.tree-couple-line{width:24px;height:1px;background:#2f5d4666;align-self:center;margin-top:-12px;position:relative}.tree-couple-line:after{content:"♥";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:16px;color:var(--color-primary);opacity:.6;background:var(--color-background-elevated);padding:0 4px;line-height:1;animation:heart-pulse 3s ease-in-out infinite}@keyframes heart-pulse{0%,to{opacity:.5;transform:translate(-50%,-50%) scale(1)}50%{opacity:.8;transform:translate(-50%,-50%) scale(1.15)}}.tree-node{display:flex;gap:var(--space-3);transition:transform var(--transition-base);align-items:flex-start}.tree-node:hover{transform:translateY(-2px)}.tree-node--couple{position:relative}.tree-node__person{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.tree-node__avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(145deg,#fff,#f5f6f7);border:3px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:var(--font-weight-bold);color:var(--color-text-secondary);letter-spacing:-.02em;box-shadow:0 4px 12px #00000014,0 2px 4px #0000000a;transition:all var(--transition-base);cursor:pointer;overflow:hidden}.tree-node__avatar--photo{padding:0;background:var(--color-background-subtle)}.tree-node__avatar--photo img{width:100%;height:100%;object-fit:cover;border-radius:50%}.tree-node__avatar:hover{border-color:var(--color-primary);box-shadow:0 6px 16px #2f5d4633,0 3px 6px #00000014;transform:scale(1.08)}.tree-node__label{font-size:11px;font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);text-align:center;white-space:nowrap;max-width:80px;overflow:hidden;text-overflow:ellipsis}.tree-node__avatar--you{border-color:var(--color-primary);box-shadow:0 0 0 4px #2f5d4626,0 6px 16px #2f5d4640,0 3px 6px #0000001a}.tree-node__avatar--you:hover{box-shadow:0 0 0 5px #2f5d4633,0 8px 20px #2f5d464d,0 4px 8px #0000001a}.tree-node__label--you{font-weight:var(--font-weight-bold);color:var(--color-primary)}.tree-node--highlight .tree-node__avatar{box-shadow:0 0 0 5px #2f5d461f,0 4px 12px #2f5d4659,0 2px 4px #0000001a,inset 0 1px #ffffff26;animation:pulse-ring 2s ease-in-out infinite}@keyframes pulse-ring{0%,to{box-shadow:0 0 0 5px #2f5d461f,0 4px 12px #2f5d4659,0 2px 4px #0000001a,inset 0 1px #ffffff26}50%{box-shadow:0 0 0 8px #2f5d4614,0 4px 12px #2f5d4659,0 2px 4px #0000001a,inset 0 1px #ffffff26}}@media(max-width:1023px){.tree-preview__grid{flex-direction:column-reverse}.tree-preview__visual{order:2;padding:var(--space-8)}.tree-preview__content{order:1}.tree-node__avatar{width:48px;height:48px;border-width:2px}.tree-node__label{font-size:10px;max-width:60px}.tree-node{gap:var(--space-3)}.tree-node--couple:after{top:24px;width:10px;height:10px}.tree-connector:after{width:260px;margin-left:-129px}.tree-connector--partial:after{width:120px;margin-left:-59px}}.how-it-works{background:var(--color-background-cool)}.how-it-works__header{text-align:center;margin-bottom:var(--space-16)}.how-it-works__subtitle{max-width:600px;margin:var(--space-4) auto 0}.how-it-works__steps{display:flex;flex-direction:column;gap:var(--space-8)}.step{display:grid;grid-template-columns:auto 1fr auto;gap:var(--space-6);align-items:flex-start;padding:var(--space-6);background:var(--color-background-elevated);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-xl)}.step__number{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-primary);color:var(--color-text-inverse);font-size:20px;font-weight:var(--font-weight-bold);border-radius:50%;flex-shrink:0}.step__content{padding-top:var(--space-2)}.step__title{margin-bottom:var(--space-2)}.step__text{font-size:var(--font-size-small)}.step__icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-light);border-radius:var(--radius-lg);flex-shrink:0}.step__icon svg{width:24px;height:24px;color:var(--color-primary)}@media(max-width:640px){.step{grid-template-columns:auto 1fr}.step__icon{display:none}}.final-cta{background:linear-gradient(180deg,var(--color-background-primary) 0%,var(--color-background) 100%)}.final-cta__content{text-align:center;max-width:700px;margin:0 auto}.final-cta__text{margin:var(--space-6) 0 var(--space-10);max-width:560px;margin-left:auto;margin-right:auto}.final-cta__actions{display:flex;justify-content:center;margin-bottom:var(--space-6)}.final-cta__note{margin:0}@media(max-width:640px){.hero__label,.gallery__label,.tree-preview__label{font-size:11px}.feature-card__icon{width:48px;height:48px}.feature-card__icon svg{width:24px;height:24px}}.features-intro{text-align:center}.features-intro__content{max-width:800px;margin:0 auto}.features-intro__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}.features-intro__text{margin-top:var(--space-6);max-width:680px;margin-left:auto;margin-right:auto}.feature-section{overflow:hidden}.feature-block{display:grid;grid-template-columns:1fr;gap:var(--space-12);align-items:center}@media(min-width:1024px){.feature-block--left,.feature-block--right{grid-template-columns:1fr 1.15fr;gap:var(--space-16)}}.feature-block__content{max-width:520px}.feature-block__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-4);letter-spacing:.15em;font-size:12px}.feature-block__title{margin-bottom:var(--space-5);letter-spacing:-.02em}.feature-block__lead{font-size:20px;line-height:1.5;color:var(--color-text-primary);margin-bottom:var(--space-6)}.feature-block__body{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-8)}.feature-block__body p{font-size:var(--font-size-body);line-height:1.7}.feature-block__action{display:flex;gap:var(--space-4);flex-wrap:wrap}.feature-block__visual{position:relative}.feature-block__image-wrapper{position:relative;border-radius:var(--radius-2xl);overflow:hidden;box-shadow:var(--shadow-xl);background:var(--color-background-elevated);border:var(--border-width) solid var(--color-border)}.feature-block__image-wrapper img{width:100%;height:auto;display:block}.feature-block__image-wrapper:before{content:"";position:absolute;top:-20px;right:-20px;width:120px;height:120px;background:var(--color-primary-light);border-radius:50%;z-index:-1;opacity:.5}@media(min-width:1024px){.feature-block--right{grid-template-columns:1.15fr 1fr}.feature-block--right .feature-block__visual{order:-1}.feature-block--right .feature-block__content{justify-self:end}.feature-block--right .feature-block__image-wrapper:before{right:auto;left:-20px}}.feature-block--stacked{display:flex;flex-direction:column;gap:var(--space-10);text-align:center}.feature-block__content--centered{max-width:700px;margin:0 auto}.feature-block__content--centered .feature-block__label,.feature-block__content--centered .feature-block__title{margin-bottom:var(--space-4)}.feature-block__content--centered .feature-block__lead{max-width:600px;margin:0 auto}.feature-block__visual--wide{width:100%;max-width:100%}.feature-block__image-wrapper--wide{max-width:1000px;margin:0 auto}.feature-block__image-wrapper--wide:before{display:none}.feature-block__body--centered{max-width:700px;margin:0 auto;text-align:center}.feature-block__body--centered p{max-width:600px;margin-left:auto;margin-right:auto}.feature-block__trust-list{list-style:none;margin:var(--space-6) 0 0;padding:0;display:flex;flex-direction:column;gap:var(--space-3)}.feature-block__trust-list li{display:flex;align-items:center;gap:var(--space-3)}.trust-icon{font-size:18px;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.features-cta{background:linear-gradient(180deg,var(--color-background) 0%,var(--color-background-subtle) 100%)}.features-cta__content{text-align:center;max-width:700px;margin:0 auto}.features-cta__text{margin:var(--space-6) 0 var(--space-10);max-width:580px;margin-left:auto;margin-right:auto}.features-cta__actions{display:flex;justify-content:center;gap:var(--space-4);flex-wrap:wrap}@media(max-width:1023px){.feature-block__content{max-width:100%;text-align:center}.feature-block__action{justify-content:center}.feature-block__body{text-align:left}.feature-block__trust-list{align-items:center}.feature-block__image-wrapper:before{width:80px;height:80px;top:-10px;right:-10px}}@media(max-width:640px){.feature-block{gap:var(--space-8)}.feature-block__label{font-size:11px}.feature-block__lead{font-size:18px}.feature-block__body p{font-size:16px}.feature-block__image-wrapper:before{display:none}}.feature-section--tree .feature-block__image-wrapper:before{background:linear-gradient(135deg,var(--color-primary-light) 0%,rgba(47,93,70,.05) 100%)}.feature-section--profiles .feature-block__image-wrapper:before{background:linear-gradient(135deg,#2f5d4614,#2f5d4605)}.feature-section--memories .feature-block__image-wrapper:before{background:linear-gradient(135deg,rgba(47,93,70,.1) 0%,transparent 100%)}.feature-section--privacy .feature-block__image-wrapper:before{background:linear-gradient(135deg,var(--color-primary-light) 0%,rgba(47,93,70,.03) 100%)}.how-it-works-page{min-height:100vh;background-color:var(--color-background)}.hiw-hero{padding-top:var(--space-20);padding-bottom:var(--space-12)}.hiw-hero__content{max-width:640px;margin:0 auto}.hiw-hero__title{font-size:clamp(40px,7vw,64px);font-weight:var(--font-weight-bold);line-height:1.1;letter-spacing:-.03em;color:var(--color-text-primary);margin-bottom:var(--space-6)}.hiw-hero__title-accent{color:var(--color-primary)}.hiw-hero__subtitle{color:var(--color-text-secondary);font-size:clamp(18px,2.5vw,22px);margin-top:var(--space-4);line-height:1.5}.hiw-hero__supporting{color:var(--color-text-tertiary);font-size:var(--font-size-body);margin-top:var(--space-6);line-height:1.6;max-width:520px;margin-left:auto;margin-right:auto}.hiw-hero__cta-wrapper{display:flex;justify-content:center;margin-top:var(--space-10)}.hiw-hero__cta{display:inline-flex;align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-8);background:var(--color-primary);color:var(--color-text-inverse);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);border-radius:var(--radius-full);transition:all var(--transition-base);text-decoration:none}.hiw-hero__cta:hover{background:var(--color-primary-hover);transform:translateY(-2px);box-shadow:0 8px 24px #2f5d4640}.hiw-hero__cta-arrow{font-size:20px;transition:transform var(--transition-base)}.hiw-hero__cta:hover .hiw-hero__cta-arrow{transform:translate(4px)}.hiw-steps{padding-top:var(--space-12);padding-bottom:var(--space-20)}.hiw-steps__container{display:flex;flex-direction:column;gap:0;max-width:600px;margin:0 auto}.hiw-step{display:grid;grid-template-columns:auto 1fr auto;align-items:start;gap:var(--space-6);padding:var(--space-10) 0;position:relative;opacity:0;animation:stepFadeIn .6s ease forwards;animation-delay:var(--step-delay)}@keyframes stepFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hiw-step__line{position:absolute;left:40px;top:calc(50% + 40px);width:2px;height:calc(100% - 40px);background:linear-gradient(to bottom,var(--color-border-strong) 0%,var(--color-border) 50%,transparent 100%)}.hiw-step__number{width:80px;height:80px;border-radius:var(--radius-full);background:var(--color-background-elevated);border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;z-index:1;transition:all var(--transition-slow);margin-top:var(--space-1)}.hiw-step__number span{font-size:32px;font-weight:var(--font-weight-bold);color:var(--color-primary);letter-spacing:-.02em}.hiw-step:hover .hiw-step__number{background:var(--color-primary);border-color:var(--color-primary);transform:scale(1.05);box-shadow:0 8px 24px #2f5d4633}.hiw-step:hover .hiw-step__number span{color:var(--color-text-inverse)}.hiw-step__content{flex:1;min-width:0}.hiw-step__title{font-size:clamp(20px,4vw,26px);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:1.3;margin:0 0 var(--space-3) 0;transition:color var(--transition-base)}.hiw-step:hover .hiw-step__title{color:var(--color-primary)}.hiw-step__description{color:var(--color-text-secondary);font-size:var(--font-size-body);line-height:1.6;margin:0 0 var(--space-3) 0}.hiw-step__hint{color:var(--color-text-tertiary);font-size:var(--font-size-small);font-style:italic;line-height:1.5;margin:0}.hiw-step__icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);opacity:.5;transition:all var(--transition-base);margin-top:var(--space-1)}.hiw-step__icon svg{width:28px;height:28px}.hiw-step:hover .hiw-step__icon{color:var(--color-primary);opacity:1;transform:scale(1.1)}.hiw-values{padding-top:var(--space-16);padding-bottom:var(--space-20);background:var(--color-background-subtle)}.hiw-values__header{margin-bottom:var(--space-12)}.hiw-values__title{font-size:clamp(28px,5vw,40px);font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:-.02em}.hiw-values__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-8);max-width:1000px;margin:0 auto}.hiw-value-card{background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8);text-align:center;transition:all var(--transition-base);opacity:0;animation:cardFadeIn .5s ease forwards;animation-delay:var(--card-delay)}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.hiw-value-card:hover{border-color:var(--color-border-strong);transform:translateY(-4px);box-shadow:0 12px 32px #00000014}.hiw-value-card__icon{width:56px;height:56px;margin:0 auto var(--space-5);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary-subtle) 0%,var(--color-background) 100%);border-radius:var(--radius-lg);color:var(--color-primary);transition:all var(--transition-base)}.hiw-value-card__icon svg{width:28px;height:28px}.hiw-value-card:hover .hiw-value-card__icon{background:var(--color-primary);color:var(--color-text-inverse);transform:scale(1.05)}.hiw-value-card__title{font-size:var(--font-size-h4);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-3) 0}.hiw-value-card__description{color:var(--color-text-secondary);font-size:var(--font-size-body);line-height:1.6;margin:0}.hiw-faq{padding-top:var(--space-16);padding-bottom:var(--space-20);background:var(--color-background)}.hiw-faq__header{margin-bottom:var(--space-10)}.hiw-faq__title{font-size:clamp(28px,5vw,40px);font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:-.02em}.hiw-faq__list{max-width:640px;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-3)}.hiw-faq__item{background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base)}.hiw-faq__item:hover{border-color:var(--color-border-strong)}.hiw-faq__item--open{border-color:var(--color-primary);box-shadow:0 4px 16px #2f5d461a}.hiw-faq__question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-5) var(--space-6);background:transparent;border:none;cursor:pointer;text-align:left;font-family:inherit;font-size:var(--font-size-body);font-weight:var(--font-weight-medium);color:var(--color-text-primary);transition:color var(--transition-base)}.hiw-faq__question:hover{color:var(--color-primary)}.hiw-faq__chevron{width:20px;height:20px;flex-shrink:0;color:var(--color-text-tertiary);transition:transform var(--transition-base)}.hiw-faq__chevron--open{transform:rotate(180deg);color:var(--color-primary)}.hiw-faq__answer{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease}.hiw-faq__item--open .hiw-faq__answer{max-height:200px}.hiw-faq__answer p{padding:0 var(--space-6) var(--space-5);margin:0;color:var(--color-text-secondary);font-size:var(--font-size-body);line-height:1.6}.hiw-final-cta{padding-top:var(--space-20);padding-bottom:var(--space-24);background:linear-gradient(to bottom,var(--color-background) 0%,var(--color-background-subtle) 100%)}.hiw-final-cta__content{display:flex;flex-direction:column;align-items:center;gap:var(--space-6);text-align:center;max-width:560px;margin:0 auto}.hiw-final-cta__title{font-size:clamp(28px,5vw,36px);font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:-.02em;line-height:1.2;margin:0}.hiw-final-cta__subtitle{color:var(--color-text-secondary);font-size:clamp(18px,2.5vw,22px);line-height:1.5;margin:0}.hiw-final-cta__button{display:inline-flex;align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-10);margin-top:var(--space-4);background:var(--color-primary);color:var(--color-text-inverse);font-size:var(--font-size-body);font-weight:var(--font-weight-semibold);border-radius:var(--radius-full);transition:all var(--transition-base);text-decoration:none}.hiw-final-cta__button:hover{background:var(--color-primary-hover);transform:translateY(-2px);box-shadow:0 12px 32px #2f5d464d}.hiw-final-cta__arrow{font-size:20px;transition:transform var(--transition-base)}.hiw-final-cta__button:hover .hiw-final-cta__arrow{transform:translate(4px)}.hiw-final-cta__microtext{color:var(--color-text-tertiary);font-size:var(--font-size-small);margin:0}@media(max-width:900px){.hiw-values__grid{grid-template-columns:1fr;gap:var(--space-6);max-width:480px}.hiw-value-card{padding:var(--space-6)}}@media(max-width:768px){.hiw-hero{padding-top:var(--space-16);padding-bottom:var(--space-10)}.hiw-hero__title{font-size:36px}.hiw-hero__supporting{font-size:var(--font-size-small)}.hiw-step{padding:var(--space-8) 0;gap:var(--space-4);align-items:start}.hiw-step__number{width:64px;height:64px}.hiw-step__number span{font-size:26px}.hiw-step__line{left:32px;top:calc(50% + 32px);height:calc(100% - 32px)}.hiw-step__title{font-size:20px}.hiw-step__icon{width:40px;height:40px}.hiw-step__icon svg{width:22px;height:22px}.hiw-values,.hiw-faq{padding-top:var(--space-12);padding-bottom:var(--space-16)}.hiw-final-cta{padding-top:var(--space-16);padding-bottom:var(--space-20)}.hiw-final-cta__button{padding:var(--space-4) var(--space-8);font-size:15px}}@media(max-width:480px){.hiw-hero__title{font-size:32px}.hiw-hero__cta{padding:var(--space-4) var(--space-6);font-size:15px}.hiw-step__number{width:56px;height:56px}.hiw-step__number span{font-size:22px}.hiw-step__line{left:28px;top:calc(50% + 28px);height:calc(100% - 28px)}.hiw-step__icon{display:none}.hiw-step{grid-template-columns:auto 1fr}.hiw-step__description{font-size:var(--font-size-small)}.hiw-step__hint{font-size:13px}.hiw-faq__question{padding:var(--space-4) var(--space-5);font-size:var(--font-size-small)}.hiw-faq__answer p{padding:0 var(--space-5) var(--space-4);font-size:var(--font-size-small)}.hiw-final-cta__title{font-size:26px}}.pricing-page{min-height:100vh;background-color:var(--color-background)}.pricing-intro{padding-top:var(--space-20);padding-bottom:var(--space-12)}.pricing-intro__content{max-width:600px;margin:0 auto}.pricing-intro__title{font-size:clamp(40px,7vw,56px);font-weight:var(--font-weight-bold);line-height:1.1;letter-spacing:-.03em;margin-bottom:var(--space-6)}.pricing-intro__subtitle{color:var(--color-text-secondary)}.pricing-tiers{padding-top:var(--space-8);padding-bottom:var(--space-16)}.pricing-tiers__toggle-wrapper{display:flex;justify-content:center;margin-bottom:var(--space-10)}.billing-toggle{display:inline-flex;position:relative;background:var(--color-background-subtle);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:4px;gap:4px}.billing-toggle__option{position:relative;z-index:2;display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);font-size:var(--font-size-body);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}.billing-toggle__option:hover{color:var(--color-text-primary)}.billing-toggle__option--active{color:var(--color-text-primary);background:var(--color-background-elevated);box-shadow:var(--shadow-sm)}.billing-toggle__option:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.billing-toggle__badge{display:inline-block;background:var(--color-primary);color:var(--color-text-inverse);font-size:11px;font-weight:var(--font-weight-semibold);padding:2px 8px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.02em}.billing-toggle__slider{display:none}.pricing-tiers__footnote{margin-top:var(--space-8);font-style:italic}.pricing-tiers__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);max-width:1000px;margin:0 auto;align-items:start}.pricing-tiers__note{margin-top:var(--space-4)}.pricing-card{background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8);position:relative;transition:all var(--transition-slow)}.pricing-card:hover{border-color:var(--color-border-strong);box-shadow:var(--shadow-md);transform:translateY(-4px)}.pricing-card--highlighted{border-color:var(--color-primary);border-width:2px;background:linear-gradient(to bottom,rgba(47,93,70,.03) 0%,var(--color-background-elevated) 100%)}.pricing-card--highlighted:hover{border-color:var(--color-primary);box-shadow:0 12px 32px #2f5d4626}.pricing-card__badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:var(--color-primary);color:var(--color-text-inverse);font-size:13px;font-weight:var(--font-weight-semibold);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);white-space:nowrap}.pricing-card__header{text-align:center;padding-bottom:var(--space-6);border-bottom:1px solid var(--color-border-subtle);margin-bottom:var(--space-6)}.pricing-card__name{font-size:var(--font-size-body);color:var(--color-text-secondary);margin-bottom:var(--space-3);display:block}.pricing-card__price-wrapper{display:flex;align-items:baseline;justify-content:center;gap:var(--space-1);margin-bottom:var(--space-2)}.pricing-card__price{font-size:clamp(40px,6vw,52px);font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:-.03em;line-height:1}.pricing-card__period{font-size:var(--font-size-body);color:var(--color-text-tertiary);font-weight:var(--font-weight-regular)}.pricing-card__description{display:block}.pricing-card__features{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-8)}.pricing-card__features li{display:flex;align-items:flex-start;gap:var(--space-3)}.pricing-card__check{flex-shrink:0;width:20px;height:20px;color:var(--color-primary);margin-top:2px}.pricing-card__check svg{width:100%;height:100%}.pricing-card__features li p{color:var(--color-text-secondary);line-height:1.4}.pricing-card__footer{margin-top:auto}.pricing-faq{padding-top:var(--section-padding-y-lg);padding-bottom:var(--section-padding-y-lg)}.pricing-faq__header{margin-bottom:var(--space-12)}.pricing-faq__subtitle{color:var(--color-text-secondary);margin-top:var(--space-4)}.pricing-faq__list{display:flex;flex-direction:column;gap:var(--space-3);max-width:700px;margin:0 auto}.faq-item{background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:all .25s cubic-bezier(.4,0,.2,1)}.faq-item:hover{border-color:var(--color-border-strong);box-shadow:0 2px 8px #0000000f}.faq-item--open{border-color:var(--color-primary);box-shadow:0 4px 12px #2f5d461a}.faq-item__question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-5) var(--space-6);text-align:left;font-size:var(--font-size-body);font-weight:var(--font-weight-medium);color:var(--color-text-primary);cursor:pointer;background:transparent;border:none;border-radius:inherit;transition:all .2s cubic-bezier(.4,0,.2,1)}.faq-item__question:hover{background:var(--color-background-subtle)}.faq-item__question:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px}.faq-item--open .faq-item__question{background:#2f5d460a}.faq-item__icon{flex-shrink:0;width:24px;height:24px;color:var(--color-text-tertiary);transition:transform .35s cubic-bezier(.4,0,.2,1),color .2s ease}.faq-item__icon svg{width:100%;height:100%}.faq-item__question:hover .faq-item__icon{color:var(--color-text-secondary)}.faq-item--open .faq-item__icon{transform:rotate(180deg);color:var(--color-primary)}.faq-item__answer{display:grid;grid-template-rows:0fr;transition:grid-template-rows .4s cubic-bezier(.4,0,.2,1)}.faq-item--open .faq-item__answer{grid-template-rows:1fr}.faq-item__answer-inner{overflow:hidden}.faq-item__answer p{padding:var(--space-4) var(--space-5);color:var(--color-text-secondary);line-height:1.7;opacity:0;transform:translateY(-8px);transition:opacity .3s cubic-bezier(.4,0,.2,1) .1s,transform .3s cubic-bezier(.4,0,.2,1) .1s}.faq-item--open .faq-item__answer p{opacity:1;transform:translateY(0)}.pricing-cta{padding-top:var(--space-20);padding-bottom:var(--space-24)}.pricing-cta__content{text-align:center;max-width:550px;margin:0 auto}.pricing-cta__content h2{margin-bottom:var(--space-4)}.pricing-cta__text{color:var(--color-text-secondary);margin-bottom:var(--space-8)}.pricing-cta__actions{display:flex;justify-content:center;margin-bottom:var(--space-6)}.pricing-cta__actions button{display:inline-flex;align-items:center;gap:var(--space-2)}.pricing-cta__actions svg{width:20px;height:20px}.pricing-cta__note{opacity:.7}@media(max-width:1024px){.pricing-tiers__grid{gap:var(--space-4)}.pricing-card{padding:var(--space-6)}.pricing-card__price{font-size:40px}}@media(max-width:768px){.pricing-intro{padding-top:var(--space-16);padding-bottom:var(--space-8)}.pricing-tiers__grid{grid-template-columns:1fr;max-width:400px;gap:var(--space-6)}.pricing-card--highlighted{order:-1}.pricing-card{padding:var(--space-6)}.pricing-card__price{font-size:48px}.pricing-faq{padding-top:var(--space-16);padding-bottom:var(--space-16)}.faq-item__question{padding:var(--space-4) var(--space-5);font-size:16px}.faq-item__answer p{padding:0 var(--space-5) var(--space-4)}.pricing-cta{padding-top:var(--space-16);padding-bottom:var(--space-16)}}@media(max-width:480px){.pricing-intro__title{font-size:32px}.billing-toggle__option{padding:var(--space-2) var(--space-3);font-size:var(--font-size-small)}.billing-toggle__badge{font-size:9px;padding:2px 6px}.pricing-card__price{font-size:42px}.pricing-card__features{gap:var(--space-3)}}.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-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)}}.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)}}}.contact-hero{text-align:center;padding-top:var(--space-20);padding-bottom:var(--space-12)}.contact-hero__content{max-width:680px;margin:0 auto}.contact-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}.contact-hero__title{font-size:clamp(36px,5vw,52px);line-height:1.1;letter-spacing:-.025em;margin-bottom:var(--space-6)}.contact-hero__lead{font-size:clamp(18px,2.5vw,22px);line-height:1.5;color:var(--color-text-secondary);max-width:520px;margin:0 auto}.contact-form-section{padding-top:var(--space-8);padding-bottom:var(--space-20)}.contact-form-wrapper{max-width:640px;margin:0 auto;background-color:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:var(--space-12);box-shadow:var(--shadow-lg)}.contact-form{display:flex;flex-direction:column;gap:var(--space-6)}.contact-form__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6)}.contact-form__textarea-wrapper{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:var(--space-1)}.contact-form__required{color:var(--color-error)}.contact-form__textarea{width:100%;min-height:160px;padding:var(--input-padding-x);font-size:var(--input-font-size);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;transition:border-color var(--transition-base),box-shadow var(--transition-base)}.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(--input-border-color-focus);box-shadow:0 0 0 3px var(--color-focus-ring)}.contact-form__submit{align-self:flex-start;margin-top:var(--space-4)}.contact-form__submit svg{width:18px;height:18px}.contact-form__spinner{width:18px;height:18px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite;margin-right:var(--space-2)}.contact-success{text-align:center;padding:var(--space-10) var(--space-4)}.contact-success__icon{width:80px;height:80px;margin:0 auto var(--space-8);background:linear-gradient(135deg,var(--color-primary-light) 0%,rgba(47,93,70,.15) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;animation:successPop .5s ease}.contact-success__icon svg{width:36px;height:36px;color:var(--color-primary)}@keyframes successPop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.contact-success__title{font-size:clamp(24px,3vw,32px);margin-bottom:var(--space-4)}.contact-success__text{color:var(--color-text-secondary);max-width:400px;margin:0 auto var(--space-8);line-height:1.6}.contact-reassurance{padding-top:var(--space-20);padding-bottom:var(--space-20)}.contact-reassurance__header{text-align:center;margin-bottom:var(--space-16)}.contact-reassurance__title{font-size:clamp(28px,3.5vw,40px);margin-bottom:var(--space-4)}.contact-reassurance__subtitle{color:var(--color-text-secondary);max-width:480px;margin:0 auto}.contact-reassurance__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-8);max-width:960px;margin:0 auto}.contact-feature{text-align:center;padding:var(--space-8);background-color:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);transition:transform var(--transition-base),box-shadow var(--transition-base)}.contact-feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.contact-feature__icon{width:56px;height:56px;margin:0 auto var(--space-5);background-color:var(--color-primary-light);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;transition:background-color var(--transition-base)}.contact-feature:hover .contact-feature__icon{background-color:var(--color-primary)}.contact-feature__icon svg{width:24px;height:24px;color:var(--color-primary);transition:color var(--transition-base)}.contact-feature:hover .contact-feature__icon svg{color:var(--color-text-inverse)}.contact-feature__title{font-size:20px;font-weight:var(--font-weight-semibold);margin-bottom:var(--space-2)}.contact-feature__description{color:var(--color-text-secondary);font-size:var(--font-size-small);line-height:1.6}.contact-alternatives{padding-top:var(--space-16);padding-bottom:var(--space-24)}.contact-alternatives__content{text-align:center}.contact-alternatives__title{font-size:clamp(24px,3vw,32px);margin-bottom:var(--space-10)}.contact-alternatives__options{display:flex;justify-content:center;gap:var(--space-8)}.contact-option{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-8) var(--space-10);background-color:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);transition:transform var(--transition-base),border-color var(--transition-base)}.contact-option:hover{transform:translateY(-2px);border-color:var(--color-primary)}.contact-option__icon{width:48px;height:48px;background-color:var(--color-primary-light);border-radius:50%;display:flex;align-items:center;justify-content:center}.contact-option__icon svg{width:22px;height:22px;color:var(--color-primary)}.contact-option__label{color:var(--color-text-secondary);font-size:var(--font-size-small)}.contact-option__link{color:var(--color-primary);font-size:var(--font-size-body);font-weight:var(--font-weight-medium);text-decoration:none;transition:color var(--transition-base)}.contact-option__link:hover{color:var(--color-primary-hover);text-decoration:underline}@media(max-width:1023px){.contact-hero{padding-top:var(--space-16);padding-bottom:var(--space-10)}.contact-form-wrapper{padding:var(--space-10)}.contact-reassurance{padding-top:var(--space-16);padding-bottom:var(--space-16)}.contact-reassurance__header{margin-bottom:var(--space-12)}.contact-alternatives{padding-top:var(--space-12);padding-bottom:var(--space-20)}}@media(max-width:768px){.contact-reassurance__grid{grid-template-columns:1fr;gap:var(--space-6)}.contact-feature{padding:var(--space-6)}}@media(max-width:640px){.contact-hero{padding-top:var(--space-12);padding-bottom:var(--space-8)}.contact-hero__label{font-size:11px;padding:var(--space-1) var(--space-3)}.contact-form-section{padding-bottom:var(--space-16)}.contact-form-wrapper{padding:var(--space-6);border-radius:var(--radius-xl)}.contact-form__grid{grid-template-columns:1fr;gap:var(--space-5)}.contact-form{gap:var(--space-5)}.contact-form__submit{width:100%}.contact-success{padding:var(--space-8) var(--space-2)}.contact-success__icon{width:64px;height:64px;margin-bottom:var(--space-6)}.contact-success__icon svg{width:28px;height:28px}.contact-alternatives__options{flex-direction:column;gap:var(--space-4)}.contact-option{padding:var(--space-6)}}@media(prefers-reduced-motion:no-preference){.contact-form-wrapper{animation:fadeInUp .6s ease}.contact-feature{opacity:0;transform:translateY(20px);animation:fadeInUp .5s ease forwards}.contact-feature:nth-child(1){animation-delay:.1s}.contact-feature:nth-child(2){animation-delay:.2s}.contact-feature:nth-child(3){animation-delay:.3s}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}}.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}.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__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__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}}.invite-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)}.invite-modal-overlay--visible{opacity:1;visibility:visible}.invite-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:680px;max-width:calc(100vw - 48px);border-radius:var(--radius-2xl)}.invite-modal--open{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}@media(max-width:640px){.invite-modal{inset:auto 0 0;transform:translateY(100%);width:100%;max-width:100%;max-height:90vh;border-radius:var(--radius-2xl) var(--radius-2xl) 0 0}.invite-modal--open{transform:translateY(0)}}.invite-modal__header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0}@media(max-width:640px){.invite-modal__header{padding:var(--space-4)}}.invite-modal__header-content{flex:1}.invite-modal__title{font-size:clamp(18px,4vw,20px);margin:0 0 var(--space-2);color:var(--color-text-primary)}.invite-modal__subtitle{margin:0;line-height:1.5}.invite-modal__close{width:44px;height:44px;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);flex-shrink:0;margin-left:var(--space-4)}.invite-modal__close:hover{background:var(--color-background-subtle);color:var(--color-text-primary)}.invite-modal__close svg{width:24px;height:24px}.invite-modal__tabs{display:flex;gap:var(--space-2);padding:var(--space-4) var(--space-6);background:var(--color-background-subtle);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0;overflow-x:auto}@media(max-width:640px){.invite-modal__tabs{padding:var(--space-3) var(--space-4)}}.invite-tab{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:transparent;border:1px solid transparent;border-radius:var(--radius-full);cursor:pointer;font-size:14px;font-weight:var(--font-weight-medium);color:var(--color-text-secondary);transition:all var(--transition-fast);white-space:nowrap}.invite-tab:hover{background:var(--color-background-muted);color:var(--color-text-primary)}.invite-tab--active{background:var(--color-primary);color:var(--color-text-inverse);border-color:var(--color-primary)}.invite-tab--active:hover{background:var(--color-primary-hover);color:var(--color-text-inverse)}.invite-tab svg{width:16px;height:16px;flex-shrink:0}.invite-modal__content{flex:1;overflow-y:auto;padding:var(--space-6)}@media(max-width:640px){.invite-modal__content{padding:var(--space-4)}}.invite-tab-content{display:flex;flex-direction:column;gap:var(--space-8)}.invite-form__row{display:flex;gap:var(--space-4)}@media(max-width:640px){.invite-form__row{flex-direction:column}}.invite-form__field{flex:1}.invite-form__field--email{flex:2}.invite-form__field--name{flex:1}.invite-form__field--role{max-width:200px}@media(max-width:640px){.invite-form__field--role{max-width:none}}.invite-form__field--message{width:100%}.invite-form__label{display:block;font-size:14px;font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--space-2)}.invite-form__optional{font-weight:var(--font-weight-regular);color:var(--color-text-tertiary)}.invite-form__textarea{width:100%;padding:var(--space-4);font-size:16px;font-family:var(--font-family);color:var(--color-text-primary);background:var(--color-background-elevated);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-lg);resize:vertical;min-height:80px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.invite-form__textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-focus-ring)}.invite-form__textarea::placeholder{color:var(--color-text-tertiary)}.invite-form__note{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--color-background-warm);border-radius:var(--radius-md)}.invite-form__note svg{width:16px;height:16px;flex-shrink:0;color:var(--color-text-tertiary);margin-top:2px}.invite-form__actions{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)}@media(max-width:640px){.invite-form__actions{flex-direction:column-reverse}.invite-form__actions .btn{width:100%;height:48px}}.invite-pending{border-top:1px solid var(--color-border);padding-top:var(--space-6)}.invite-pending__title{font-size:16px;margin-bottom:var(--space-4);display:flex;align-items:center;gap:var(--space-2)}.invite-pending__count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;background:var(--color-primary);color:var(--color-text-inverse);border-radius:var(--radius-full);font-size:12px;font-weight:var(--font-weight-semibold)}.invite-empty{padding:var(--space-8);text-align:center;background:var(--color-background-subtle);border-radius:var(--radius-lg)}.invite-list{display:flex;flex-direction:column;gap:0;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.invite-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--color-background-elevated);border-bottom:1px solid var(--color-border-subtle)}.invite-item:last-child{border-bottom:none}.invite-item:hover{background:var(--color-background-subtle)}.invite-item__info{flex:1;min-width:0}.invite-item__name{font-size:15px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:2px}.invite-item__email{font-size:13px;color:var(--color-text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invite-item__role,.invite-item__status,.invite-item__date{flex-shrink:0}.invite-item__date{font-size:13px;color:var(--color-text-tertiary);min-width:90px}.invite-role-badge{display:inline-block;padding:4px 12px;background:var(--color-background-subtle);border-radius:var(--radius-full);font-size:12px;font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.invite-role-badge--editor{background:var(--color-primary-light);color:var(--color-primary)}.invite-status-badge{display:inline-block;padding:4px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:var(--font-weight-semibold)}.invite-status-badge--pending{background:#fef3c7;color:#92400e}.invite-status-badge--accepted{background:var(--color-primary-light);color:var(--color-primary)}.invite-action-wrapper{position:relative}.invite-item__action{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)}.invite-item__action:hover{background:var(--color-background-muted);color:var(--color-text-primary)}.invite-item__action svg{width:20px;height:20px}@media(max-width:768px){.invite-item{flex-wrap:wrap;gap:var(--space-2)}.invite-item__info{width:100%;order:1}.invite-item__role,.invite-item__status,.invite-item__date{order:2}.invite-action-wrapper{order:3;margin-left:auto}.invite-item__date{display:none}}.invite-action-menu{position:absolute;top:100%;right:0;min-width:180px;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);overflow:hidden;animation:fadeInScale var(--transition-fast)}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}.invite-action-menu__item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);background:transparent;border:none;cursor:pointer;font-size:14px;font-weight:var(--font-weight-medium);color:var(--color-text-secondary);transition:all var(--transition-fast);text-align:left}.invite-action-menu__item:hover{background:var(--color-background-subtle);color:var(--color-text-primary)}.invite-action-menu__item svg{width:16px;height:16px;flex-shrink:0}.invite-action-menu__item--danger{color:var(--color-danger)}.invite-action-menu__item--danger:hover{background:#ef44441a;color:var(--color-danger)}.share-link-section{display:flex;flex-direction:column;gap:var(--space-4)}.toggle-row__label{font-size:16px;font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.share-link-content{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-4);background:var(--color-background-subtle);border-radius:var(--radius-lg);animation:fadeIn var(--transition-base)}.share-link-settings__row{display:flex;gap:var(--space-4)}@media(max-width:640px){.share-link-settings__row{flex-direction:column}}.share-link-settings__field{flex:1}.share-link-url{display:flex;gap:var(--space-2)}.share-buttons{display:flex;gap:var(--space-3)}@media(max-width:640px){.share-buttons{flex-wrap:wrap}}.share-button{display:flex;align-items:center;justify-content:center;gap:var(--space-2);flex:1;padding:var(--space-3) var(--space-4);background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;font-size:14px;font-weight:var(--font-weight-medium);color:var(--color-text-primary);transition:all var(--transition-fast)}.share-button:hover{border-color:var(--color-border-strong);background:var(--color-background-muted)}.share-button svg{width:20px;height:20px}.share-button--whatsapp svg{color:#25d366}.share-button--email svg{color:var(--color-primary)}.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)}.qr-section{display:flex;flex-direction:column;align-items:center;gap:var(--space-6);padding:var(--space-4)}.qr-display{display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.qr-code-wrapper{padding:var(--space-4);background:#fff;border:2px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.qr-code-svg{display:block}.qr-display__label{font-size:16px;color:var(--color-text-secondary);text-align:center}.qr-display__label strong{color:var(--color-text-primary)}.qr-actions{display:flex;gap:var(--space-3)}@media(max-width:640px){.qr-actions{flex-direction:column;width:100%}.qr-actions .btn{width:100%}}.qr-actions .btn svg{width:18px;height:18px}.qr-note{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--color-background-warm);border-radius:var(--radius-md);max-width:400px;text-align:center}.qr-note svg{width:16px;height:16px;flex-shrink:0;color:var(--color-text-tertiary);margin-top:2px}.invite-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)}.invite-toast svg{width:18px;height:18px}.invite-toast--success{background:var(--color-primary)}.invite-toast--error{background:var(--color-danger)}.invite-confirm-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);padding:var(--space-4)}.invite-confirm-dialog{background:var(--color-background-elevated);border-radius:var(--radius-xl);padding:var(--space-6);width:400px;max-width:100%;box-shadow:var(--shadow-xl);animation:scaleIn var(--transition-base)}.invite-confirm-dialog__title{margin-bottom:var(--space-3);font-size:18px}.invite-confirm-dialog__message{margin-bottom:var(--space-5);font-size:15px;line-height:1.5;color:var(--color-text-secondary)}.invite-confirm-dialog__actions{display:flex;justify-content:flex-end;gap:var(--space-3)}.role-change-options{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-5)}.role-change-option{display:flex;align-items:center;padding:var(--space-4);background:var(--color-background-subtle);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;font-size:15px;font-weight:var(--font-weight-medium);color:var(--color-text-primary);transition:all var(--transition-fast)}.role-change-option:hover{border-color:var(--color-border-strong);background:var(--color-background-muted)}.role-change-option--selected{border-color:var(--color-primary);background:var(--color-background-primary)}.btn--danger,button.btn--danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn--danger:hover,button.btn--danger:hover{background:#dc2626;border-color:#dc2626}.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{min-height:100vh;background:var(--color-background);display:flex;flex-direction:column;transition:filter var(--transition-base)}.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-top:calc(var(--navbar-height) + 40px);padding-bottom:40px}.tree-card{background:var(--color-background-elevated);border-radius:var(--radius-xl);border:1px solid var(--color-border);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;height:110vh;min-height:800px}.tree-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6) var(--space-8);background:var(--color-background-elevated);border-bottom:1px solid var(--color-border);gap:var(--space-4);flex-wrap:wrap}@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:radial-gradient(circle at 50% 50%,var(--color-background-primary) 0%,var(--color-background) 70%),linear-gradient(90deg,var(--color-border-subtle) 1px,transparent 1px),linear-gradient(var(--color-border-subtle) 1px,transparent 1px);background-size:100% 100%,40px 40px,40px 40px;overflow:hidden;cursor:grab;-webkit-user-select:none;user-select:none}.tree-container--dragging{cursor:grabbing}.tree-canvas{position:absolute;inset:0;transform-origin:center center;transition:transform .1s ease-out}@media(max-width:768px){.tree-canvas{width:1200px;height:1000px;inset:0 auto auto 0}}.tree-connections{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}.tree-connection{fill:none;stroke:var(--color-border-strong);stroke-width:2;stroke-linecap:round}.tree-connection--spouse{stroke:var(--color-primary);stroke-width:2;stroke-dasharray:4 4;opacity:.6}.tree-connection--parent{stroke:var(--color-border-strong);opacity:.5}.person-card{position:absolute;display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-3);background:var(--color-background-elevated);border-radius:var(--radius-xl);border:2px solid var(--color-border);cursor:pointer;transition:all var(--transition-base);z-index:10;min-width:100px;box-shadow:var(--shadow-sm)}.person-card:hover{transform:translate(-50%,-50%) scale(1.08)!important;box-shadow:var(--shadow-lg);border-color:var(--color-border-strong);z-index:20}.person-card--selected{border-color:var(--color-primary);box-shadow:var(--shadow-lg),0 0 0 4px var(--color-primary-light)}.person-card--current{border-color:var(--color-primary);background:linear-gradient(180deg,var(--color-background-elevated) 0%,var(--color-background-primary) 100%)}.person-card--deceased{opacity:.75}.person-card--deceased .person-card__avatar{filter:grayscale(30%)}.person-card__avatar{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:var(--font-weight-bold);color:var(--color-text-inverse);position:relative;transition:transform var(--transition-base)}.person-card--male .person-card__avatar{background:linear-gradient(135deg,#4a90a4,#2f6b7f)}.person-card--female .person-card__avatar{background:linear-gradient(135deg,#b4838d,#8b5a5a)}.person-card__avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.person-card__badge{position:absolute;bottom:-4px;right:-4px;background:var(--color-primary);color:var(--color-text-inverse);font-size:9px;font-weight:var(--font-weight-bold);padding:2px 6px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em;border:2px solid var(--color-background-elevated)}.person-card__info{display:flex;flex-direction:column;align-items:center;gap:2px;text-align:center}.person-card__name{font-size:13px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap}.person-card__years{font-size:11px;color:var(--color-text-tertiary)}.generation-labels{position:absolute;left:var(--space-4);top:0;bottom:0;width:120px;pointer-events:none;z-index:5}.generation-label{position:absolute;left:0;transform:translateY(-50%);font-size:11px;font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;background:var(--color-background);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);opacity:.8}.zoom-controls{position:absolute;bottom:var(--space-6);right:var(--space-6);display:flex;align-items:center;gap:var(--space-2);background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-2);box-shadow:var(--shadow-md);z-index:100}.zoom-control{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-secondary);transition:all var(--transition-fast)}.zoom-control:hover{background:var(--color-background-subtle);color:var(--color-text-primary)}.zoom-control svg{width:20px;height:20px}.zoom-level{min-width:48px;text-align:center;font-size:13px;font-weight:var(--font-weight-semibold);color:var(--color-text-secondary)}.zoom-divider{width:1px;height:24px;background:var(--color-border);margin:0 var(--space-1)}.canvas-hint{position:absolute;bottom:var(--space-6);left:50%;transform:translate(-50%);background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:var(--space-2) var(--space-5);box-shadow:var(--shadow-sm);z-index:100;opacity:.9}.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:fixed;top:0;right:0;bottom:0;width:380px;max-width:90vw;background:var(--color-background-elevated);border-left:1px solid var(--color-border);box-shadow:var(--shadow-xl);transform:translate(100%);transition:transform var(--transition-slow);z-index:var(--z-modal);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)}.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 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}.confirm-modal-overlay{position:fixed;inset:0;background:#00000080;z-index:calc(var(--z-modal) + 10);animation:fadeIn .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:slideUp .25s ease-out}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}.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__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}.action-toast{position:fixed;bottom:var(--space-6);left:50%;transform:translate(-50%);padding:var(--space-4) var(--space-6);background:var(--color-background-elevated);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--color-border);z-index:calc(var(--z-modal) + 20);animation:toastSlideUp .3s ease-out}@keyframes toastSlideUp{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}.action-toast--success{border-left:3px solid var(--color-success, #22c55e)}.action-toast--info{border-left:3px solid var(--color-primary)}.action-toast--error{border-left:3px solid var(--color-error)}@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-labels{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}.person-card{min-width:80px;padding:var(--space-2)}.person-card__avatar{width:44px;height:44px;font-size:14px}.person-card__name{font-size:11px}.person-card__years{font-size:10px}}@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}.confirm-modal{padding:var(--space-6)}.confirm-modal__actions{flex-direction:column}.confirm-modal__actions .btn{width:100%}.action-toast{width:calc(100% - var(--space-8));max-width:none}}.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__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-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}.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)}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.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}}.addmember-modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;visibility:hidden;transition:opacity var(--transition-base),visibility var(--transition-base);z-index:var(--z-modal-backdrop)}.addmember-modal-overlay--visible{opacity:1;visibility:visible}.addmember-modal{position:fixed;z-index:var(--z-modal);background:var(--color-background-elevated);border:1px solid var(--color-border);box-shadow:var(--shadow-xl),0 0 60px #00000026;display:flex;flex-direction:column;max-height:92vh;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:900px;max-width:calc(100vw - 48px);border-radius:var(--radius-2xl)}.addmember-modal--open{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}@media(max-width:640px){.addmember-modal{inset:auto 0 0;transform:translateY(100%);width:100%;max-width:100%;max-height:92vh;border-radius:var(--radius-2xl) var(--radius-2xl) 0 0}.addmember-modal--open{transform:translateY(0)}}.addmember-modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-background-elevated) 100%);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0}.addmember-modal__header-content{display:flex;align-items:center;gap:var(--space-3)}.addmember-modal__header-content svg{width:28px;height:28px;color:var(--color-primary)}.addmember-modal__title{font-size:16px;margin:0;color:var(--color-text-primary);background:linear-gradient(135deg,var(--color-primary) 0%,#2dd4bf 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.addmember-modal__close{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;color:var(--color-text-tertiary);transition:all var(--transition-fast)}.addmember-modal__close:hover{background:var(--color-background-subtle);color:var(--color-text-primary);border-color:var(--color-border-strong)}.addmember-modal__close svg{width:20px;height:20px}.addmember-modal__stepper{padding:var(--space-4) var(--space-6);background:var(--color-background-subtle);border-bottom:1px solid var(--color-border-subtle);overflow:visible}.addmember-stepper{display:flex;align-items:center;justify-content:center;gap:0;min-width:max-content}.addmember-stepper__item{display:flex;align-items:center;gap:var(--space-2)}.addmember-stepper__dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:var(--font-weight-semibold);background:var(--color-background-elevated);border:2px solid var(--color-border);color:var(--color-text-tertiary);cursor:default;transition:all var(--transition-fast);flex-shrink:0}.addmember-stepper__dot:disabled{cursor:default}.addmember-stepper__dot:not(:disabled){cursor:pointer}.addmember-stepper__dot:not(:disabled):hover{border-color:var(--color-primary);transform:scale(1.05)}.addmember-stepper__dot--current{background:var(--color-primary);border-color:var(--color-primary);color:#fff;box-shadow:0 0 0 4px var(--color-primary-light)}.addmember-stepper__dot--completed{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.addmember-stepper__dot--completed svg{width:16px;height:16px}.addmember-stepper__label{font-size:12px;font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);margin-right:var(--space-2);white-space:nowrap}.addmember-stepper__label--current{color:var(--color-primary);font-weight:var(--font-weight-semibold)}.addmember-stepper__line{width:32px;height:2px;background:var(--color-border);margin:0 var(--space-1);flex-shrink:0}.addmember-stepper__line--completed{background:var(--color-primary)}@media(max-width:640px){.addmember-stepper__label{display:none}.addmember-stepper__line{width:20px}}.addmember-modal__content{flex:1;overflow-y:auto;padding:var(--space-6)}.addmember-modal__footer{display:flex;align-items:center;justify-content:space-between;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}.addmember-modal__footer .button svg{width:16px;height:16px}.addmember-modal__submit{min-width:140px}@media(max-width:640px){.addmember-modal__footer{padding:var(--space-4)}}.addmember-step{animation:fadeSlideIn var(--transition-base) ease-out}@keyframes fadeSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.addmember-step__header{text-align:center;margin-bottom:var(--space-6)}.addmember-step__header .addmember-step__header-icon{display:flex;align-items:center;justify-content:center;margin:1rem auto 1.5rem}.addmember-step__header .addmember-step__header-icon svg{width:48px;height:48px;color:var(--color-primary);padding:var(--space-3);background:var(--color-primary-light);border-radius:var(--radius-xl)}.addmember-step__title{margin:0 0 var(--space-2) 0;font-size:16px;color:var(--color-text-primary)}.addmember-step__subtitle{margin:0;font-size:15px}.relationship-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);margin-bottom:var(--space-5)}@media(max-width:600px){.relationship-grid{grid-template-columns:repeat(2,1fr)}}.relationship-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-5) var(--space-3);background:var(--color-background-subtle);border:2px solid var(--color-border);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-fast);text-align:center}.relationship-card:hover{border-color:var(--color-border-strong);background:var(--color-background-muted);transform:translateY(-2px)}.relationship-card--selected{border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:0 0 0 4px rgba(var(--color-primary-rgb),.1)}.relationship-card__icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-background-elevated);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.relationship-card__icon svg{width:24px;height:24px;color:var(--color-text-secondary);transition:color var(--transition-fast)}.relationship-card--selected .relationship-card__icon{background:var(--color-primary)}.relationship-card--selected .relationship-card__icon svg{color:#fff}.relationship-card__label{font-size:15px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.relationship-card__description{font-size:12px;color:var(--color-text-tertiary);line-height:1.4}.other-relation-input{margin-bottom:var(--space-5);animation:fadeIn var(--transition-fast)}.link-existing-toggle{margin-bottom:var(--space-4)}.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--compact{padding:var(--space-3) var(--space-4)}.toggle-row--large{padding:var(--space-5);background:linear-gradient(135deg,var(--color-background-subtle) 0%,var(--color-background-muted) 100%);border:1px solid var(--color-border)}.toggle-row__content{display:flex;flex-direction:column;gap:2px}.toggle-row__label{font-size:15px;font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.toggle-row__description{font-size:13px;color:var(--color-text-tertiary)}.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;flex-shrink: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)}.existing-member-search{background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);animation:fadeIn var(--transition-fast)}.search-input-wrapper{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--color-background-subtle);border-radius:var(--radius-md);margin-bottom:var(--space-3)}.search-input-wrapper svg{width:20px;height:20px;color:var(--color-text-tertiary);flex-shrink:0}.search-input{flex:1;border:none;background:transparent;font-size:15px;color:var(--color-text-primary);outline:none}.search-input::placeholder{color:var(--color-text-tertiary)}.existing-members-list{display:flex;flex-direction:column;gap:var(--space-2)}.existing-member-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--color-background-subtle);border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%}.existing-member-item:hover{background:var(--color-background-muted)}.existing-member-item--selected{border-color:var(--color-primary);background:var(--color-primary-light)}.existing-member-item__avatar{width:40px;height:40px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:var(--font-weight-semibold);flex-shrink:0}.existing-member-item__info{flex:1;display:flex;flex-direction:column;gap:2px}.existing-member-item__name{font-size:14px;font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.existing-member-item__relation{font-size:12px;color:var(--color-text-tertiary);text-transform:capitalize}.existing-member-item svg{width:20px;height:20px;color:var(--color-primary)}.search-empty{padding:var(--space-4);text-align:center}.details-form{display:flex;flex-direction:column;gap:var(--space-5)}.avatar-upload-section{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.avatar-upload{position:relative;width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary) 0%,#2dd4bf 100%);display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;box-shadow:var(--shadow-md);transition:transform var(--transition-fast)}.avatar-upload:hover{transform:scale(1.05)}.avatar-upload__initials{font-size:32px;font-weight:var(--font-weight-bold);color:#fff;text-transform:uppercase}.avatar-upload__image{width:100%;height:100%;object-fit:cover}.avatar-upload__overlay{position:absolute;inset:0;background:#00000080;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-1);opacity:0;transition:opacity var(--transition-fast)}.avatar-upload:hover .avatar-upload__overlay{opacity:1}.avatar-upload__overlay svg{width:24px;height:24px;color:#fff}.avatar-upload__overlay span{font-size:11px;color:#fff;font-weight:var(--font-weight-medium)}.avatar-upload__input{display:none}.avatar-upload__hint{text-align:center}.details-form__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}@media(max-width:500px){.details-form__row{grid-template-columns:1fr}}.details-form__field{display:flex;flex-direction:column}.deceased-toggle{margin-top:var(--space-2)}.death-year-field{animation:fadeIn var(--transition-fast);padding-left:var(--space-4);border-left:3px solid var(--color-border)}.note-label{display:flex;flex-direction:column;gap:2px;margin-bottom:var(--space-2)}.note-textarea{width:100%;min-height:80px;padding:var(--space-3);font-size:15px;color:var(--color-text-primary);background:var(--color-background-elevated);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-md);resize:vertical;font-family:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.note-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.note-textarea::placeholder{color:var(--color-text-tertiary)}.year-picker{position:relative;width:100%}.year-picker__label{display:block;font-size:14px;font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--space-2)}.year-picker__input-wrapper{position:relative;display:flex;align-items:center}.year-picker__input{width:100%;height:var(--input-height);padding:0 var(--space-10) 0 var(--input-padding-x);font-size:15px;color:var(--color-text-primary);background:var(--color-background-elevated);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);font-family:inherit}.year-picker__input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.year-picker__input::placeholder{color:var(--color-text-tertiary)}.year-picker__input-wrapper svg{position:absolute;right:var(--space-3);width:20px;height:20px;color:var(--color-text-tertiary);pointer-events:none}.year-picker__dropdown{position:absolute;top:100%;left:0;right:0;margin-top:var(--space-1);background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-height:240px;overflow-y:auto;z-index:100;animation:dropdownFadeIn var(--transition-fast)}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.year-picker__option{display:block;width:100%;padding:var(--space-3) var(--space-4);font-size:15px;color:var(--color-text-primary);background:transparent;border:none;text-align:left;cursor:pointer;transition:background-color var(--transition-fast)}.year-picker__option:hover{background:var(--color-background-subtle)}.year-picker__option--selected{background:var(--color-primary-light);color:var(--color-primary);font-weight:var(--font-weight-semibold)}.year-picker__option--selected:hover{background:var(--color-primary-light)}.year-picker__no-results{padding:var(--space-4);text-align:center;color:var(--color-text-tertiary);font-size:14px}.placement-preview{background:var(--color-background-subtle);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8) var(--space-6);margin-bottom:var(--space-5)}.placement-preview__tree{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);position:relative}.placement-preview__node{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);position:relative}.placement-preview__node--side{position:absolute;left:calc(50% + 80px);top:50%;transform:translateY(-50%)}.placement-preview__avatar{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:var(--font-weight-semibold);box-shadow:var(--shadow-md)}.placement-preview__avatar--you{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.placement-preview__avatar--new{background:linear-gradient(135deg,var(--color-primary) 0%,#2dd4bf 100%);color:#fff}.placement-preview__avatar--new img{width:100%;height:100%;object-fit:cover;border-radius:50%}.placement-preview__avatar span{font-size:14px}.placement-preview__name{font-size:13px;font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.placement-preview__badge{position:absolute;top:-8px;right:-20px;background:var(--color-primary);color:#fff;font-size:10px;font-weight:var(--font-weight-bold);padding:2px 8px;border-radius:var(--radius-full);text-transform:uppercase;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.placement-preview__line{width:2px;height:32px;background:var(--color-border-strong)}.placement-preview__line--horizontal{position:absolute;width:60px;height:2px;left:calc(50% + 20px);top:50%}.placement-side-select{max-width:300px;margin:0 auto var(--space-5)}.placement-confirmation{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-background-warm) 100%);border-radius:var(--radius-lg);text-align:center;justify-content:center}.placement-confirmation svg{width:24px;height:24px;color:var(--color-primary);flex-shrink:0}.placement-confirmation__text{font-size:15px;color:var(--color-text-primary)}.permissions-skip{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-5);background:var(--color-background-subtle);border-radius:var(--radius-lg);text-align:left}.permissions-skip svg{width:24px;height:24px;color:var(--color-text-tertiary);flex-shrink:0;margin-top:2px}.invite-toggle{margin-bottom:var(--space-5)}.invite-form-section{display:flex;flex-direction:column;gap:var(--space-5);animation:fadeIn var(--transition-fast)}.role-select{display:flex;flex-direction:column;gap:var(--space-3)}.role-select__label{margin-bottom:var(--space-1)}.role-options{display:flex;flex-direction:column;gap:var(--space-2)}.role-option{display:flex;flex-direction:column;gap:2px;padding:var(--space-4);background:var(--color-background-subtle);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;text-align:left;transition:all var(--transition-fast);width:100%}.role-option:hover{border-color:var(--color-border-strong);background:var(--color-background-muted)}.role-option--selected{border-color:var(--color-primary);background:var(--color-primary-light)}.role-option__label{font-size:15px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.role-option__description{font-size:13px;color:var(--color-text-tertiary)}.review-card{background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-md)}.review-card__header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-5);padding-bottom:var(--space-5);border-bottom:1px solid var(--color-border-subtle)}.review-card__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:#fff;flex-shrink:0;box-shadow:var(--shadow-md)}.review-card__avatar--male{background:linear-gradient(135deg,#3b82f6,#6366f1)}.review-card__avatar--female{background:linear-gradient(135deg,#ec4899,#f43f5e)}.review-card__avatar--other{background:linear-gradient(135deg,var(--color-primary) 0%,#2dd4bf 100%)}.review-card__avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.review-card__name-section{display:flex;flex-direction:column;gap:var(--space-1)}.review-card__name{margin:0;font-size:22px;color:var(--color-text-primary)}.review-card__relation{display:inline-block;padding:4px 12px;background:var(--color-primary-light);color:var(--color-primary);border-radius:var(--radius-full);font-size:13px;font-weight:var(--font-weight-semibold);text-transform:capitalize;width:fit-content}.review-card__details{display:flex;flex-wrap:wrap;gap:var(--space-4);margin-bottom:var(--space-4)}.review-card__detail{display:flex;align-items:center;gap:var(--space-2);font-size:14px;color:var(--color-text-secondary)}.review-card__detail svg{width:16px;height:16px;color:var(--color-text-tertiary)}.review-card__detail-label{color:var(--color-text-tertiary)}.review-card__note{padding:var(--space-4);background:var(--color-background-subtle);border-radius:var(--radius-md);margin-bottom:var(--space-4);font-style:italic}.review-card__invite{padding-top:var(--space-4);border-top:1px solid var(--color-border-subtle)}.review-card__invite-status{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:14px}.review-card__invite-status svg{width:20px;height:20px;flex-shrink:0}.review-card__invite-status--invited{background:var(--color-primary-light);color:var(--color-primary)}.review-card__invite-status--invited>div{display:flex;flex-direction:column;gap:2px}.review-card__invite-status--no-invite,.review-card__invite-status--deceased{background:var(--color-background-subtle);color:var(--color-text-tertiary)}.addmember-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:var(--color-text-inverse);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);font-size:15px;font-weight:var(--font-weight-medium);z-index:calc(var(--z-modal) + 100);animation:toastSlideUp var(--transition-base)}.addmember-toast svg{width:20px;height:20px}.addmember-toast--success{background:linear-gradient(135deg,var(--color-primary) 0%,#059669 100%)}.addmember-toast--error{background:linear-gradient(135deg,var(--color-danger) 0%,#dc2626 100%)}.addmember-toast--info{background:linear-gradient(135deg,#3b82f6,#6366f1)}@keyframes toastSlideUp{0%{opacity:0;transform:translate(-50%,24px)}to{opacity:1;transform:translate(-50%)}}@media(max-width:500px){.addmember-modal__content{padding:var(--space-4)}.addmember-step__header svg{width:40px;height:40px}.addmember-step__title{font-size:20px}.relationship-card{padding:var(--space-4) var(--space-2)}.relationship-card__icon{width:40px;height:40px}.relationship-card__icon svg{width:20px;height:20px}.placement-preview{padding:var(--space-6) var(--space-4)}.review-card{padding:var(--space-4)}.review-card__avatar{width:56px;height:56px;font-size:20px}.review-card__name{font-size:18px}}.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-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)}.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}}.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__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}.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)}.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{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);flex:1;display:flex;align-items:flex-start;flex-direction:column;text-align:left}.story-card__meta{display:flex;align-items:center;justify-content:space-between;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)}.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}.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:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.kebab-trigger:hover{background:var(--color-background-elevated);border-color:var(--color-primary)}.story-card.story-card--grid .kebab-trigger svg{width:14px;height:14px;color:var(--color-text-secondary);margin:0}.story-card.story-card--grid .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.story-card--grid .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.story-card--grid .kebab-item:hover{background:var(--color-background)}.story-card.story-card--grid .kebab-item--danger{color:var(--color-danger)}.story-card.story-card--grid .kebab-item--danger:hover{background:rgba(var(--color-danger-rgb),.1)}.story-card.story-card--grid .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-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)}}.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}.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{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{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-bottom:var(--space-4)}.family-tab{text-align:center;padding:var(--space-12) 0}.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)}}@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%}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-8) var(--space-6);background-color:var(--color-background)}.auth-container{width:100%;max-width:420px;margin:4rem auto;display:flex;flex-direction:column;align-items:center;justify-content:center}.auth-logo{display:block;margin-bottom:var(--space-10);transition:opacity var(--transition-base)}.auth-logo:hover{opacity:.8}.auth-logo img{height:44px;width:auto}.auth-header{text-align:center;margin-bottom:var(--space-10);width:100%}.auth-title{font-size:clamp(28px,4vw,36px);font-weight:var(--font-weight-bold);line-height:1.2;letter-spacing:-.02em;margin-bottom:var(--space-3)}.auth-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-body)}.auth-notice+.auth-form{margin-top:var(--space-6)}.auth-form{width:100%;display:flex;flex-direction:column;gap:var(--space-5)}.auth-form .input-wrapper--lg .input{height:56px;font-size:17px;padding:0 var(--space-5);border-radius:var(--radius-lg)}.auth-form .input__label{font-size:15px;font-weight:var(--font-weight-medium);margin-bottom:var(--space-2)}.auth-password-field{display:flex;flex-direction:column;gap:var(--space-2)}.auth-password-label{font-size:15px;font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.auth-password-input-wrapper{position:relative;display:flex;align-items:center}.auth-password-toggle{position:absolute;right:var(--space-4);top:50%;transform:translateY(-50%);background:none;border:none;padding:var(--space-2);cursor:pointer;color:var(--color-text-tertiary);display:flex;align-items:center;justify-content:center;transition:color var(--transition-base);z-index:1}.auth-password-toggle:hover{color:var(--color-text-secondary)}.auth-password-toggle svg{width:20px;height:20px}.auth-password-field .input{padding-right:52px!important}.auth-password-requirements{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4);background:var(--color-background-subtle);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-lg);margin-top:var(--space-2)}.auth-requirement{display:flex;flex-direction:column;gap:var(--space-2)}.auth-requirement__header{display:flex;align-items:center;justify-content:space-between}.auth-requirement__label{font-size:var(--font-size-small);color:var(--color-text-secondary);transition:color var(--transition-base)}.auth-requirement--met .auth-requirement__label{color:var(--color-success);font-weight:var(--font-weight-medium)}.auth-requirement__icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:50%;background-color:var(--color-border);color:var(--color-text-tertiary);transition:all var(--transition-base)}.auth-requirement--met .auth-requirement__icon{background-color:var(--color-success);color:#fff}.auth-requirement__icon svg{width:12px;height:12px}.auth-requirement__progress{width:100%;height:4px;background-color:var(--color-border);border-radius:var(--radius-full);overflow:hidden;position:relative}.auth-requirement__progress-bar{height:100%;width:0%;background-color:var(--color-text-tertiary);border-radius:var(--radius-full);transition:width .3s ease,background-color .3s ease}.auth-requirement--met .auth-requirement__progress-bar{width:100%;background-color:var(--color-success)}.auth-forgot{display:flex;justify-content:flex-end;margin-top:calc(-1 * var(--space-2))}.auth-forgot__link{font-size:var(--font-size-small);color:var(--color-primary);text-decoration:none;transition:color var(--transition-base)}.auth-forgot__link:hover{color:var(--color-primary-hover);text-decoration:underline}.auth-submit{margin-top:var(--space-4);height:56px;font-size:17px;font-weight:var(--font-weight-semibold)}.auth-terms{text-align:center;color:var(--color-text-tertiary);margin-top:var(--space-6);line-height:1.6}.auth-terms a{color:var(--color-text-secondary);text-decoration:underline;text-underline-offset:2px;transition:color var(--transition-base)}.auth-demo{width:100%;margin-top:var(--space-8);padding:var(--space-5);background:linear-gradient(135deg,var(--color-background-primary) 0%,var(--color-background-warm) 100%);border:1px solid var(--color-primary-light);border-radius:var(--radius-lg);text-align:center}.auth-demo__header{display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin-bottom:var(--space-2)}.auth-demo__header svg{width:16px;height:16px;color:var(--color-primary)}.auth-demo__text,.auth-demo__button{margin-bottom:var(--space-4)}.auth-demo__button svg{width:16px;height:16px}.auth-demo__credentials{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3);background:var(--color-background-elevated);border-radius:var(--radius-md);font-family:var(--font-mono, monospace)}.auth-demo__credentials strong{color:var(--color-text-secondary)}.auth-divider{width:100%;display:flex;align-items:center;gap:var(--space-4);margin:var(--space-8) 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background-color:var(--color-border)}.auth-divider span{font-size:var(--font-size-small);color:var(--color-text-tertiary);text-transform:lowercase}.auth-alternate{text-align:center}.auth-alternate p{color:var(--color-text-secondary)}.auth-alternate__link{color:var(--color-primary);font-weight:var(--font-weight-semibold);text-decoration:none;transition:color var(--transition-base)}.auth-alternate__link:hover{color:var(--color-primary-hover);text-decoration:underline}.auth-social{width:100%;display:flex;flex-direction:column;gap:var(--space-3)}.auth-social__button{display:flex;align-items:center;justify-content:center;gap:var(--space-3);width:100%;height:56px;padding:0 var(--space-5);font-family:var(--font-family);font-size:16px;font-weight:var(--font-weight-medium);line-height:1;color:var(--color-text-primary);background-color:var(--color-background-elevated);border:var(--border-width-thick) solid var(--color-border-strong);border-radius:var(--button-radius);cursor:pointer;transition:background-color var(--transition-base),border-color var(--transition-base),box-shadow var(--transition-base),transform var(--transition-fast)}.auth-social__button:hover{background-color:var(--color-background-subtle);border-color:var(--color-text-tertiary)}.auth-social__button:active{background-color:var(--color-border);transform:translateY(1px)}.auth-social__button:focus-visible{outline:none;box-shadow:0 0 0 3px var(--color-focus-ring)}.auth-social__button:disabled{opacity:.6;cursor:not-allowed}.auth-social__button svg{width:20px;height:20px;flex-shrink:0}.auth-social__button .social-icon-google{width:20px;height:20px}.auth-social__button--facebook{color:var(--color-text-primary)}.auth-social__button--facebook svg{color:#1877f2}.auth-social__message{text-align:center;padding:var(--space-3);background-color:var(--color-background-primary);border-radius:var(--radius-md);animation:socialMessageFadeIn .3s ease}@keyframes socialMessageFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.auth-divider--social{margin:var(--space-6) 0}@media(max-width:480px){.auth-page{padding:var(--space-6) var(--space-4);align-items:flex-start;padding-top:var(--space-12)}.auth-logo{margin-bottom:var(--space-8)}.auth-logo img{height:38px}.auth-header{margin-bottom:var(--space-8)}.auth-form{gap:var(--space-4)}.auth-form .input-wrapper--lg .input,.auth-submit{height:52px;font-size:16px}.auth-divider{margin:var(--space-6) 0}.auth-social__button{height:52px;font-size:15px}.auth-divider--social{margin:var(--space-5) 0}}@media(prefers-reduced-motion:no-preference){.auth-container{animation:authFadeIn .5s ease}@keyframes authFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.auth-form .input-wrapper{animation:authFieldFadeIn .4s ease backwards}.auth-form .input-wrapper:nth-child(1){animation-delay:.1s}.auth-form .input-wrapper:nth-child(2){animation-delay:.15s}.auth-password-field{animation:authFieldFadeIn .4s ease .2s backwards}.auth-submit{animation:authFieldFadeIn .4s ease .25s backwards}@keyframes authFieldFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}}.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,#2f5d461a,#2f5d4633);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}.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-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-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:var(--z-toast);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-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)}}.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)}.story-body p{margin-bottom:var(--space-6)}.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}.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}.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}.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}}.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)}.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}@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}.save-exit-btn{position:absolute;top:var(--space-6);right:var(--space-6);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}.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)}.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}
