*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#151d22;-webkit-font-smoothing:antialiased;background:#f5faff;min-height:100vh;font-family:Be Vietnam Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans KR,sans-serif}.material-symbols-outlined{white-space:nowrap;direction:ltr;font-family:Material Symbols Outlined;font-style:normal;font-weight:400;display:inline-block}#root{min-height:100vh}button{font-family:inherit}.app{flex-direction:column;min-height:100vh;display:flex}.header{z-index:40;background:#f5faff;border-bottom:1px solid #dbe4ea;position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:12px 32px;display:flex}.logo{color:#0c6780;letter-spacing:-.3px;font-size:1.5rem;font-weight:700}.btn-add{color:#fff;cursor:pointer;background:#0c6780;border:none;border-radius:9999px;align-items:center;gap:6px;padding:8px 20px;font-size:.875rem;font-weight:500;transition:opacity .2s,transform .1s;display:inline-flex;box-shadow:0 1px 3px #0000001a}.btn-add .material-symbols-outlined{font-size:18px}.btn-add:hover{opacity:.9;transform:translateY(-1px)}.btn-add:active{transform:scale(.96)}.main{flex:1;width:100%;max-width:960px;margin:0 auto;padding:48px 32px}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:60vh;display:flex}.empty-icon{margin-bottom:8px;font-size:5rem;animation:3s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.empty-state h2{color:#444;font-size:1.4rem;font-weight:700}.empty-state p{color:#999;margin-bottom:8px;font-size:.95rem}.btn-add-primary{color:#fff;cursor:pointer;background:#0c6780;border:none;border-radius:28px;margin-top:8px;padding:14px 36px;font-size:1rem;font-weight:600;transition:background .2s,transform .15s;box-shadow:0 4px 16px #0c678059}.btn-add-primary:hover{background:#004d62;transform:translateY(-2px)}.children-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:24px;display:grid}.child-card{text-align:center;background:#fff;border-radius:20px;padding:32px 20px 24px;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 16px #00000012}.child-card:hover{transform:translateY(-4px);box-shadow:0 10px 28px #0000001f}.child-photo-wrap{background:#d7eef4;border:3px solid #9fcfd5;border-radius:50%;justify-content:center;align-items:center;width:110px;height:110px;margin:0 auto 16px;display:flex;overflow:hidden}.child-photo{object-fit:cover;width:100%;height:100%}.child-photo-placeholder{font-size:2.8rem}.child-name{color:#222;margin-bottom:6px;font-size:1.15rem;font-weight:700}.child-age{color:#0c6780;margin-bottom:4px;font-size:.95rem;font-weight:600}.child-birth{color:#aaa;font-size:.8rem}.add-card{cursor:pointer;color:#0c6780;background:#fff;border:2px dashed #9fcfd5;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;gap:8px;min-height:210px;padding:32px 20px 24px;transition:border-color .2s,background .2s,transform .15s;display:flex}.add-card:hover{background:#edf5fc;border-color:#0c6780;transform:translateY(-2px)}.add-card span{font-size:2.5rem;font-weight:300;line-height:1}.add-card p{font-size:.9rem;font-weight:600}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:24px;width:100%;max-width:400px;padding:36px 32px;animation:.25s slideUp;box-shadow:0 24px 64px #0003}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-title{color:#222;text-align:center;margin-bottom:28px;font-size:1.25rem;font-weight:700}.child-form{flex-direction:column;gap:20px;display:flex}.photo-upload{cursor:pointer;background:#d7eef4;border:2px dashed #9fcfd5;border-radius:50%;justify-content:center;align-items:center;width:110px;height:110px;margin:0 auto;transition:border-color .2s,background .2s;display:flex;overflow:hidden}.photo-upload:hover{background:#b8e8ee;border-color:#0c6780}.photo-preview{object-fit:cover;width:100%;height:100%}.photo-placeholder{color:#0c6780;flex-direction:column;align-items:center;gap:4px;display:flex}.photo-placeholder span{font-size:1.8rem}.photo-placeholder p{font-size:.7rem;font-weight:600}.form-label{color:#666;letter-spacing:.2px;flex-direction:column;gap:6px;font-size:.8rem;font-weight:600;display:flex}.form-input{color:#333;background:#fff;border:1.5px solid #e5e5e5;border-radius:12px;outline:none;width:100%;padding:12px 14px;font-size:.95rem;transition:border-color .2s}.form-input:focus{border-color:#0c6780}.form-actions{gap:10px;margin-top:4px;display:flex}.btn-cancel{color:#888;cursor:pointer;background:#fff;border:1.5px solid #e5e5e5;border-radius:12px;flex:1;padding:13px;font-size:.9rem;font-weight:600;transition:border-color .2s,color .2s}.btn-cancel:hover{color:#555;border-color:#ccc}.btn-submit{color:#fff;cursor:pointer;background:#0c6780;border:none;border-radius:12px;flex:2;padding:13px;font-size:.9rem;font-weight:600;transition:background .2s}.btn-submit:hover{background:#004d62}.btn-back{color:#0c6780;cursor:pointer;background:0 0;border:none;border-radius:9999px;align-items:center;gap:4px;padding:8px 10px 8px 6px;font-size:.9rem;font-weight:500;transition:background .15s;display:inline-flex}.btn-back:hover{background:#dbe4ea}.btn-back .material-symbols-outlined{font-size:16px}.header-title{color:#151d22;font-size:1.05rem;font-weight:600}.header-spacer{width:88px}.child-count{color:#bbb;margin-top:4px;font-size:.78rem}.detail{position:relative}.detail-hero{background:#fff;border-radius:20px;align-items:center;gap:16px;margin-bottom:20px;padding:20px;display:flex;box-shadow:0 2px 16px #00000012}.detail-photo{background:#d7eef4;border:3px solid #9fcfd5;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:76px;height:76px;display:flex;overflow:hidden}.detail-photo img{object-fit:cover;width:100%;height:100%}.detail-info{flex:1}.detail-info h2{color:#222;font-size:1.3rem;font-weight:700}.detail-age{color:#0c6780;margin-top:2px;font-size:.9rem;font-weight:600}.detail-birth{color:#bbb;margin-top:2px;font-size:.78rem}.btn-diary{color:#0c6780;cursor:pointer;white-space:nowrap;background:#edf5fc;border:1.5px solid #9fcfd5;border-radius:9999px;align-items:center;gap:6px;padding:10px 16px;font-size:.85rem;font-weight:600;transition:background .15s;display:inline-flex}.btn-diary .material-symbols-outlined{font-size:18px}.btn-diary:hover{background:#d7eef4}.filter-bar{flex-wrap:wrap;gap:8px;margin-bottom:18px;display:flex}.filter-chip{color:#888;cursor:pointer;background:#fff;border:1.5px solid #eee;border-radius:20px;padding:7px 14px;font-size:.82rem;font-weight:600;transition:all .15s}.filter-chip.active{color:#fff;background:#0c6780;border-color:#0c6780}.memory-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px;display:grid}.memory-cell{background:#fff;border-radius:16px;position:relative;overflow:hidden;box-shadow:0 2px 12px #0000000f}.memory-thumb{aspect-ratio:1;cursor:pointer;background:#f3f3f3;border:none;width:100%;padding:0;display:block;position:relative}.memory-thumb img{object-fit:cover;width:100%;height:100%}.memory-kind-badge{background:#00000080;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.85rem;display:flex;position:absolute;top:8px;left:8px}.memory-cell-foot{padding:10px 12px}.memory-title{color:#333;text-overflow:ellipsis;white-space:nowrap;font-size:.85rem;font-weight:600;overflow:hidden}.memory-date{color:#bbb;margin-top:2px;font-size:.72rem}.memory-del{color:#fff;cursor:pointer;opacity:0;background:#00000073;border:none;border-radius:50%;width:26px;height:26px;font-size:.75rem;transition:opacity .15s;position:absolute;top:8px;right:8px}.memory-cell:hover .memory-del{opacity:1}.empty-state.small{min-height:40vh}.fab{color:#fff;cursor:pointer;z-index:50;background:#0c6780;border:none;border-radius:9999px;justify-content:center;align-items:center;width:60px;height:60px;transition:transform .15s,box-shadow .2s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 6px 20px #0c678073}.fab .material-symbols-outlined{font-size:30px}.fab:hover{transform:scale(1.08)translateY(-2px);box-shadow:0 10px 26px #0c678080}.modal-wide{max-width:460px;max-height:90vh;overflow-y:auto}.mem-image-area{margin-bottom:4px}.mem-image-actions{gap:12px;display:flex}.mem-pick-btn{color:#0c6780;cursor:pointer;background:#f5faff;border:2px dashed #9fcfd5;border-radius:16px;flex-direction:column;flex:1;align-items:center;gap:6px;padding:22px 8px;font-size:.82rem;font-weight:600;display:flex}.mem-pick-btn span{font-size:1.6rem}.mem-pick-btn:disabled{opacity:.5;cursor:default}.mem-image-preview{border-radius:16px;position:relative;overflow:hidden}.mem-image-preview img{object-fit:cover;width:100%;max-height:280px;display:block}.mem-size-badge{color:#fff;background:#0009;border-radius:8px;padding:4px 8px;font-size:.7rem;position:absolute;bottom:8px;left:8px}.mem-image-change{color:#fff;cursor:pointer;background:#0009;border:none;border-radius:8px;padding:6px 10px;font-size:.72rem;position:absolute;top:8px;right:8px}.mem-strip{flex-wrap:wrap;gap:8px;margin-bottom:10px;display:flex}.mem-strip-thumb{cursor:pointer;background:#edf1f4;border:2px solid #dbe4ea;border-radius:12px;flex:none;width:60px;height:60px;padding:0;transition:border-color .15s;position:relative;overflow:hidden}.mem-strip-thumb img{object-fit:cover;width:100%;height:100%}.mem-strip-thumb.active{border-color:#0c6780}.mem-strip-badge{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.6rem;font-weight:900;display:flex;position:absolute;bottom:3px;left:3px}.mem-strip-badge.spin{background:#0000008c;animation:1.4s ease-in-out infinite dreamFloat}.mem-strip-badge.warn{background:#e53935}.mem-strip-remove{color:#fff;cursor:pointer;background:#0009;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.85rem;line-height:1;display:flex;position:absolute;top:2px;right:2px}.mem-strip-add{color:#6f787d;cursor:pointer;background:#f5faff;border:2px dashed #b6c4ce;border-radius:12px;flex:none;width:60px;height:60px;font-size:1.5rem}.mem-strip-add:disabled{opacity:.5;cursor:default}.kind-tabs{gap:8px;display:flex}.kind-tab{color:#888;cursor:pointer;background:#fff;border:1.5px solid #eee;border-radius:12px;flex:1;padding:10px;font-size:.82rem;font-weight:600}.kind-tab.active{color:#0c6780;background:#edf5fc;border-color:#0c6780}.form-textarea{resize:vertical;font-family:inherit}.btn-submit:disabled{opacity:.5;cursor:default}.ai-banner{border-radius:12px;padding:11px 14px;font-size:.82rem;font-weight:600;line-height:1.4}.ai-banner.analyzing{color:#0c6780;background:#edf5fc}.ai-banner.done{color:#2e7d4f;background:#eaf7ee}.ai-banner.failed{color:#999;background:#f5f5f5}.ai-hint{opacity:.7;margin-top:2px;font-size:.74rem;font-weight:500;display:block}.viewer-overlay{z-index:200;background:#000000e6;flex-direction:column;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.viewer-close{color:#fff;cursor:pointer;z-index:2;background:0 0;border:none;font-size:1.8rem;position:absolute;top:16px;right:20px}.viewer-stage{flex:1;justify-content:center;align-items:center;max-width:100%;display:flex;overflow:auto}.viewer-img{object-fit:contain;cursor:zoom-in;border-radius:8px;max-width:92vw;max-height:70vh;transition:transform .25s}.viewer-img.zoomed{cursor:zoom-out;transform:scale(2.2)}.viewer-meta{color:#fff;text-align:center;max-width:480px;padding:16px 0 4px}.viewer-kind{opacity:.7;font-size:.8rem}.viewer-meta h3{margin-top:6px;font-size:1.1rem;font-weight:700}.viewer-place{opacity:.85;margin-top:4px;font-size:.85rem}.viewer-note{opacity:.9;margin-top:8px;font-size:.9rem;line-height:1.5}.viewer-date{opacity:.6;margin-top:8px;font-size:.78rem}.viewer-hint{opacity:.4;margin-top:6px;font-size:.72rem}.diary-controls{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.interval-picker{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.interval-picker>span{color:#888;font-size:.8rem;font-weight:600}.interval-chip{color:#888;cursor:pointer;background:#fff;border:1.5px solid #eee;border-radius:18px;padding:6px 12px;font-size:.8rem;font-weight:600}.interval-chip.active{color:#fff;background:#0c6780;border-color:#0c6780}.btn-print{color:#fff;cursor:pointer;background:#293137;border:none;border-radius:9999px;align-items:center;gap:6px;padding:10px 18px;font-size:.82rem;font-weight:500;transition:opacity .15s;display:inline-flex}.btn-print .material-symbols-outlined{font-size:18px}.btn-print:hover{opacity:.9}.diary-paper{background:#fff;border-radius:12px;max-width:794px;margin:0 auto;padding:28px;box-shadow:0 4px 24px #0000001a}.diary-cover{text-align:center;border-bottom:2px dashed #9fcfd5;margin-bottom:24px;padding:20px 0 28px}.diary-cover-photo{background:#d7eef4;border:3px solid #9fcfd5;border-radius:50%;justify-content:center;align-items:center;width:90px;height:90px;margin:0 auto 12px;font-size:2.4rem;display:flex;overflow:hidden}.diary-cover-photo img{object-fit:cover;width:100%;height:100%}.diary-cover h1{color:#0c6780;font-size:1.5rem;font-weight:800}.diary-cover p{color:#999;margin-top:6px;font-size:.85rem}.diary-empty{text-align:center;color:#aaa;padding:40px 0}.diary-entry{break-inside:avoid;margin-bottom:28px}.diary-entry-head{align-items:center;gap:10px;margin-bottom:12px;display:flex}.diary-entry-face{background:#d7eef4;border:2px solid #9fcfd5;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;overflow:hidden}.diary-entry-face img{object-fit:cover;width:100%;height:100%}.diary-entry-head h2{color:#333;font-size:1.05rem;font-weight:700}.diary-entry-age{color:#0c6780;font-size:.75rem;font-weight:600}.collage{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.collage-item{cursor:pointer;aspect-ratio:1;background:#f3f3f3;border:none;border-radius:8px;padding:0;position:relative;overflow:hidden}.collage-item.wide{aspect-ratio:2;grid-column:span 2}.collage-item img{object-fit:cover;width:100%;height:100%}.collage-cap{color:#fff;text-align:left;text-overflow:ellipsis;white-space:nowrap;background:linear-gradient(#0000,#000000a6);padding:12px 6px 4px;font-size:.62rem;position:absolute;bottom:0;left:0;right:0;overflow:hidden}@media print{.no-print,.header,.fab{display:none!important}.main{max-width:none;padding:0}.app{background:#fff}.diary-paper{box-shadow:none;border-radius:0;max-width:none;padding:0}.diary-entry{margin-bottom:14px}.collage{grid-template-columns:repeat(6,1fr);gap:3px}.collage-cap{font-size:.5rem}@page{size:A4;margin:12mm}.book-result,.book-paper{display:block}.book-paper{gap:0}.book-page{box-shadow:none;break-after:page;page-break-after:always;border-radius:0;min-height:auto;margin:0}.book-page:last-child{break-after:auto;page-break-after:auto}.book-dream{display:none!important}.book-cover{background:#fff!important}.book-chapter .book-section,.book-chapter .book-preface,.book-chapter .book-closing{-webkit-backdrop-filter:none!important;backdrop-filter:none!important;box-shadow:none!important;background:0 0!important;padding:0!important}.book-photos img{box-shadow:none!important;border-color:#eee!important;transform:none!important}}@media (prefers-reduced-motion:reduce){.book-dream-blob{animation:none}}@media (width<=640px){.header{padding:16px 20px}.children-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}.modal{padding:28px 20px}.memory-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:12px}.collage{grid-template-columns:repeat(3,1fr)}.main{padding:24px 16px}}.login{background:radial-gradient(120% 80% at 50% 0,#cfe9f0 0%,#f5faff 55%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{text-align:center;background:#fff;border-radius:28px;width:100%;max-width:380px;padding:40px 32px 32px;box-shadow:0 18px 50px #0c67801f}.login-brand{color:#0c6780;letter-spacing:-.3px;align-items:center;gap:8px;margin-bottom:18px;font-size:1.4rem;font-weight:700;display:inline-flex}.login-brand .material-symbols-outlined{font-size:28px}.login-kicker{color:#37656b;letter-spacing:3px;font-size:.8rem;font-weight:600}.login-title{color:#151d22;letter-spacing:-.5px;margin:10px 0 8px;font-size:1.7rem;font-weight:800;line-height:1.35}.login-sub{color:#6f787d;margin-bottom:26px;font-size:.9rem}.login-form{flex-direction:column;gap:12px;display:flex}.login-start{width:100%;margin-top:2px}.login-hint{color:#bfc8cd;font-size:.78rem}.login-error{color:#d9534f;margin:2px 0 0;font-size:.82rem}.login-sent{color:#3a4448;background:#f1f7f8;border-radius:12px;padding:18px 16px;font-size:.9rem;line-height:1.5}.login-sent strong{color:#2a6f77}.splash{color:#6f787d;justify-content:center;align-items:center;min-height:100vh;font-size:.95rem;display:flex}.login-divider{color:#bfc8cd;align-items:center;gap:12px;margin:22px 0 16px;font-size:.8rem;display:flex}.login-divider:before,.login-divider:after{content:"";background:#dbe4ea;flex:1;height:1px}.login-social{flex-direction:column;gap:10px;display:flex}.social-btn{color:#555;cursor:not-allowed;background:#fff;border:1px solid #dbe4ea;border-radius:14px;justify-content:center;align-items:center;gap:10px;width:100%;padding:13px;font-size:.92rem;font-weight:600;display:flex;position:relative}.social-btn:disabled{opacity:.65}.social-icon{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:.8rem;font-weight:800;display:inline-flex}.social-google .social-icon{background:#4285f4}.social-kakao{color:#3c1e1e;background:#fee500;border-color:#fee500}.social-kakao .social-icon{color:#fee500;background:#3c1e1e}.social-btn em{color:#bfc8cd;font-size:.68rem;font-style:normal;position:absolute;right:14px}.landing{background:#f5faff;flex-direction:column;min-height:100vh;display:flex}.kk-greeting-sr{clip:rect(0 0 0 0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.material-symbols-outlined{font-variation-settings:"FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;line-height:1}.material-symbols-outlined.filled{font-variation-settings:"FILL" 1}.kk-topnav{z-index:40;background:#f5faff;position:sticky;top:0}.kk-topnav-inner{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:8px 64px;display:flex}.kk-brand{letter-spacing:-.3px;color:#0c6780;font-size:1.5rem;font-weight:700}.kk-nav{align-items:center;gap:24px;display:flex}.kk-nav a{color:#3f484c;padding-bottom:4px;font-size:.875rem;font-weight:500;text-decoration:none;transition:color .15s}.kk-nav a:hover{color:#0c6780}.kk-nav a.active{color:#0c6780;border-bottom:2px solid #0c6780}.kk-topnav-actions{align-items:center;gap:16px;display:flex}.kk-icon-group{gap:8px;display:flex}.kk-icon-btn{cursor:pointer;color:#3f484c;background:0 0;border:none;border-radius:9999px;justify-content:center;align-items:center;padding:8px;transition:background .15s,color .15s;display:inline-flex}.kk-icon-btn:hover{color:#0c6780;background:#dbe4ea}.kk-upload-btn{color:#fff;cursor:pointer;background:#0c6780;border:none;border-radius:9999px;padding:8px 24px;font-size:.875rem;font-weight:500;transition:opacity .15s,transform .1s;box-shadow:0 1px 3px #0000001a}.kk-upload-btn:hover{opacity:.9}.kk-upload-btn:active{transform:scale(.96)}.kk-hero{flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:80vh;display:flex;position:relative;overflow:hidden}.kk-hero-bg{z-index:0;justify-content:center;align-items:flex-start;display:flex;position:absolute;inset:0;overflow:hidden}.kk-hero-bg img{object-position:center top;opacity:.9;width:80%;max-width:1000px;height:auto}.kk-hero-bg:after{content:"";background:linear-gradient(#f5faff40 0%,#f5faff73 45%,#f5faffe6 78%,#f5faff 100%);position:absolute;inset:0}.kk-hero-content{z-index:20;text-align:center;flex-direction:column;align-items:center;max-width:768px;padding:48px 16px 0;display:flex;position:relative}.kk-hero-title{letter-spacing:-.02em;color:#151d22;text-shadow:0 1px 2px #0000000f;margin-bottom:16px;font-size:32px;font-weight:700;line-height:40px}.kk-hero-sub{color:#3f484c;max-width:36rem;margin-bottom:40px;font-size:18px;line-height:28px}.kk-hero-actions{flex-wrap:wrap;justify-content:center;gap:16px;margin-bottom:64px;display:flex}.kk-cta{cursor:pointer;border-radius:9999px;justify-content:center;align-items:center;gap:8px;padding:16px 32px;font-size:.875rem;font-weight:500;transition:transform .3s,box-shadow .3s;display:inline-flex}.kk-cta-primary{color:#fff;background:#0c6780;border:none;box-shadow:0 8px 20px #0c678033}.kk-cta-primary:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0c67804d}.kk-cta-secondary{color:#37656b;background:#fff;border:1px solid #bfc8cd;box-shadow:0 8px 20px #37656b1a}.kk-cta-secondary:hover{transform:translateY(-4px);box-shadow:0 12px 24px #37656b26}.kk-cta .material-symbols-outlined{font-size:20px}.kk-book-action{z-index:20;margin-top:auto;padding-bottom:48px;position:relative}.kk-book-btn{cursor:pointer;color:#3f484c;background:0 0;border:none;flex-direction:column;align-items:center;gap:16px;transition:color .15s;display:flex}.kk-book-btn:hover{color:#0c6780}.kk-book-circle{background:#fff;border-radius:9999px;justify-content:center;align-items:center;width:192px;height:192px;transition:transform .3s;display:flex;box-shadow:0 24px 60px #0c678026}.kk-book-btn:hover .kk-book-circle{transform:translateY(-16px)}.kk-book-circle .material-symbols-outlined{color:#0c6780;font-size:72px}.kk-book-label{letter-spacing:-.01em;opacity:.8;font-size:24px;font-weight:700;transition:opacity .15s}.kk-book-btn:hover .kk-book-label{opacity:1}.kk-footer{background:#fff;border-top:1px solid #bfc8cd;margin-top:auto;padding:48px 64px}.kk-footer-inner{flex-flow:wrap;justify-content:space-between;align-items:center;gap:24px;max-width:1200px;margin:0 auto;display:flex}.kk-footer-brand{color:#0c6780;font-size:1.5rem;font-weight:600}.kk-footer-links{flex-wrap:wrap;justify-content:center;gap:24px;display:flex}.kk-footer-links a{color:#3f484c;font-size:16px;text-decoration:none;transition:color .15s}.kk-footer-links a:hover{color:#37656b}.kk-footer-copy{color:#3f484c;text-align:right;font-size:.875rem}.kk-bottomnav{z-index:50;width:100%;padding:8px 16px calc(8px + env(safe-area-inset-bottom,0px));background:#edf5fc;border-radius:12px 12px 0 0;justify-content:space-around;align-items:center;display:none;position:fixed;bottom:0;left:0;box-shadow:0 -4px 12px #0c678014}.kk-bottomnav a{color:#3f484c;cursor:pointer;background:0 0;border:none;border-radius:9999px;flex-direction:column;align-items:center;padding:4px 16px;text-decoration:none;transition:background .15s,transform .15s;display:flex}.kk-bottomnav a:active{transform:scale(.9)}.kk-bottomnav a.active{color:#005870;background:#87ceeb}.kk-bottomnav a span:last-child{margin-top:4px;font-size:10px;font-weight:500}.kk-bottomnav .material-symbols-outlined{font-size:24px}@media (width<=768px){.kk-topnav-inner{padding:8px 16px}.kk-nav,.kk-icon-group{display:none}.kk-footer{padding:48px 16px}.kk-footer-inner{flex-direction:column}.kk-footer-copy{text-align:center}.kk-bottomnav{display:flex}.kk-hero{padding-bottom:72px}}.book-setup{max-width:560px;margin:0 auto}.book-setup-title{color:#151d22;margin-bottom:24px;font-size:1.5rem;font-weight:800}.book-field{margin-bottom:26px}.book-field h3{color:#3f484c;margin-bottom:12px;font-size:1rem}.period-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.period-chip{color:#3f484c;cursor:pointer;background:#fff;border:2px solid #dbe4ea;border-radius:16px;padding:16px;font-size:1rem;font-weight:700;transition:all .15s}.period-chip.active{color:#004d62;background:#edf5fc;border-color:#0c6780}.book-child-list{flex-wrap:wrap;gap:14px;display:flex}.book-child{cursor:pointer;background:#fff;border:2px solid #dbe4ea;border-radius:18px;flex-direction:column;align-items:center;gap:8px;width:104px;padding:14px;transition:all .15s;display:flex}.book-child.active{background:#edf5fc;border-color:#0c6780}.book-child-photo{background:#cfe9f0;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;font-size:1.8rem;display:flex;overflow:hidden}.book-child-photo img{object-fit:cover;width:100%;height:100%}.book-child-name{color:#3f484c;font-size:.92rem;font-weight:700}.book-count{color:#6f787d;margin-bottom:8px;font-size:.9rem}.book-error{color:#e53935;margin-bottom:12px;font-size:.9rem}.book-open-btn{width:100%}.book-hint{color:#6f787d;margin-top:10px;font-size:.84rem;line-height:1.5}.book-mode-toggle{grid-template-columns:1fr 1fr;gap:12px;display:grid}.book-mode-chip{text-align:left;cursor:pointer;background:#fff;border:2px solid #dbe4ea;border-radius:16px;flex-direction:column;gap:4px;padding:16px;transition:all .15s;display:flex}.book-mode-chip.active{background:#edf5fc;border-color:#0c6780}.book-mode-name{color:#151d22;font-size:.95rem;font-weight:800}.book-mode-desc{color:#6f787d;font-size:.8rem;line-height:1.4}.book-months{background:radial-gradient(120% 70% at 50% -20%,#fff7ebe6,#0000 60%),linear-gradient(165deg,#fdf6ef 0%,#f6ecf5 55%,#eaf0fa 100%);border-radius:20px;flex-direction:column;gap:22px;padding:20px;display:flex;box-shadow:inset 0 1px #fff9}.book-month-head{justify-content:space-between;align-items:baseline;margin-bottom:10px;display:flex}.book-month-label{color:#4a4036;font-family:Georgia,Times New Roman,serif;font-size:.98rem;font-weight:800}.book-month-count{color:#8a5a2b;background:#fffcf7b3;border-radius:14px;padding:3px 10px;font-size:.82rem;font-weight:700}.book-photo-grid{grid-template-columns:repeat(auto-fill,minmax(74px,1fr));gap:10px;display:grid}.book-photo-thumb{aspect-ratio:1;cursor:pointer;filter:sepia(.35)saturate(.85)brightness(1.02);opacity:.6;background:#efe7dd;border:3px solid #fff;border-radius:10px;padding:0;transition:filter .2s,opacity .2s,transform .2s,box-shadow .2s;position:relative;overflow:hidden;box-shadow:0 4px 12px #785a4624}.book-photo-thumb img{object-fit:cover;width:100%;height:100%}.book-photo-thumb.selected{filter:none;opacity:1;border-color:#e8b97e;transform:translateY(-2px);box-shadow:0 8px 20px #b4824652}.book-photo-thumb:not(.readonly):hover{filter:none;opacity:.92}.book-photo-thumb.readonly{cursor:default}.book-photo-kind{filter:drop-shadow(0 1px 2px #00000073);font-size:.85rem;position:absolute;bottom:5px;left:5px}.book-photo-check{color:#fff;background:#c98a4b;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:.7rem;font-weight:900;display:flex;position:absolute;top:5px;right:5px;box-shadow:0 2px 6px #00000040}.book-result{max-width:860px;margin:0 auto;padding:20px 16px 60px}.book-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.book-toolbar-actions{flex-wrap:wrap;gap:10px;display:flex}.btn-kakao{color:#3c1e1e;cursor:pointer;background:#fee500;border:none;border-radius:24px;padding:10px 18px;font-size:.875rem;font-weight:700}.book-paper{flex-direction:column;gap:28px;display:flex}.book-page{aspect-ratio:1/1.414;background:#fff;border-radius:8px;padding:56px 56px 64px;position:relative;overflow:hidden;box-shadow:0 6px 28px #0000001a}.book-page>:not(.book-dream){z-index:1;position:relative}.book-dream{z-index:0;pointer-events:none;background:radial-gradient(120% 80% at 50% -10%,#fff7ebe6,#0000 60%),linear-gradient(165deg,#fdf6ef 0%,#f6ecf5 45%,#eaf0fa 100%);position:absolute;inset:0;overflow:hidden}.book-dream-blob{filter:blur(46px);opacity:.5;mix-blend-mode:multiply;border-radius:50%;animation:16s ease-in-out infinite dreamFloat;position:absolute}.book-dream-blob.b1{background:radial-gradient(circle,#ffd7b0,#0000 70%);width:46%;height:36%;top:8%;left:-8%}.book-dream-blob.b2{background:radial-gradient(circle,#e7c7f0,#0000 70%);width:50%;height:40%;animation-delay:-5s;top:28%;right:-10%}.book-dream-blob.b3{background:radial-gradient(circle,#bfe0f2,#0000 70%);width:52%;height:42%;animation-delay:-10s;bottom:-12%;left:18%}@keyframes dreamFloat{0%,to{transform:translate(0,0)scale(1)}50%{transform:translateY(-18px)scale(1.08)}}.book-cover{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:14px;display:flex}.book-cover-period{color:#0c6780;letter-spacing:2px;font-size:.85rem;font-weight:700}.book-cover-title{color:#151d22;font-size:2rem;font-weight:800;line-height:1.3}.book-cover-name{color:#6f787d;font-weight:700}.book-cover-photo{aspect-ratio:4/3;border-radius:12px;width:60%;max-width:320px;margin:8px 0;overflow:hidden;box-shadow:0 8px 24px #00000026}.book-cover-photo img{object-fit:cover;width:100%;height:100%}.book-cover-toc{color:#0c6780;letter-spacing:1px;font-size:.82rem;font-weight:700}.book-preface{color:#3f484c;max-width:80%;font-size:.98rem;line-height:1.9}.book-chapter-head{margin-bottom:22px}.book-chapter-month{color:#004d62;letter-spacing:1px;background:#edf5fc;border-radius:20px;margin-bottom:12px;padding:5px 12px;font-size:.82rem;font-weight:800;display:inline-block}.book-chapter .book-preface{max-width:100%}.book-cover-title{font-family:Georgia,Times New Roman,serif}.book-section{margin-bottom:22px}.book-section h3{color:#8a5a2b;border-bottom:2px solid #d9b38c80;margin-bottom:10px;padding-bottom:6px;font-family:Georgia,Times New Roman,serif;font-size:1.25rem;font-weight:800}.book-section p{color:#4a4036;margin-bottom:10px;font-size:1rem;line-height:1.95}.book-chapter .book-section,.book-chapter .book-preface,.book-chapter .book-closing{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#fffcf7b8;border-radius:16px;padding:18px 20px;box-shadow:0 4px 18px #785a4614}.book-photos{grid-template-columns:repeat(2,1fr);gap:16px;margin:16px 4px 8px;display:grid}.book-photos img{aspect-ratio:4/3;object-fit:cover;background:#fff;border:7px solid #fff;border-radius:3px;width:100%;transition:transform .2s;transform:rotate(-1.8deg);box-shadow:0 12px 26px #5a465038}.book-photos img:nth-child(2n){transform:rotate(2deg)}.book-photos img:nth-child(3n){transform:rotate(-.8deg)}.book-photos img:hover{transform:rotate(0)scale(1.02)}.book-closing{text-align:center;color:#6f5a4a;margin-top:24px;font-style:italic;line-height:1.9}.toast{color:#fff;z-index:100;background:#151d22;border-radius:24px;padding:12px 22px;font-size:.9rem;position:fixed;bottom:32px;left:50%;transform:translate(-50%);box-shadow:0 8px 24px #00000040}@media (width<=640px){.kk-hero-title{font-size:28px;line-height:36px}.kk-book-circle{width:160px;height:160px}.kk-book-circle .material-symbols-outlined{font-size:60px}.book-page{aspect-ratio:auto;padding:32px 24px 40px}.period-grid{grid-template-columns:1fr 1fr}}
