:root{--colour-bg: #f9f7f4;--colour-surface: #ffffff;--colour-surface-alt: #f4f1ed;--colour-border: #e4ddd6;--colour-text-primary: #1c1810;--colour-text-secondary: #5c5248;--colour-text-muted: #8c8178;--colour-accent: #8b2635;--colour-accent-light: #c4576a;--colour-accent-dark: #5e1520;--colour-gold: #b8960c;--colour-gold-light: #f0d060;--font-display: "Playfair Display", Georgia, serif;--font-body: "Inter", system-ui, -apple-system, sans-serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-md: 1.125rem;--text-lg: 1.25rem;--text-xl: 1.5rem;--text-2xl: 1.875rem;--text-3xl: 2.25rem;--text-4xl: 3rem;--leading-tight: 1.2;--leading-snug: 1.4;--leading-normal: 1.65;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--container-max: 1200px;--sidebar-width: 260px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 16px;--shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 12px rgba(0,0,0,.1), 0 2px 4px rgba(0,0,0,.06);--shadow-lg: 0 8px 24px rgba(0,0,0,.12), 0 4px 8px rgba(0,0,0,.08);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--colour-text-primary);background-color:var(--colour-bg);min-height:100vh}img{display:block;max-width:100%}a{color:var(--colour-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--colour-accent-dark)}h1,h2,h3,h4{font-family:var(--font-display);line-height:var(--leading-tight);color:var(--colour-text-primary)}p{margin-bottom:var(--space-4)}p:last-child{margin-bottom:0}.lazy-image-wrapper{background-color:var(--colour-surface-alt)}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.lazy-shimmer{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,var(--colour-surface-alt) 25%,#e8e3dd 50%,var(--colour-surface-alt) 75%);background-size:800px 100%;animation:shimmer 1.4s infinite linear}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:var(--space-4) 0;transition:background-color var(--transition-slow),backdrop-filter var(--transition-slow),box-shadow var(--transition-slow),padding var(--transition-slow)}.navbar--scrolled{background-color:#f9f7f4f0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow-sm);padding:var(--space-3) 0}.navbar__container{max-width:var(--container-max);margin:0 auto;padding:0 var(--space-6);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.navbar__brand{display:flex;align-items:center;gap:var(--space-2);text-decoration:none;color:var(--colour-surface);transition:color var(--transition-fast)}.navbar--scrolled .navbar__brand{color:var(--colour-text-primary)}.navbar__brand-icon{font-size:var(--text-lg);color:var(--colour-gold-light);transition:color var(--transition-fast)}.navbar--scrolled .navbar__brand-icon{color:var(--colour-accent)}.navbar__brand-text{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;letter-spacing:.01em}.navbar__toggle{display:none;flex-direction:column;gap:5px;padding:var(--space-2);background:none;border:none;cursor:pointer}.navbar__toggle span{display:block;width:22px;height:2px;background-color:var(--colour-surface);transition:transform var(--transition-normal),opacity var(--transition-normal);border-radius:2px}.navbar--scrolled .navbar__toggle span{background-color:var(--colour-text-primary)}.navbar__toggle--open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.navbar__toggle--open span:nth-child(2){opacity:0}.navbar__toggle--open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.navbar__links{display:flex;align-items:center;gap:var(--space-8)}.navbar__link{font-size:var(--text-sm);font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:#ffffffd9;text-decoration:none;position:relative;padding-bottom:2px;transition:color var(--transition-fast)}.navbar__link:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:1px;background-color:var(--colour-gold-light);transform:scaleX(0);transition:transform var(--transition-normal)}.navbar__link:hover,.navbar__link--active{color:#fff}.navbar--scrolled .navbar__link{color:var(--colour-text-secondary)}.navbar--scrolled .navbar__link:hover,.navbar--scrolled .navbar__link--active{color:var(--colour-accent)}.navbar__link:hover:after,.navbar__link--active:after{transform:scaleX(1)}.navbar--scrolled .navbar__link:after{background-color:var(--colour-accent)}.splash{position:relative;min-height:70vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background-color:#141d27}.splash:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:var(--splash-bg, none);background-size:cover;background-position:center var(--splash-bg-y, 50%);background-repeat:no-repeat;background-attachment:fixed;opacity:0;transition:opacity .6s ease}.splash--bg-loaded:before{opacity:1}.splash__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#0e0a06b8,#5a141e80 60%,#0e0a0699)}.splash__content{position:relative;z-index:1;padding:var(--space-20) var(--space-6);max-width:680px;margin:0 auto}.splash__eyebrow{font-size:var(--text-xs);font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--colour-gold-light);margin-bottom:var(--space-4)}.splash__title{font-family:var(--font-display);font-size:clamp(var(--text-3xl),6vw,4.5rem);font-weight:700;color:#fff;text-shadow:0 2px 20px rgba(0,0,0,.5);margin-bottom:var(--space-4);letter-spacing:-.01em}.splash__subtitle{font-size:var(--text-md);color:#fffc;margin-bottom:var(--space-8);font-style:italic;font-family:var(--font-display)}.splash__cta{display:inline-block;padding:var(--space-3) var(--space-8);background-color:var(--colour-accent);color:#fff;font-size:var(--text-sm);font-weight:600;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;border-radius:var(--radius-sm);box-shadow:0 4px 20px #8b263573;transition:background-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.splash__cta:hover{background-color:var(--colour-accent-dark);color:#fff;transform:translateY(-1px);box-shadow:0 6px 24px #8b26358c}.site-main{padding:var(--space-10) 0 var(--space-16)}.site-main__container{max-width:var(--container-max);margin:0 auto;padding:0 var(--space-6);display:grid;grid-template-columns:1fr var(--sidebar-width);gap:var(--space-8);align-items:start}@media(max-width:900px){.site-main__container{grid-template-columns:1fr;order:1}.site-main__sidebar-area{order:2}}.page-content{display:flex;flex-direction:column;gap:var(--space-6)}.article-card{background-color:var(--colour-surface);border:1px solid var(--colour-border);border-radius:var(--radius-lg);padding:var(--space-8);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-normal)}.article-card:hover{box-shadow:var(--shadow-md)}.article-card__intro-layout{display:flex;gap:var(--space-6);align-items:flex-start}.article-card__intro-image{flex-shrink:0}.article-card__intro-text{flex:1}.article-card__welcome{font-size:var(--text-2xl);color:var(--colour-accent);margin-bottom:var(--space-4)}.article-card__feature-layout{display:flex;gap:var(--space-8);align-items:flex-start}.article-card__feature-image{flex-shrink:0;width:200px}.article-card__feature-text{flex:1}.article-card__heading{font-size:var(--text-xl);color:var(--colour-accent);margin-bottom:var(--space-2)}.article-card__subheading{font-size:var(--text-md);color:var(--colour-text-secondary);font-style:italic;margin-bottom:var(--space-4);font-family:var(--font-display)}.article-card__cta{display:inline-block;margin-top:var(--space-4);padding:var(--space-2) var(--space-5);background-color:var(--colour-accent);color:#fff;font-size:var(--text-sm);font-weight:600;border-radius:var(--radius-sm);text-decoration:none;transition:background-color var(--transition-fast),transform var(--transition-fast)}.article-card__cta:hover{background-color:var(--colour-accent-dark);color:#fff;transform:translateY(-1px)}.article-card__cta--outline{background-color:transparent;color:var(--colour-accent);border:1.5px solid var(--colour-accent)}.article-card__cta--outline:hover{background-color:var(--colour-accent);color:#fff}@media(max-width:600px){.article-card__intro-layout,.article-card__feature-layout{flex-direction:column}.article-card__feature-image{width:100%}.article-card{padding:var(--space-5)}}.about-card__name{font-size:var(--text-3xl);color:var(--colour-accent);margin-bottom:var(--space-1)}.about-card__pen-name{font-size:var(--text-md);color:var(--colour-text-muted);margin-bottom:var(--space-6)}.about-card__layout{display:flex;gap:var(--space-8);align-items:flex-start}.about-card__image-col{flex-shrink:0}.about-card__bio-col{flex:1}.about-card__contact{margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid var(--colour-border)}.about-card__contact h3{font-size:var(--text-lg);margin-bottom:var(--space-4)}.about-card__email-link,.about-card__social-link{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background-color:var(--colour-surface-alt);border:1px solid var(--colour-border);border-radius:var(--radius-md);color:var(--colour-text-primary);font-size:var(--text-sm);font-weight:500;text-decoration:none;margin-right:var(--space-3);margin-bottom:var(--space-3);transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.about-card__email-link:hover,.about-card__social-link:hover{background-color:var(--colour-accent);border-color:var(--colour-accent);color:#fff}@media(max-width:600px){.about-card__layout{flex-direction:column}}.book-detail-card__title{font-size:var(--text-3xl);color:var(--colour-accent);margin-bottom:var(--space-1)}.book-detail-card__author{font-size:var(--text-md);color:var(--colour-text-secondary);font-style:italic;margin-bottom:var(--space-6);font-family:var(--font-display)}.book-detail-card__images{display:flex;gap:var(--space-6);flex-wrap:wrap;margin-bottom:var(--space-8)}.book-detail-card__image-wrap{flex:0 0 auto;max-width:240px}.book-detail-card__description{margin-bottom:var(--space-8);padding:var(--space-6);background-color:var(--colour-surface-alt);border-radius:var(--radius-md);border-left:4px solid var(--colour-accent)}.book-detail-card__desc-heading{font-size:var(--text-lg);color:var(--colour-accent-dark);margin-bottom:var(--space-4)}.book-detail-card__meta{margin-bottom:var(--space-8)}.book-detail-card__meta-grid{display:grid;grid-template-columns:max-content 1fr;gap:var(--space-2) var(--space-5);margin-bottom:var(--space-6);max-width:400px}.book-detail-card__meta-label{font-size:var(--text-sm);font-weight:600;color:var(--colour-text-muted);text-transform:uppercase;letter-spacing:.06em}.book-detail-card__meta-value{font-size:var(--text-sm);color:var(--colour-text-primary)}.book-detail-card__buy-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-8);background-color:var(--colour-accent);color:#fff;font-size:var(--text-sm);font-weight:600;letter-spacing:.04em;text-decoration:none;border-radius:var(--radius-sm);box-shadow:0 4px 16px #8b263559;transition:background-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.book-detail-card__buy-btn:hover{background-color:var(--colour-accent-dark);color:#fff;transform:translateY(-1px);box-shadow:0 6px 20px #8b263573}.book-detail-card__back{padding-top:var(--space-6);border-top:1px solid var(--colour-border)}.not-found-card{text-align:center;padding:var(--space-16) var(--space-8);background-color:var(--colour-surface);border-radius:var(--radius-lg);border:1px solid var(--colour-border)}.not-found-card h1{font-size:var(--text-2xl);margin-bottom:var(--space-3)}.not-found-card p{color:var(--colour-text-secondary);margin-bottom:var(--space-6)}.sidebar{background-color:var(--colour-surface);border:1px solid var(--colour-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-sm);position:sticky;top:90px}.sidebar__header{margin-bottom:var(--space-5)}.sidebar__title{font-size:var(--text-lg);color:var(--colour-accent);margin-bottom:var(--space-3)}.sidebar__divider{height:2px;background:linear-gradient(90deg,var(--colour-accent),transparent);border-radius:2px}.sidebar__list{list-style:none;display:flex;flex-direction:column;gap:var(--space-6)}.sidebar__item{display:flex;flex-direction:column;gap:var(--space-2)}.sidebar__book-name{font-size:var(--text-sm);font-weight:600;color:var(--colour-text-primary);font-family:var(--font-display)}.sidebar__thumb-btn{position:relative;background:none;border:none;padding:0;cursor:pointer;border-radius:var(--radius-md);overflow:hidden;width:130px;transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.sidebar__thumb-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.sidebar__thumb{border-radius:var(--radius-md)}.sidebar__thumb-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background-color:#8b2635cc;color:#fff;font-size:var(--text-xs);font-weight:600;letter-spacing:.08em;text-transform:uppercase;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-normal);border-radius:var(--radius-md)}.sidebar__thumb-btn:hover .sidebar__thumb-overlay,.sidebar__thumb-btn:focus-visible .sidebar__thumb-overlay{opacity:1}.sidebar__buy-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background-color:var(--colour-accent);color:#fff;font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;text-transform:uppercase;text-decoration:none;border-radius:var(--radius-sm);width:fit-content;transition:background-color var(--transition-fast)}.sidebar__buy-btn:hover{background-color:var(--colour-accent-dark);color:#fff}.footer{background-color:var(--colour-text-primary);color:#ffffffb3;padding:var(--space-10) 0}.footer__inner{max-width:var(--container-max);margin:0 auto;padding:0 var(--space-6);display:flex;flex-direction:column;align-items:center;gap:var(--space-4);text-align:center}.footer__links{display:flex;gap:var(--space-6);flex-wrap:wrap;justify-content:center}.footer__link{color:#ffffffb3;font-size:var(--text-sm);text-decoration:none;text-transform:uppercase;letter-spacing:.08em;transition:color var(--transition-fast)}.footer__link:hover{color:var(--colour-gold-light)}.footer__copy{font-size:var(--text-xs);color:#ffffff73;margin-bottom:0}:focus-visible{outline:2px solid var(--colour-accent);outline-offset:3px}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--colour-bg)}::-webkit-scrollbar-thumb{background-color:var(--colour-border);border-radius:4px;border:2px solid var(--colour-bg)}::-webkit-scrollbar-thumb:hover{background-color:var(--colour-text-muted)}@media(max-width:768px){.navbar__toggle{display:flex}.navbar__links{display:none;flex-direction:column;position:absolute;top:100%;left:0;right:0;background-color:var(--colour-surface);padding:var(--space-4);gap:var(--space-4);box-shadow:var(--shadow-md);border-top:1px solid var(--colour-border)}.navbar__links--open{display:flex}.navbar__link{color:var(--colour-text-secondary)}.navbar__link:hover,.navbar__link--active{color:var(--colour-accent)}.navbar__link:after{background-color:var(--colour-accent)}.splash{min-height:55vh}.splash:before{background-attachment:scroll}.splash__content{padding:var(--space-16) var(--space-4)}.sidebar{position:static}.book-detail-card__images{flex-direction:column}.book-detail-card__image-wrap{max-width:200px}}@media(max-width:480px){.article-card,.sidebar{padding:var(--space-4)}.navbar__container{padding:0 var(--space-4)}}.group-main{min-height:calc(100vh - 120px);background:var(--color-bg, #faf8f4)}.group-page{max-width:680px;margin:0 auto;padding:2.5rem 1.5rem 4rem}.group-page--loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;min-height:40vh;color:#888}.group-loading__spinner{width:40px;height:40px;border:3px solid #ddd;border-top-color:#8b6b9e;border-radius:50%;animation:spin .7s linear infinite}.group-error{text-align:center;padding:3rem 1rem}.group-error__message{color:#c0392b;margin-bottom:1.25rem;font-size:1rem}.group-error__link{color:#8b6b9e;text-decoration:underline}.group-create{max-width:480px;margin:0 auto;text-align:center}.group-create__title{font-size:2rem;margin-bottom:.75rem;color:#2c2c2c}.group-create__subtitle{color:#666;line-height:1.6;margin-bottom:2rem}.group-create__form{display:flex;flex-direction:column;gap:.75rem;text-align:left}.group-create__label{font-weight:600;font-size:.9rem;color:#444}.group-create__input{padding:.7rem 1rem;border:1.5px solid #ccc;border-radius:6px;font-size:1rem;transition:border-color .2s;width:100%;box-sizing:border-box}.group-create__input:focus{outline:none;border-color:#8b6b9e;box-shadow:0 0 0 3px #8b6b9e26}.group-create__input--error{border-color:#c0392b}.group-create__error{color:#c0392b;font-size:.85rem;margin:0}.group-create__btn{margin-top:.5rem;padding:.8rem 1.5rem;background:#8b6b9e;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.group-create__btn:hover{background:#74569a}.group-header{margin-top:4rem;margin-bottom:2rem}.group-header__name{font-size:1.75rem;margin-bottom:.75rem;color:#2c2c2c}.group-header__name-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.group-header__name-row .group-header__name{margin-bottom:0}.group-header__name-edit-btn{background:none;border:none;color:#8b6b9e;cursor:pointer;padding:.25rem;display:flex;align-items:center;opacity:.65;transition:opacity .15s,background .15s;border-radius:4px;flex-shrink:0}.group-header__name-edit-btn:hover{opacity:1;background:#f5f0fa}.group-header__name-edit{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.group-header__name-input{font-size:1.5rem;font-weight:700;color:#2c2c2c;font-family:inherit;border:1.5px solid #8b6b9e;border-radius:6px;padding:.2rem .5rem;outline:none;flex:1;min-width:0;box-shadow:0 0 0 3px #8b6b9e26}.group-header__name-save-btn{padding:.35rem .85rem;background:#8b6b9e;color:#fff;border:none;border-radius:5px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap}.group-header__name-save-btn:hover:not(:disabled){background:#74569a}.group-header__name-save-btn:disabled{opacity:.6;cursor:not-allowed}.group-header__name-cancel-btn{padding:.35rem .75rem;background:none;color:#666;border:1.5px solid #ccc;border-radius:5px;font-size:.85rem;cursor:pointer;transition:border-color .2s;white-space:nowrap}.group-header__name-cancel-btn:hover:not(:disabled){border-color:#888}.group-header__name-error{color:#c0392b;font-size:.82rem;width:100%}.group-header__actions{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;justify-content:space-between}.group-header__share{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.group-header__share-label{font-size:.85rem;color:#888}.group-header__share-url{font-size:.8rem;background:#f0e9d8;padding:.25rem .5rem;border-radius:4px;color:#555;word-break:break-all}.group-header__copy-btn{font-size:.8rem;padding:.25rem .6rem;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer;transition:background .15s}.group-header__copy-btn:hover{background:#f5f0fa}.group-header__add-btn{padding:.5rem 1.1rem;background:#8b6b9e;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap}.group-header__add-btn:hover{background:#74569a}.group-birthdays__heading{font-size:1.1rem;font-weight:600;color:#444;margin-bottom:1.25rem;padding-bottom:.5rem;border-bottom:1px solid #e8e0d0}.birthday-list{display:flex;flex-direction:column;gap:.75rem}.birthday-list__empty{color:#999;font-style:italic;padding:1.5rem 0}.birthday-card{display:flex;align-items:center;gap:1rem;padding:.9rem 1rem;background:#fff;border:1px solid #e8e0d0;border-radius:8px;transition:box-shadow .15s}.birthday-card:hover{box-shadow:0 2px 8px #00000014}.birthday-card--urgent{border-color:#8b6b9e;background:#fdf9ff}.birthday-card__photo{width:52px;height:52px;border-radius:50%;object-fit:cover;flex-shrink:0;background:#f0e9d8}.birthday-card__info{flex:1;min-width:0}.birthday-card__name{display:block;font-weight:600;color:#2c2c2c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.birthday-card__date{display:block;font-size:.85rem;color:#888;margin-top:.15rem}.birthday-card__days{font-size:.85rem;font-weight:600;color:#666;white-space:nowrap}.birthday-card__days--today{color:#8b6b9e;font-size:1rem}.add-person-form{background:#fff;border:1px solid #e8e0d0;border-radius:10px;padding:2rem}.add-person-form__title{font-size:1.25rem;margin-bottom:1.5rem;color:#2c2c2c}.add-person-form__photo-section{display:flex;flex-direction:column;align-items:center;margin-bottom:1.75rem}.add-person-form__photo-btn{background:none;border:2px dashed #ccc;border-radius:50%;cursor:pointer;padding:0;width:90px;height:90px;overflow:hidden;position:relative;transition:border-color .2s;display:flex;align-items:center;justify-content:center}.add-person-form__photo-btn:hover{border-color:#8b6b9e}.add-person-form__photo-preview{width:100%;height:100%;object-fit:cover;border-radius:50%}.add-person-form__photo-label{position:absolute;bottom:0;left:0;right:0;background:#00000073;color:#fff;font-size:.7rem;text-align:center;padding:3px 0}.add-person-form__file-input{display:none}.add-person-form__camera-btn{display:none;align-items:center;gap:.4rem;margin-top:.5rem;padding:.45rem 1rem;background:#f5f0f8;color:#6b4f7d;border:1.5px solid #ccc;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .2s,border-color .2s}.add-person-form__camera-btn:hover{background:#ece4f1;border-color:#8b6b9e}@media(pointer:coarse){.add-person-form__camera-btn{display:inline-flex}}.add-person-form__fields{display:flex;flex-direction:column;gap:1.1rem}.add-person-form__field{display:flex;flex-direction:column;gap:.35rem}.add-person-form__field label{font-size:.9rem;font-weight:600;color:#444}.add-person-form__field input{padding:.65rem .85rem;border:1.5px solid #ccc;border-radius:6px;font-size:1rem;transition:border-color .2s}.add-person-form__field input:focus{outline:none;border-color:#8b6b9e;box-shadow:0 0 0 3px #8b6b9e26}.add-person-form__date-row{display:flex;gap:.5rem}.add-person-form__date-row select{padding:.65rem .85rem;border:1.5px solid #ccc;border-radius:6px;font-size:1rem;transition:border-color .2s;background:#fff;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;min-width:0}.add-person-form__date-row select:first-child{flex:3}.add-person-form__date-row select:nth-child(2){flex:4}.add-person-form__date-row select:last-child{flex:2}.add-person-form__date-row select:focus{outline:none;border-color:#8b6b9e;box-shadow:0 0 0 3px #8b6b9e26}.add-person-form__error{font-size:.82rem;color:#c0392b}.add-person-form__submit-error{color:#c0392b;font-size:.9rem;margin:1rem 0 0}.add-person-form__actions{display:flex;gap:.75rem;margin-top:1.75rem}.add-person-form__submit{padding:.75rem 1.5rem;background:#8b6b9e;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.add-person-form__submit:hover:not(:disabled){background:#74569a}.add-person-form__submit:disabled{opacity:.6;cursor:not-allowed}.add-person-form__spinner{display:inline-block;width:1em;height:1em;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle;margin-right:.5em}@keyframes spin{to{transform:rotate(360deg)}}.add-person-form__cancel{padding:.75rem 1.25rem;background:none;color:#666;border:1.5px solid #ccc;border-radius:6px;font-size:1rem;cursor:pointer;transition:border-color .2s}.add-person-form__cancel:hover:not(:disabled){border-color:#888}.add-person-form__remove-photo{margin-top:.5rem;background:none;border:none;color:#c0392b;font-size:.82rem;cursor:pointer;text-decoration:underline}.add-person-form__remove-photo:hover{color:#962d22}.group-header__btns{display:flex;gap:.5rem;flex-wrap:wrap}.group-header__members-btn{padding:.5rem 1.1rem;background:#fff;color:#8b6b9e;border:1.5px solid #8b6b9e;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s,color .2s;white-space:nowrap}.group-header__members-btn:hover{background:#f5f0fa}.group-header__back-btn{padding:.5rem 1.1rem;background:none;color:#666;border:1.5px solid #ccc;border-radius:6px;font-size:.9rem;cursor:pointer;transition:border-color .2s;white-space:nowrap}.group-header__back-btn:hover{border-color:#888}.group-members__heading{font-size:1.1rem;font-weight:600;color:#444;margin-bottom:1.25rem;padding-bottom:.5rem;border-bottom:1px solid #e8e0d0}.member-list{display:flex;flex-direction:column;gap:.75rem}.member-list__empty{color:#999;font-style:italic;padding:1.5rem 0}.member-card{display:flex;align-items:center;gap:1rem;padding:.9rem 1rem;background:#fff;border:1px solid #e8e0d0;border-radius:8px;transition:box-shadow .15s}.member-card:hover{box-shadow:0 2px 8px #00000014}.member-card__photo{width:52px;height:52px;border-radius:50%;object-fit:cover;flex-shrink:0;background:#f0e9d8}.member-card__info{flex:1;min-width:0}.member-card__name{display:block;font-weight:600;color:#2c2c2c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-card__full-name{display:block;font-size:.8rem;color:#999;margin-top:.1rem}.member-card__date{display:block;font-size:.85rem;color:#888;margin-top:.15rem}.member-card__actions{display:flex;gap:.4rem;flex-shrink:0}.member-card__edit-btn{padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;color:#8b6b9e;border:1.5px solid #8b6b9e;border-radius:5px;cursor:pointer;transition:background .15s;flex-shrink:0}.member-card__edit-btn:hover{background:#f5f0fa}.member-card__delete-btn{padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;color:#c0392b;border:1.5px solid #c0392b;border-radius:5px;cursor:pointer;transition:background .15s;flex-shrink:0}.member-card__delete-btn:hover{background:#fdf0ed}@media(max-width:480px){.group-page{padding:3rem 1rem}.add-person-form{padding:1.25rem}.group-header__actions{flex-direction:column;align-items:flex-start}}
