:root{--paper:#f3f0ea;--surface:#fbfaf7;--ink:#171716;--muted:#77736d;--line:#d9d4cc;--accent:#ff6c45;--lime:#c8dd72;--blue:#9dcbd0;--rose:#e6a7a2;--violet:#a7a1cc;--danger:#b43d37;--display:'Iowan Old Style','Palatino Linotype',Georgia,serif;--body:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;--mono:ui-monospace,'SFMono-Regular',Consolas,monospace;--safe:env(safe-area-inset-bottom,0px);--shadow:0 22px 70px color-mix(in oklch,var(--ink) 16%,transparent)}
*{box-sizing:border-box}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--body);line-height:1.5;-webkit-font-smoothing:antialiased}button,input,textarea,select{font:inherit}button{cursor:pointer}img,video{display:block;max-width:100%}svg{display:block;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}h1,h2,h3,p{margin-top:0}h1,h2,h3{font-family:var(--display);font-weight:500;letter-spacing:-.025em;text-wrap:balance}[hidden]{display:none!important}.muted{color:var(--muted)}.kicker{margin:0 0 7px;color:var(--muted);font:600 10px/1.3 var(--mono);letter-spacing:.12em;text-transform:uppercase}.count{font:12px var(--mono);color:var(--muted)}
.app{min-height:100dvh;padding-bottom:calc(82px + var(--safe))}.app-header{position:sticky;top:0;z-index:30;display:grid;grid-template-columns:44px 1fr 44px;align-items:center;min-height:66px;padding:8px max(14px,calc((100vw - 1100px)/2));background:color-mix(in oklch,var(--paper) 90%,transparent);border-bottom:1px solid color-mix(in oklch,var(--line) 70%,transparent);backdrop-filter:blur(18px)}.profile-button,.icon-button,.close-button{display:grid;width:42px;height:42px;padding:0;place-items:center;border:1px solid var(--line);border-radius:50%;background:var(--surface);color:var(--ink)}.profile-button span{font:20px var(--display)}.icon-button{position:relative}.icon-button svg{width:20px}.icon-button i{position:absolute;right:2px;bottom:3px;width:8px;height:8px;border:2px solid var(--paper);border-radius:50%;background:var(--lime)}.icon-button i.pending{background:var(--accent)}.month-switcher{border:0;background:none;text-align:center}.month-switcher span{display:block;font:600 14px var(--body)}.month-switcher small{color:var(--muted);font-size:11px}
.screen{display:none;width:min(100%,1100px);margin:auto;padding:18px 16px 56px;animation:reveal .3s ease}.screen.active{display:block}@keyframes reveal{from{opacity:0;transform:translateY(6px)}}
.month-cover{position:relative;display:grid;grid-template-columns:1fr 1.2fr;grid-template-rows:1fr auto;gap:26px;min-height:min(76dvh,760px);overflow:hidden;padding:clamp(24px,5vw,64px);border-radius:30px;background:var(--ink);color:var(--surface);isolation:isolate}.cover-copy{z-index:2;align-self:end}.cover-number{font:11px var(--mono);letter-spacing:.14em}.cover-copy h1{margin:0;font-size:clamp(60px,10vw,134px);line-height:.82}.cover-copy p:last-child{margin:20px 0 0;color:color-mix(in oklch,var(--surface) 70%,transparent)}.cover-photo{z-index:1;grid-row:1/3;grid-column:2;overflow:hidden;border-radius:20px;background:color-mix(in oklch,var(--surface) 8%,transparent)}.cover-photo img{width:100%;height:100%;object-fit:cover}.cover-photo.placeholder{display:grid;place-items:center;color:color-mix(in oklch,var(--surface) 45%,transparent);font:11px var(--mono);letter-spacing:.08em;text-transform:uppercase}.cover-edit{z-index:3;align-self:end;justify-self:start;padding:10px 14px;border:1px solid color-mix(in oklch,var(--surface) 30%,transparent);border-radius:999px;background:transparent;color:var(--surface);font-size:12px}.cover-orb{position:absolute;z-index:-1;border-radius:48% 52% 60% 40%;filter:blur(1px);opacity:.85}.orb-one{width:42vw;height:42vw;max-width:520px;max-height:520px;top:-20%;left:-8%;background:var(--accent);transform:rotate(18deg)}.orb-two{width:32vw;height:32vw;max-width:420px;max-height:420px;right:30%;bottom:-25%;background:var(--lime);opacity:.42}.season-winter .orb-one{background:var(--blue)}.season-spring .orb-one{background:var(--lime)}.season-autumn .orb-one{background:var(--rose)}
.content-section,.calendar-ribbon-section,.feature-strip,.family-section{padding:clamp(58px,8vw,100px) 2px;border-bottom:1px solid var(--line)}.section-title{display:flex;align-items:end;justify-content:space-between;gap:20px;margin-bottom:34px}.section-title.compact{align-items:center;margin-bottom:20px}.section-title h2,.family-section h2{margin:0;font-size:clamp(34px,5vw,62px);line-height:1}.text-button{padding:7px 0;border:0;border-bottom:1px solid var(--ink);background:none;font-size:13px}.featured-grid{display:grid;grid-template-columns:1.35fr 1fr;gap:14px}.featured-grid .moment-card:first-child{grid-row:span 2;min-height:520px}.editorial-empty{padding:44px;border:1px dashed var(--line);border-radius:20px;color:var(--muted);text-align:center}.editorial-empty p{margin:0}.moment-card{position:relative;display:flex;min-height:250px;overflow:hidden;border-radius:18px;background:var(--surface);cursor:pointer}.moment-card.has-media{color:var(--surface)}.moment-card img,.moment-card video{position:absolute;width:100%;height:100%;object-fit:cover}.moment-card::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,color-mix(in oklch,var(--ink) 75%,transparent),transparent 70%);opacity:0}.moment-card.has-media::after{opacity:1}.moment-card-copy{z-index:1;align-self:end;padding:22px}.moment-card h3{margin:5px 0 0;font-size:clamp(23px,3vw,38px);line-height:1}.moment-card .card-date{font:10px var(--mono);letter-spacing:.08em;text-transform:uppercase}.moment-card .card-mark{position:absolute;z-index:2;top:14px;right:14px;display:grid;width:34px;height:34px;place-items:center;border:0;border-radius:50%;background:color-mix(in oklch,var(--surface) 80%,transparent);color:var(--ink)}
.calendar-ribbon{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;scrollbar-width:none}.day-chip{display:grid;flex:0 0 54px;min-height:72px;padding:9px 5px;place-items:center;border:1px solid var(--line);border-radius:999px;background:var(--surface);color:var(--muted)}.day-chip strong{font:18px var(--display);color:var(--ink)}.day-chip small{font:9px var(--mono);text-transform:uppercase}.day-chip.has-moment{border-color:var(--ink);background:var(--ink);color:var(--surface)}.day-chip.has-moment strong{color:var(--surface)}.day-chip.today{box-shadow:inset 0 0 0 2px var(--accent)}
.media-mosaic{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:80px;gap:8px}.media-tile{position:relative;overflow:hidden;border-radius:14px;background:var(--line)}.media-tile:nth-child(5n+1){grid-column:span 7;grid-row:span 4}.media-tile:nth-child(5n+2){grid-column:span 5;grid-row:span 2}.media-tile:nth-child(5n+3){grid-column:span 5;grid-row:span 2}.media-tile:nth-child(5n+4),.media-tile:nth-child(5n+5){grid-column:span 6;grid-row:span 3}.media-tile img,.media-tile video{width:100%;height:100%;object-fit:cover}.media-type{position:absolute;right:8px;bottom:8px;padding:4px 7px;border-radius:999px;background:color-mix(in oklch,var(--ink) 70%,transparent);color:var(--surface);font:9px var(--mono);text-transform:uppercase}.audio-tile{display:grid;place-items:center;background:var(--blue);color:var(--ink)}.audio-wave{font:28px var(--mono);letter-spacing:-5px}
.moments-feed{display:grid;gap:0}.story-row{display:grid;grid-template-columns:120px minmax(0,1fr) 220px;gap:30px;padding:34px 0;border-top:1px solid var(--line);cursor:pointer}.story-row:first-child{border-top-color:var(--ink)}.story-date{font:10px var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.story-body h3{margin:0 0 8px;font-size:clamp(25px,3vw,38px);line-height:1.1}.story-body p{margin:0;color:var(--muted)}.story-thumb{height:145px;overflow:hidden;border-radius:12px;background:var(--line)}.story-thumb img,.story-thumb video{width:100%;height:100%;object-fit:cover}.story-badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:13px}.badge{padding:4px 8px;border:1px solid var(--line);border-radius:999px;font:9px var(--mono);text-transform:uppercase}.badge.accent{border-color:var(--accent);color:var(--accent)}.big-empty{padding:80px 18px;text-align:center}.empty-index{display:block;margin-bottom:14px;color:var(--accent);font:12px var(--mono)}.big-empty h3{margin-bottom:10px;font-size:34px}.big-empty p{max-width:40ch;margin:0 auto 25px;color:var(--muted)}
.month-portrait{margin:70px 0 0;padding:clamp(32px,6vw,76px);border-radius:28px;background:var(--lime)}.month-portrait h2{max-width:12ch;font-size:clamp(45px,7vw,86px);line-height:.95}.portrait-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin:50px 0;background:color-mix(in oklch,var(--ink) 18%,transparent)}.portrait-item{min-height:150px;padding:20px;background:var(--lime)}.portrait-item span{font:10px var(--mono);text-transform:uppercase}.portrait-item strong{display:block;margin-top:20px;font:25px var(--display)}.family-section{border:0}.message-card{max-width:720px;padding:28px 0;border-top:1px solid var(--ink)}.message-card blockquote{margin:0;font:clamp(22px,3vw,32px)/1.35 var(--display)}.message-card cite{display:block;margin-top:12px;color:var(--muted);font:11px var(--mono);font-style:normal}.feature-strip{margin-top:40px}.feature-strip h3{font-size:34px}
.page-header{padding:clamp(40px,8vw,90px) 0}.page-header h1{margin:0 0 15px;font-size:clamp(64px,12vw,150px);line-height:.8}.page-header>p:last-child{max-width:52ch;color:var(--muted)}.year-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.month-tile{position:relative;display:flex;min-height:380px;overflow:hidden;padding:22px;align-items:end;border:0;border-radius:20px;background:var(--ink);color:var(--surface);text-align:left}.month-tile:nth-child(4n+2){background:var(--blue);color:var(--ink)}.month-tile:nth-child(4n+3){background:var(--lime);color:var(--ink)}.month-tile:nth-child(4n){background:var(--rose);color:var(--ink)}.month-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.month-tile::after{content:'';position:absolute;inset:0;background:linear-gradient(transparent,color-mix(in oklch,var(--ink) 60%,transparent))}.month-tile-copy{z-index:1}.month-tile h2{margin:0;font-size:42px}.month-tile small{font:10px var(--mono)}
.growth-progress{display:grid;grid-template-columns:180px 1fr;gap:30px;align-items:end;padding-bottom:50px;border-bottom:1px solid var(--ink)}.growth-progress span{display:block;font:80px/1 var(--display)}.growth-progress small{color:var(--muted)}.progress-line{height:3px;background:var(--line)}.progress-line i{display:block;width:0;height:100%;background:var(--accent);transition:width .4s}.age-chapter{display:grid;grid-template-columns:180px 1fr;gap:30px;padding:46px 0;border-bottom:1px solid var(--line)}.age-chapter h2{font-size:42px}.milestone-list{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.milestone-button{display:flex;gap:12px;align-items:center;padding:13px;border:1px solid var(--line);border-radius:12px;background:var(--surface);text-align:left}.milestone-button i{width:9px;height:9px;flex:0 0 9px;border:1px solid var(--muted);border-radius:50%}.milestone-button.done{border-color:var(--ink)}.milestone-button.done i{border-color:var(--accent);background:var(--accent)}.milestone-button span{font-size:13px}
.search-box{display:flex;align-items:center;gap:10px;padding:0 18px;border-bottom:1px solid var(--ink);background:transparent}.search-box svg{width:23px}.search-box input{width:100%;height:66px;border:0;outline:0;background:transparent;font:clamp(22px,4vw,38px) var(--display)}.search-filters,.rediscovery-buttons{display:flex;gap:9px;margin-top:15px}.search-results{margin-top:44px}.search-result{display:grid;grid-template-columns:110px 1fr auto;gap:20px;padding:22px 0;border-top:1px solid var(--line);cursor:pointer}.search-result h3{margin:0;font-size:24px}.search-result p{margin:5px 0 0;color:var(--muted);font-size:13px}
.button{min-height:45px;padding:10px 17px;border:1px solid transparent;border-radius:999px;background:none;color:var(--ink);font-weight:650}.button.primary{background:var(--accent);color:var(--surface)}.button.secondary{border-color:var(--line);background:var(--surface)}.button.dark{background:var(--ink);color:var(--surface)}.button.ghost{color:var(--muted)}.button.danger{width:100%;border-color:color-mix(in oklch,var(--danger) 35%,transparent);color:var(--danger)}.button.small{min-height:38px;padding:7px 13px;font-size:12px}.form-stack{display:grid;gap:15px}.control{width:100%;min-height:47px;padding:11px 13px;border:1px solid var(--line);border-radius:11px;outline:0;background:var(--surface);color:var(--ink)}.control:focus{border-color:var(--ink);box-shadow:0 0 0 3px color-mix(in oklch,var(--ink) 8%,transparent)}.textarea{resize:vertical}.title-control{font:24px var(--display)}label{display:grid;gap:6px;color:var(--muted);font-size:12px}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.bottom-nav{position:fixed;right:0;bottom:0;left:0;z-index:35;display:grid;grid-template-columns:repeat(5,1fr);height:calc(70px + var(--safe));padding:5px max(8px,calc((100vw - 620px)/2)) var(--safe);border-top:1px solid var(--line);background:color-mix(in oklch,var(--surface) 92%,transparent);backdrop-filter:blur(18px)}.nav-item{position:relative;display:grid;place-items:center;align-content:center;gap:3px;border:0;background:none;color:var(--muted);font-size:10px}.nav-item svg{width:21px;height:21px}.nav-item.active{color:var(--ink)}.nav-item.active::before{content:'';position:absolute;top:0;width:20px;height:2px;background:var(--accent)}.capture-fab{position:fixed;z-index:40;bottom:calc(32px + var(--safe));left:50%;display:grid;width:60px;height:60px;padding:0;place-items:center;transform:translate(-50%,50%);border:6px solid var(--surface);border-radius:50%;background:var(--accent);color:var(--surface);box-shadow:0 10px 30px color-mix(in oklch,var(--ink) 18%,transparent)}.capture-fab span{font-size:30px;font-weight:300}
dialog{color:var(--ink)}dialog::backdrop{background:color-mix(in oklch,var(--ink) 45%,transparent);backdrop-filter:blur(4px)}.sheet{width:min(100%,720px);max-width:none;margin:auto auto 0;padding:0;border:0;border-radius:26px 26px 0 0;background:var(--paper);box-shadow:var(--shadow)}.sheet[open],.modal[open]{animation:sheet-in .22s ease}@keyframes sheet-in{from{opacity:0;transform:translateY(20px)}}.sheet-head,.modal-head{display:flex;align-items:center;justify-content:space-between;gap:15px;padding:20px}.sheet-head h2,.modal-head h2{margin:0;font-size:31px}.sheet-head.sticky{position:sticky;top:0;z-index:3;border-bottom:1px solid var(--line);background:color-mix(in oklch,var(--paper) 94%,transparent);backdrop-filter:blur(16px)}.capture-sheet{padding-bottom:calc(22px + var(--safe))}.capture-option{display:grid;grid-template-columns:42px 1fr auto;gap:14px;align-items:center;width:calc(100% - 32px);margin:0 16px 9px;padding:19px;border:1px solid var(--line);border-radius:16px;background:var(--surface);color:var(--ink);text-align:left}.capture-option.featured-option{background:var(--ink);color:var(--surface)}.capture-option strong,.capture-option small{display:block}.capture-option small{margin-top:4px;color:var(--muted)}.featured-option small{color:color-mix(in oklch,var(--surface) 65%,transparent)}.option-index{font:11px var(--mono)}.editor-sheet{height:min(94dvh,950px);overflow:auto}.editor-body{display:grid;gap:20px;padding:22px 18px calc(34px + var(--safe))}.media-inputs{display:grid;grid-template-columns:1fr 1fr;gap:9px}.media-add{display:grid;min-height:105px;padding:15px;place-items:center;border:1px dashed var(--line);border-radius:14px;background:var(--surface);text-align:center}.media-add input{position:absolute;width:1px;height:1px;opacity:0}.media-add small,.toggle-row small{display:block;color:var(--muted);font-size:11px}.media-preview{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}.preview-item{position:relative;aspect-ratio:1;overflow:hidden;border-radius:11px;background:var(--line)}.preview-item img,.preview-item video{width:100%;height:100%;object-fit:cover}.preview-item audio{width:100%;margin-top:40%}.preview-remove{position:absolute;top:4px;right:4px;width:28px;height:28px;border:0;border-radius:50%;background:var(--ink);color:var(--surface)}.editor-options{border-top:1px solid var(--line)}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid var(--line)}.toggle-row input{width:22px;height:22px;accent-color:var(--accent)}.story-prompts{display:grid;gap:10px}.prompt-card{padding:18px;border-radius:14px;background:var(--blue);color:var(--ink)}.prompt-answer{display:grid;gap:7px}.prompt-answer p{margin:0;font:19px var(--display)}details{padding:15px;border:1px solid var(--line);border-radius:13px}summary{cursor:pointer;font-weight:650}.perspective-fields{margin-top:14px}
.modal{width:min(calc(100% - 24px),720px);max-width:none;padding:22px;border:0;border-radius:22px;background:var(--paper);box-shadow:var(--shadow)}.modal-head{padding:0 0 22px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}.calendar-cell{min-height:78px;padding:8px;border:1px solid var(--line);border-radius:9px;background:var(--surface)}.calendar-cell.empty{border-color:transparent;background:transparent}.calendar-cell span{font:10px var(--mono)}.calendar-cell i{display:block;width:8px;height:8px;margin-top:18px;border-radius:50%;background:var(--accent)}.button-stack{display:grid;gap:8px}.file-button{display:grid;place-items:center}.file-button input{position:absolute;width:1px;height:1px;opacity:0}.fine-print{margin:18px 0 0;color:var(--muted);font-size:11px}.modal hr{margin:24px 0;border:0;border-top:1px solid var(--line)}.import-drop{display:grid;min-height:160px;margin-top:20px;padding:25px;place-items:center;border:1px dashed var(--ink);border-radius:16px;background:var(--surface);text-align:center}.import-drop input{position:absolute;width:1px;height:1px;opacity:0}.import-group{display:flex;align-items:center;justify-content:space-between;gap:15px;padding:14px 0;border-top:1px solid var(--line)}.toast{position:fixed;right:16px;bottom:calc(90px + var(--safe));left:16px;z-index:90;width:fit-content;max-width:calc(100% - 32px);margin:auto;padding:11px 16px;border-radius:999px;background:var(--ink);color:var(--surface);font-size:12px;opacity:0;pointer-events:none;transform:translateY(8px);transition:.2s}.toast.show{opacity:1;transform:none}
.auth-view{display:grid;min-height:100dvh;padding:20px;place-items:center;background:var(--ink)}.auth-panel{width:min(100%,500px);padding:clamp(25px,6vw,60px);border-radius:26px;background:var(--paper)}.auth-panel h1{font-size:clamp(45px,8vw,76px);line-height:.95}.monogram{display:grid;width:55px;height:55px;margin-bottom:50px;place-items:center;border-radius:50%;background:var(--accent);color:var(--surface);font:28px var(--display)}.error{min-height:18px;color:var(--danger);font-size:12px}
.family-login-picker{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:0;padding:0;border:0}.family-login-picker legend{grid-column:1/-1;margin-bottom:8px;font-size:13px}.family-login{display:flex;align-items:center;gap:10px;padding:13px;border:1px solid var(--line);border-radius:16px;background:transparent;color:var(--ink);cursor:pointer}.family-login span{display:grid;width:34px;height:34px;place-items:center;border-radius:50%;background:var(--surface);font-family:var(--display)}.family-login.active{border-color:var(--ink);background:var(--ink);color:var(--paper)}
.onboarding-modal{width:min(94vw,720px)}.session-picker{display:flex;gap:10px;flex-wrap:wrap;padding:16px;border:1px solid var(--line);border-radius:16px}.session-picker legend{padding:0 6px}.session-picker label{flex:1;min-width:100px}.calendar-cell:disabled,.day-chip:disabled{opacity:.25;pointer-events:none}
.comments-panel{margin-top:24px;padding-top:18px;border-top:1px solid var(--line)}.comment{padding:10px 0;border-bottom:1px solid var(--line)}.comment.reply{margin-left:24px}.comment small{display:block;color:var(--muted)}.comment-compose{display:flex;gap:8px;margin-top:14px}.comment-compose .control{flex:1}
@media(max-width:760px){.month-cover{grid-template-columns:1fr;grid-template-rows:1.2fr auto auto;min-height:76dvh}.cover-photo{grid-column:1;grid-row:1}.cover-copy{grid-row:2}.cover-edit{grid-row:3}.featured-grid{grid-template-columns:1fr 1fr}.featured-grid .moment-card:first-child{grid-column:1/3;min-height:390px}.story-row{grid-template-columns:75px 1fr}.story-thumb{display:none}.year-grid{grid-template-columns:repeat(2,1fr)}.month-tile{min-height:300px}.age-chapter,.growth-progress{grid-template-columns:1fr}.milestone-list{grid-template-columns:1fr}.portrait-grid{grid-template-columns:1fr 1fr}.screen{padding-inline:12px}}
@media(max-width:480px){.featured-grid{display:block}.featured-grid .moment-card{min-height:300px;margin-bottom:9px}.media-mosaic{grid-auto-rows:58px}.year-grid{grid-template-columns:1fr 1fr}.month-tile{min-height:240px}.two-col,.media-inputs{grid-template-columns:1fr}.search-filters,.rediscovery-buttons{flex-direction:column}.portrait-grid{grid-template-columns:1fr}.page-header h1{font-size:64px}}
.month-cover::before{content:'';position:absolute;z-index:0;inset:0;background-image:var(--generated-art,none);background-size:55%;background-position:left top;background-repeat:no-repeat;opacity:.65;pointer-events:none}.reaction-panel{display:flex;align-items:center;justify-content:space-between;padding:16px;border:1px solid var(--line);border-radius:14px;background:var(--surface)}.reaction-panel>span{color:var(--muted);font-size:12px}.reaction-panel button{min-width:44px;height:40px;border:1px solid var(--line);border-radius:999px;background:var(--paper);font-size:19px}.reaction-panel button.active{border-color:var(--accent);background:var(--accent);color:var(--surface)}.reader-mode .capture-fab,.reader-mode #edit-month-button,.reader-mode #month-summary-button{display:none}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
