@import url("https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700&display=swap");:root{--bg:#f8f7f5;--surface:#fff;--surface-soft:#faf8f5;--line:#e8dfd6;--line-soft:#f0e8df;--ink:#2d2620;--muted:#7d7470;--faint:#a89c92;--accent:#d4836c;--accent-dark:#c4745c;--earth:#8b6f4f;--ok:#2e7d32;--warn:#b45309;--danger:#c2185b;--friend:#7b1fa2;--shadow:0 2px 8px rgba(0,0,0,0.03)}*{box-sizing:border-box}body,html{min-height:100%;background:var(--bg)}body{margin:0;color:var(--ink);font-family:DM Sans,sans-serif;letter-spacing:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}.serif{font-family:"DM Serif Display",serif;font-weight:400}.brand-em{color:var(--accent);font-style:italic}.landing{min-height:100vh;display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,.78fr);padding-bottom:62px}.landing-left{min-height:calc(100vh - 62px);display:flex;flex-direction:column;justify-content:center;padding:64px clamp(28px,7vw,88px);background:linear-gradient(135deg,#f8f7f5,#ede7e0)}.landing-logo{font-family:"DM Serif Display",serif;font-size:28px;margin-bottom:56px;color:var(--accent)}.landing-logo em{color:var(--earth)}.landing h1{max-width:660px;margin:0 0 20px;font-family:"DM Serif Display",serif;font-size:clamp(42px,7vw,64px);font-weight:400;line-height:1.08}.landing-copy{max-width:620px;margin:0;color:#5d5450;font-size:18px;line-height:1.7;font-weight:300}.feature-list{display:grid;grid-gap:20px;gap:20px;margin-top:42px}.feature-item{display:flex;gap:15px;align-items:flex-start}.feature-icon{font-size:28px;width:34px}.feature-title{font-size:14px;font-weight:700}.feature-desc{margin-top:4px;font-size:12px;color:var(--muted)}.landing-right{min-height:calc(100vh - 62px);display:grid;place-items:center;padding:48px 28px;background:#fff}.auth-card{width:min(100%,390px);border:1px solid var(--line);border-radius:20px;padding:36px;box-shadow:0 4px 20px rgba(0,0,0,.05)}.badge{display:inline-flex;align-items:center;gap:8px;border:1px solid #e0d4c6;border-radius:999px;padding:6px 14px;background:var(--line-soft);color:var(--earth);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.badge-dot{width:6px;height:6px;border-radius:99px;background:var(--accent);box-shadow:0 0 6px rgba(212,131,108,.4)}.card-title{margin:24px 0 18px;text-align:center;color:#5d5450;font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.danger-btn,.ghost-btn,.primary-btn,.secondary-btn,.small-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:10px;border:1px solid var(--line);min-height:40px;padding:10px 14px;font-weight:700;transition:.2s ease}.primary-btn{width:100%;color:#fff;background:var(--accent);border-color:var(--accent)}.primary-btn:hover{background:var(--accent-dark);border-color:var(--accent-dark)}.secondary-btn{background:var(--bg);color:var(--ink)}.ghost-btn:hover,.secondary-btn:hover{background:var(--line-soft);border-color:var(--accent)}.ghost-btn,.small-btn{background:#fff;color:#5d5450}.small-btn{min-height:32px;padding:6px 10px;border-radius:8px;font-size:12px}.danger-btn{background:#fce4ec;border-color:#f8bbd0;color:var(--danger)}.auth-stack{display:grid;grid-gap:10px;gap:10px}.footer-note{margin:18px 0 0;font-size:11px;line-height:1.6}.footer-note,.site-footer{color:var(--faint);text-align:center}.site-footer{position:fixed;left:0;right:0;bottom:0;border-top:1px solid var(--line);padding:16px;background:var(--bg);font-size:12px}.shell{min-height:100vh;display:grid;grid-template-columns:220px minmax(0,1fr)}.sidebar{position:-webkit-sticky;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;border-right:1px solid var(--line);background:#fff;box-shadow:var(--shadow)}.sidebar-logo{padding:24px 20px 20px;border-bottom:1px solid var(--line)}.logo-text{font-family:"DM Serif Display",serif;font-size:20px;line-height:1}.logo-sub{margin-top:4px;color:var(--faint);font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.nav{flex:1 1;overflow-y:auto;padding:16px 10px}.nav-section{margin:16px 12px 8px;color:var(--faint);font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.nav-item{display:flex;align-items:center;gap:10px;min-height:40px;padding:10px 12px;border-radius:10px;color:#5d5450;font-size:13px;transition:.2s ease}.nav-item.active,.nav-item:hover{background:var(--line-soft);color:var(--accent)}.nav-item.locked{opacity:.45}.nav-icon{width:20px;text-align:center}.user-block{display:flex;align-items:center;gap:10px;border-top:1px solid var(--line);padding:14px 16px}.avatar{width:34px;height:34px;flex:none;display:grid;place-items:center;border-radius:50%;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-dark))}.avatar,.user-name{font-size:12px;font-weight:700}.user-role{margin-top:2px;color:var(--faint);font-size:10px;word-break:break-word}.album-visibility,.role-badge,.status-pill,.tile-status{display:inline-flex;align-items:center;width:-moz-fit-content;width:fit-content;border-radius:10px;border:1px solid #e0d4c6;background:var(--line-soft);color:var(--accent);padding:3px 8px;font-size:10px;font-weight:700}.main{min-width:0;padding:28px 32px 40px;overflow:hidden}.topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:24px}.greeting{margin:0;font-family:"DM Serif Display",serif;font-size:26px;font-weight:400}.topbar-actions{display:flex;gap:10px;align-items:center}.icon-btn{width:36px;height:36px;display:grid;place-items:center;border:1px solid var(--line);border-radius:10px;background:#fff;color:#5d5450}.mobile-menu{display:none}.alert-banner,.pending-banner,.success-banner{display:flex;align-items:center;gap:10px;border-radius:12px;padding:12px 14px;margin-bottom:16px;font-size:12px;font-weight:700}.alert-banner,.pending-banner{background:#fef3c7;border:1px solid #fcd34d;color:#92400e}.success-banner{background:#e8f5e9;border:1px solid #c8e6c9;color:var(--ok)}.album-card,.mini-card,.panel,.service-card,.stat-card,.tile,.weather-card{border:1px solid var(--line);border-radius:12px;background:#fff;box-shadow:var(--shadow)}.weather-card{justify-content:space-between;gap:18px;padding:18px 20px;margin-bottom:24px;background:linear-gradient(135deg,#fff,#faf8f5)}.weather-card,.weather-left{display:flex;align-items:center}.weather-left{gap:14px}.weather-icon{font-size:32px}.weather-temp{font-family:"DM Serif Display",serif;font-size:34px;line-height:1}.muted,.weather-desc,.weather-stats{color:var(--muted);font-size:12px}.weather-right{text-align:right}.weather-city{font-weight:700;font-size:13px}.weather-stats{display:flex;gap:16px;margin-top:8px}.section-label{margin:22px 0 12px;color:var(--faint);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.tiles{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:12px;gap:12px}.tile{min-height:156px;display:flex;flex-direction:column;align-items:flex-start;padding:18px;transition:.2s ease}.tile:hover{border-color:var(--accent);background:var(--surface-soft);box-shadow:0 4px 12px rgba(212,131,108,.1)}.tile-icon{font-size:28px;margin-bottom:12px}.tile-name{font-size:13px;font-weight:700}.tile-desc{margin-top:4px;color:var(--muted);font-size:11px;line-height:1.4}.tile-status{margin-top:auto}.status-live{background:#e8f5e9;color:var(--ok);border-color:#c8e6c9}.status-soon{background:var(--line-soft);color:var(--earth)}.status-admin{background:#fce4ec;color:var(--danger);border-color:#f8bbd0}.bottom-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:14px;gap:14px;margin-top:24px}.mini-card{padding:18px}.mini-card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:12px;margin-bottom:14px;border-bottom:1px solid var(--line-soft)}.mini-card-title{color:#5d5450;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.event-item,.link-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--line-soft)}.event-item:last-child,.link-item:last-child{border-bottom:0}.event-title,.link-name{font-size:12px;font-weight:700}.event-meta{margin-top:2px;color:var(--faint);font-size:11px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:20px}.page-kicker{color:var(--faint);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.page-title{margin:6px 0;font-family:"DM Serif Display",serif;font-size:30px;font-weight:400}.page-copy{margin:0;color:var(--muted);font-size:13px;line-height:1.6;max-width:760px}.panel{padding:22px}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px;padding-bottom:16px;border-bottom:1px solid var(--line-soft)}.panel-title{margin:0;font-size:16px;font-weight:700}.service-grid,.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:12px;gap:12px}.service-card,.stat-card{padding:16px}.service-card h3{margin:0 0 8px;font-size:14px}.service-card p,.stat-label{margin:0;color:var(--muted);font-size:12px;line-height:1.5}.stat-num{font-family:"DM Serif Display",serif;font-size:30px}.filter-tabs,.filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}.filter-pill,.filter-tab{border:1px solid var(--line);border-radius:999px;background:#fff;padding:7px 14px;color:#5d5450;font-size:12px;font-weight:700}.filter-pill.active,.filter-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:12px;background:#fff}.table{width:100%;min-width:760px;border-collapse:collapse}.table th{padding:12px 16px;background:var(--surface-soft);color:var(--faint);font-size:10px;letter-spacing:.08em;text-align:left;text-transform:uppercase}.table td,.table th{border-bottom:1px solid var(--line-soft)}.table td{padding:14px 16px;color:#5d5450;font-size:12px;vertical-align:middle}.table tr:last-child td{border-bottom:0}.user-cell{display:flex;align-items:center;gap:12px}.user-cell strong{display:block;color:var(--ink);font-size:13px}.role-admin{background:#fce4ec;color:var(--danger);border-color:#f8bbd0}.role-family{background:#e8f5e9;color:var(--ok);border-color:#c8e6c9}.role-relative{background:var(--line-soft);color:var(--earth)}.role-friend{background:#f3e5f5;color:var(--friend);border-color:#e1bee7}.role-guest{background:#fef3c7;color:var(--warn);border-color:#fcd34d}.form-grid{display:grid;grid-gap:12px;gap:12px}.field{display:grid;grid-gap:6px;gap:6px}.field label{color:#5d5450;font-size:12px;font-weight:700}.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:10px;background:var(--bg);padding:11px 12px;color:var(--ink);outline:0}.field textarea{min-height:96px;resize:vertical}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);background:#fff}.albums-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));grid-gap:16px;gap:16px}.album-card{overflow:hidden}.album-cover{height:158px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;font-size:44px}.album-info{padding:16px}.album-name{margin-bottom:8px;font-size:13px;font-weight:700}.album-creator,.album-meta{color:var(--faint);font-size:11px}.album-actions{display:flex;gap:6px;margin-top:12px;padding-top:10px;border-top:1px solid var(--line-soft)}.tree-board{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));grid-gap:14px;gap:14px}.person-card{border:1px solid var(--line);border-radius:12px;background:#fff;padding:16px}.person-card strong{display:block;margin-bottom:4px}.person-card p{margin:0;color:var(--muted);font-size:12px;line-height:1.5}@media (max-width:1000px){.tiles{grid-template-columns:repeat(2,minmax(0,1fr))}.landing{grid-template-columns:1fr}.landing-left,.landing-right{min-height:auto}.site-footer{position:static}.landing{padding-bottom:0}}@media (max-width:760px){.shell{grid-template-columns:1fr}.sidebar{position:static;height:auto;border-right:0;border-bottom:1px solid var(--line)}.nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));padding-bottom:8px}.nav-section{grid-column:1/-1}.user-block{display:none}.main{padding:22px 16px 34px}.topbar{align-items:flex-start}.topbar-actions .icon-btn{display:none}.page-header,.panel-header,.weather-card{align-items:flex-start;flex-direction:column}.weather-right{text-align:left}.weather-stats{flex-wrap:wrap}.bottom-row,.tiles{grid-template-columns:1fr}.tile{min-height:132px}.auth-card{padding:26px}}