:root{color:#38241f;background:#fff8f2;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.auth-shell{min-height:100vh;padding:24px;display:grid;place-items:center;background:radial-gradient(circle at top left,rgba(242,109,91,.24),transparent 34rem),linear-gradient(145deg,#fff8f2,#fff1dc 58%,#e8f4ef)}.landing{width:min(1080px,100%);display:grid;gap:28px}.landing-hero,.auth-card{background:#ffffffe0;border:1px solid rgba(116,82,64,.13);border-radius:28px;padding:clamp(28px,6vw,64px);box-shadow:0 24px 80px #502d1c1f}.landing-hero h1,.auth-card h1,.page-header h1{margin:0;line-height:1.05;letter-spacing:0}.landing-hero h1{max-width:780px;font-size:clamp(2.45rem,8vw,5.8rem)}.landing-hero p,.auth-card p,.page-description,.quiet-copy{color:#6f5b54;line-height:1.65}.landing-hero p{max-width:650px;font-size:1.08rem}.feature-grid,.dashboard-grid,.details-grid,.profile-layout{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.feature-grid article,.panel{background:#fff;border:1px solid rgba(116,82,64,.13);border-radius:20px;padding:20px;box-shadow:0 14px 40px #502d1c14}.feature-grid h2,.panel h2,.event-card h3{margin:0 0 8px}.feature-grid p{margin:0;color:#6f5b54;line-height:1.5}.brand{display:inline-flex;align-items:center;gap:10px;font-weight:800}.landing-brand{margin-bottom:22px}.brand-mark{width:38px;height:38px;display:grid;place-items:center;border-radius:14px;background:#f26d5b;color:#fff8f2}.button-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}.button{min-height:44px;display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:999px;padding:0 18px;font-weight:750;cursor:pointer}.button.primary{background:#f26d5b;color:#fff8f2}.button.secondary{background:#ffe0b8;color:#38241f}.button.ghost{background:#f6efe8;color:#60463c}.button.danger{background:#ffe7e0;color:#9c302b}.full-width{width:100%}.muted{color:#79665e}.muted a,.text-link,.section-heading a{color:#b64d42;font-weight:750}.auth-card{width:min(440px,100%)}.auth-card h1{margin-top:26px;font-size:clamp(2rem,7vw,3rem)}.form{display:grid;gap:14px;margin:22px 0}.form-error{margin:0;border-radius:14px;background:#ffe7e0;color:#9c302b;padding:12px 14px;font-weight:700}.success-message{margin:0;border-radius:14px;background:#e8f4ef;color:#20524a;padding:12px 14px;font-weight:700}.panel-message{margin-top:12px}button:disabled{cursor:not-allowed;opacity:.68}.form label{display:grid;gap:8px;color:#60463c;font-weight:700}input,select,textarea{width:100%;border:1px solid #decfc4;border-radius:16px;background:#fffaf6;color:#38241f;padding:13px 14px}textarea{resize:vertical}.app-shell{min-height:100vh;background:#fff8f2}.app-content{min-height:100vh}.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:#fff8f2eb;border-bottom:1px solid rgba(116,82,64,.12);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.topbar-actions{display:inline-flex;align-items:center;gap:10px}.mini-user{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#60463c;font-weight:800}.icon-button{width:42px;height:42px;display:grid;place-items:center;border-radius:999px;background:#f26d5b;color:#fff}.page-frame{width:min(1120px,100%);margin:0 auto;padding:22px 18px 96px}.page-header{display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;align-items:flex-end;margin-bottom:22px}.page-header h1{font-size:clamp(2rem,7vw,4rem)}.eyebrow{margin:0 0 8px;color:#b64d42;font-weight:800;text-transform:uppercase;font-size:.78rem}.page-description{max-width:680px;margin:12px 0 0}.wide{grid-column:span 2}.section-heading{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:14px}.stack{display:grid;gap:12px}.event-card{min-height:96px;display:grid;grid-template-columns:70px 1fr;gap:14px;align-items:center;padding:14px;border:1px solid #eadbd0;border-radius:18px;background:#fffaf6}.event-card p{margin:0 0 10px;color:#79665e}.date-badge{width:64px;min-height:68px;display:grid;place-items:center;border-radius:18px;background:#e8f4ef;color:#20524a}.date-badge span{font-size:.75rem;font-weight:800}.date-badge strong{font-size:1.4rem}.pill{display:inline-flex;border-radius:999px;padding:5px 10px;background:#ffe0b8;color:#6b3a16;font-size:.83rem;font-weight:800}.status-cancelled{background:#f6efe8;color:#79665e}.avatar-row,.friend-list li{display:flex;align-items:center}.avatar-row{margin:16px 0}.avatar{width:42px;height:42px;display:inline-grid;place-items:center;border:3px solid #ffffff;border-radius:999px;background:#20524a;color:#f9f5ec;font-weight:850;margin-right:-8px}.avatar.large{width:92px;height:92px;margin:0 0 12px;font-size:2.2rem}.profile-card{text-align:center}.simple-list,.friend-list{list-style:none;margin:0;padding:0;display:grid;gap:12px}.simple-list li{display:grid;gap:4px;padding:14px 0;border-bottom:1px solid #efe2d8}.simple-list span{color:#79665e}.friend-list li{gap:12px;justify-content:space-between;padding:10px 0;border-bottom:1px solid #efe2d8}.compact-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.friend-list .avatar{margin-right:0}.inline-form{display:flex;gap:10px}.two-column{grid-template-columns:repeat(2,minmax(0,1fr))}.span-all{grid-column:1 / -1}.detail-list{margin:0;display:grid;gap:14px}.detail-list div{display:grid;gap:4px;padding-bottom:12px;border-bottom:1px solid #efe2d8}.detail-list dt{color:#79665e;font-weight:700}.detail-list dd{margin:0;font-weight:800}.button-grid{display:grid;gap:10px}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}.calendar-label{text-align:center;color:#79665e;font-size:.78rem}.calendar-day{aspect-ratio:1;display:grid;place-items:center;border:1px solid #eadbd0;border-radius:16px;background:#fffaf6;color:#38241f;font-weight:800}.calendar-day.has-event{background:#e8f4ef;border-color:#8fbcb0;color:#20524a}.photo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px}.photo-placeholder{aspect-ratio:4 / 3;display:grid;place-items:center;border-radius:18px;background:linear-gradient(145deg,#ffe0b8,#e8f4ef);color:#60463c;font-weight:800}.memory-photo{margin:0;overflow:hidden;border-radius:18px;background:#fffaf6;border:1px solid #eadbd0}.memory-photo img{width:100%;aspect-ratio:4 / 3;object-fit:cover;display:block}.memory-photo figcaption{padding:10px 12px;color:#60463c;font-weight:700}.memory-list{list-style:none;margin:0;padding:0;display:grid;gap:12px}.memory-list li{padding:16px;border-radius:18px;background:#fffaf6;border:1px solid #eadbd0}.memory-list p{margin:0 0 10px;line-height:1.6}.memory-list span{color:#79665e;font-weight:800}.sidebar{display:none}.bottom-nav{position:fixed;left:12px;right:12px;bottom:12px;z-index:20;display:grid;grid-template-columns:repeat(6,1fr);gap:6px;padding:8px;border:1px solid rgba(116,82,64,.14);border-radius:24px;background:#fffffff0;box-shadow:0 18px 45px #502d1c29;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.bottom-nav-link,.nav-link{display:flex;align-items:center;justify-content:center;gap:6px;border-radius:18px;color:#79665e;font-size:.72rem;font-weight:800}.nav-button{border:0;background:transparent;cursor:pointer;font:inherit}.bottom-nav-link{min-height:54px;flex-direction:column}.bottom-nav-link.active,.nav-link.active{background:#fff1dc;color:#b64d42}.primary-action{color:#20524a}.mobile-logout{color:#9c302b}.empty-state{margin:0;padding:22px;border-radius:18px;background:#fffaf6;color:#79665e;text-align:center}.empty-action{display:grid;justify-items:center;gap:12px}.empty-action p{margin:0}.loading-screen{min-height:100vh;display:grid;align-content:center;justify-items:center;gap:14px;padding:24px;background:#fff8f2;color:#6f5b54}.settings-logout{margin-top:20px}@media(max-width:720px){.wide{grid-column:span 1}.inline-form,.two-column{grid-template-columns:1fr;flex-direction:column}.page-action,.page-action .button{width:100%}}@media(min-width:900px){.app-shell{display:grid;grid-template-columns:248px 1fr}.sidebar{position:sticky;top:0;height:100vh;display:block;padding:24px 18px;border-right:1px solid rgba(116,82,64,.12);background:#fffaf6}.compact-brand{margin:0 0 28px}.side-nav{display:grid;gap:8px}.nav-link{min-height:48px;justify-content:flex-start;padding:0 14px;font-size:.95rem}.topbar,.bottom-nav{display:none}.page-frame{padding:38px}}
