*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:#f5f5f5;color:#333;-webkit-font-smoothing:antialiased}#root{width:100%;height:100dvh;display:flex;justify-content:center}.chat-container{width:100%;max-width:480px;height:100dvh;display:flex;flex-direction:column;background:#b2c7d9;position:relative}.loading-screen,.error-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#555}.spinner{width:32px;height:32px;border:3px solid #ccc;border-top-color:#4a90d9;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.chat-header{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#4a90d9;color:#fff;flex-shrink:0}.header-avatar{width:42px;height:42px;border-radius:14px;background:#ffffff40;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700}.header-info{display:flex;flex-direction:column}.header-name{font-size:17px;font-weight:700;line-height:1.3}.header-status{font-size:12px;opacity:.85}.chat-messages{flex:1;overflow-y:auto;padding:16px 12px;display:flex;flex-direction:column;gap:8px;-webkit-overflow-scrolling:touch}.bubble-row{display:flex;align-items:flex-end;gap:8px;max-width:85%}.bubble-row.bot{align-self:flex-start}.bubble-row.user{align-self:flex-end;flex-direction:row-reverse}.bubble-avatar{width:36px;height:36px;min-width:36px;border-radius:12px;background:#4a90d9;color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;align-self:flex-start}.bubble{padding:10px 14px;border-radius:16px;font-size:15px;line-height:1.55;word-break:keep-all;overflow-wrap:break-word}.bubble.bot{background:#fff;color:#333;border-top-left-radius:4px}.bubble.user{background:#fef01b;color:#333;border-top-right-radius:4px}.bubble.typing{display:flex;align-items:center;gap:5px;padding:12px 18px}.dot{width:8px;height:8px;border-radius:50%;background:#999;animation:bounce 1.2s infinite}.dot:nth-child(2){animation-delay:.2s}.dot:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.quick-actions{display:flex;gap:8px;padding:8px 12px;background:#ffffffd9;flex-shrink:0}.action-btn{flex:1;text-align:center;padding:10px 0;border-radius:10px;font-size:14px;font-weight:600;text-decoration:none;transition:opacity .2s}.action-btn:active{opacity:.7}.action-btn.call{background:#4a90d9;color:#fff}.action-btn.blog{background:#2db400;color:#fff}.chat-input-bar{display:flex;gap:8px;padding:10px 12px;padding-bottom:max(10px,env(safe-area-inset-bottom));background:#fff;border-top:1px solid #e0e0e0;flex-shrink:0}.chat-input{flex:1;padding:10px 14px;border:1px solid #ddd;border-radius:20px;font-size:15px;outline:none;transition:border-color .2s}.chat-input:focus{border-color:#4a90d9}.chat-input:disabled{background:#f5f5f5}.send-btn{padding:10px 20px;border:none;border-radius:20px;background:#4a90d9;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap}.send-btn:hover:not(:disabled){background:#3a7bc8}.send-btn:disabled{background:#b0c4de;cursor:default}.mic-btn{position:relative;width:42px;height:42px;border:none;border-radius:50%;background:#f0f0f0;color:#666;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.mic-btn:hover:not(:disabled){background:#e0e0e0;color:#333}.mic-btn:disabled{opacity:.4;cursor:default}.mic-btn.listening{background:#ef4444;color:#fff;animation:mic-glow 1.5s ease-in-out infinite}@keyframes mic-glow{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 10px #ef444400}}.mic-pulse{position:absolute;inset:-4px;border-radius:50%;border:2px solid #ef4444;animation:mic-pulse-ring 1.5s ease-out infinite}@keyframes mic-pulse-ring{0%{transform:scale(1);opacity:.6}to{transform:scale(1.5);opacity:0}}.tts-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:none;border-radius:50%;background:#e0f2fe;color:#2196f3;cursor:pointer;margin-top:6px;transition:all .2s;float:right}.tts-btn:hover{background:#bbdefb;color:#1565c0;transform:scale(1.15)}.tts-btn:active{transform:scale(.95)}.tts-btn.speaking{background:#ef4444;color:#fff;animation:tts-pulse 1.5s ease-in-out infinite}.tts-btn.speaking:hover{background:#dc2626;transform:scale(1.15)}@keyframes tts-pulse{0%,to{opacity:1}50%{opacity:.7}}.bubble.error{background:#fff0f0;border:1px solid #ffcccc;color:#c33}.retry-btn{display:inline-block;margin-top:8px;padding:6px 16px;border:1px solid #cc3333;border-radius:14px;background:#fff;color:#c33;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s,color .2s}.retry-btn:hover{background:#c33;color:#fff}.retry-btn:active{opacity:.7}.admin-container{width:100%;max-width:900px;margin:0 auto;padding:20px;min-height:100dvh;background:#fff}.admin-login{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60dvh;gap:20px}.admin-login h1{font-size:24px;color:#333}.admin-login form{display:flex;gap:8px;width:100%;max-width:360px}.admin-login input{flex:1;padding:10px 14px;border:1px solid #ddd;border-radius:8px;font-size:15px;outline:none}.admin-login input:focus{border-color:#4a90d9}.admin-login button{padding:10px 20px;border:none;border-radius:8px;background:#4a90d9;color:#fff;font-size:15px;font-weight:600;cursor:pointer}.admin-login button:hover{background:#3a7bc8}.admin-error{color:#c33;font-size:14px}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #eee}.admin-header h1{font-size:22px;color:#333}.logout-btn{padding:8px 16px;border:1px solid #ddd;border-radius:6px;background:#fff;color:#666;font-size:14px;cursor:pointer}.logout-btn:hover{background:#f5f5f5}.admin-message{padding:10px 14px;margin-bottom:16px;border-radius:8px;background:#e8f4fd;color:#1a73e8;font-size:14px}.admin-actions{margin-bottom:16px}.add-btn{padding:10px 20px;border:none;border-radius:8px;background:#4a90d9;color:#fff;font-size:14px;font-weight:600;cursor:pointer}.add-btn:hover{background:#3a7bc8}.admin-form{background:#f9f9f9;padding:20px;border-radius:10px;margin-bottom:20px;display:flex;flex-direction:column;gap:12px}.facility-modal{background:#fff;border-radius:12px;width:90%;max-width:520px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.facility-modal-header{padding:20px 24px 0;flex-shrink:0}.facility-modal-header h2{margin:0 0 4px;font-size:18px;color:#333}.facility-modal-body{padding:16px 24px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:16px}.facility-modal-footer{padding:16px 24px;border-top:1px solid #eee;display:flex;gap:10px;flex-shrink:0}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:600;color:#555}.form-group input,.form-group textarea{padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit;outline:none}.form-group input:focus,.form-group textarea:focus{border-color:#4a90d9}.admin-form>button{align-self:flex-end;padding:10px 24px;border:none;border-radius:8px;background:#4a90d9;color:#fff;font-size:14px;font-weight:600;cursor:pointer}.admin-form>button:hover:not(:disabled){background:#3a7bc8}.admin-form>button:disabled{background:#b0c4de;cursor:default}.table-scroll-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:4px}.admin-table{width:100%;border-collapse:collapse;font-size:14px;min-width:700px}.admin-table th{text-align:left;padding:10px 12px;background:#f5f5f5;border-bottom:2px solid #ddd;font-weight:600;color:#555;white-space:nowrap}.admin-table td{padding:10px 12px;border-bottom:1px solid #eee;vertical-align:middle;white-space:nowrap}.admin-table a{color:#4a90d9;text-decoration:none}.admin-table a:hover{text-decoration:underline}.empty-row{text-align:center;color:#999;padding:30px 12px!important}.action-cell{display:flex;gap:4px;flex-wrap:nowrap}.btn-sm{padding:4px 10px;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;line-height:1.4}.btn-edit,.btn-crawl,.btn-delete{padding:4px 10px;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap}.btn-edit{background:#e8f4fd;color:#1a73e8}.btn-edit:hover{background:#d0e8f9}.btn-crawl{background:#e6f7e6;color:#2db400}.btn-crawl:hover{background:#d0f0d0}.btn-delete{background:#fde8e8;color:#c33}.btn-delete:hover{background:#fcd0d0}.btn-blog-draft{background:#fff3e0;color:#e67e22}.btn-blog-draft:hover{background:#ffe8cc}.link-cell{display:flex;gap:6px}.btn-link{padding:4px 10px;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;text-decoration:none;display:inline-block}.btn-view{background:#e8f0fe;color:#1967d2}.btn-view:hover{background:#d2e3fc}.btn-copy{background:#fef3e0;color:#e37400}.btn-copy:hover{background:#fde8c8}.stats-cards{display:flex;gap:16px;margin-bottom:24px}.stat-card{flex:1;background:#f8f9fa;border-radius:10px;padding:20px;text-align:center;border:1px solid #e9ecef}.stat-value{font-size:32px;font-weight:700;color:#1a73e8}.stat-label{font-size:14px;color:#666;margin-top:4px}.stat-card-action{display:flex;align-items:center;justify-content:center}.btn-logs{padding:12px 20px;background:#1a73e8;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer}.btn-logs:hover{background:#1557b0}.token-usage-section{background:#f8f9fa;border-radius:10px;padding:20px;margin-bottom:24px;border:1px solid #e9ecef}.token-usage-section h2{margin:0 0 12px;font-size:18px}.token-table td{text-align:center}.token-table td:first-child{text-align:left}.cost-cell{color:#e37400;font-weight:600}.total-row{background:#f0f4ff;border-top:2px solid #ddd}.cost-note{margin-top:8px;font-size:12px;color:#999}.chat-logs-section{background:#f8f9fa;border-radius:10px;padding:20px;margin-bottom:24px;border:1px solid #e9ecef}.chat-logs-section h2{margin:0 0 16px;font-size:18px}.empty-logs{color:#999;text-align:center;padding:20px}.chat-logs-list{display:flex;flex-direction:column;gap:12px;max-height:500px;overflow-y:auto}.chat-log-item{background:#fff;border-radius:8px;padding:14px;border:1px solid #e9ecef}.log-header{display:flex;justify-content:space-between;margin-bottom:10px;font-size:13px}.log-facility{font-weight:600;color:#1a73e8}.log-time{color:#999}.log-bubble{padding:8px 12px;border-radius:6px;font-size:14px;line-height:1.5;margin-bottom:6px;word-break:break-word}.log-user{background:#e8f4fd}.log-bot{background:#f0f0f0}.btn-load-more{display:block;width:100%;padding:10px;margin-top:12px;background:#fff;border:1px solid #ddd;border-radius:6px;font-size:14px;cursor:pointer;color:#1a73e8}.btn-load-more:hover{background:#f0f4ff}.btn-learn{padding:4px 10px;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;background:#f3e8fd;color:#7c3aed}.btn-learn:hover{background:#e8d5fa}.btn-upload{padding:4px 10px;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;background:#e0f2fe;color:#0369a1}.btn-upload:hover{background:#bae6fd}.btn-youtube{padding:4px 10px;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;background:#fee2e2;color:#dc2626}.btn-youtube:hover{background:#fecaca}.btn-youtube-submit{background:#dc2626!important}.btn-youtube-submit:hover:not(:disabled){background:#b91c1c!important}.file-info{font-size:13px;color:#666;margin:4px 0 8px}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:900}.modal-content{background:#fff;border-radius:12px;padding:28px;width:90%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 30px #00000026}.modal-content h2{margin:0 0 4px;font-size:20px}.modal-desc{color:#666;font-size:14px;margin:0 0 20px}.modal-content .form-group{margin-bottom:16px}.modal-content textarea{resize:vertical;min-height:120px}.modal-actions{display:flex;gap:10px;margin-top:8px}.btn-learn-submit{flex:1;padding:10px;background:#7c3aed;color:#fff;border:none;border-radius:6px;font-size:15px;font-weight:600;cursor:pointer}.btn-learn-submit:hover:not(:disabled){background:#6d28d9}.btn-learn-submit:disabled{opacity:.5;cursor:not-allowed}.btn-learn-submit.loading{background:#a78bfa}.btn-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:btn-spin .6s linear infinite;margin-right:6px;vertical-align:middle}@keyframes btn-spin{to{transform:rotate(360deg)}}.learn-toast{padding:10px 14px;border-radius:8px;font-size:14px;font-weight:500;margin-bottom:12px;animation:toast-slide-in .3s ease-out}.learn-toast.success{background:#ecfdf5;color:#047857;border:1px solid #a7f3d0}.learn-toast.error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}@keyframes toast-slide-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.btn-modal-cancel{padding:10px 20px;background:#f1f1f1;color:#333;border:none;border-radius:6px;font-size:15px;cursor:pointer}.btn-modal-cancel:hover{background:#e0e0e0}.copy-toast{position:fixed;bottom:30px;left:50%;transform:translate(-50%);background:#333;color:#fff;padding:10px 24px;border-radius:8px;font-size:14px;z-index:1000;animation:fadeInOut 2s ease-in-out}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%) translateY(10px)}15%{opacity:1;transform:translate(-50%) translateY(0)}85%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-10px)}}.btn-knowledge{background:#fef3c7;color:#92400e}.btn-knowledge:hover,.btn-knowledge.active{background:#fde68a}.knowledge-row td{padding:0!important}.knowledge-panel{background:#fafafa}.knowledge-section{padding:16px 20px;border-top:2px solid #e5e7eb}.knowledge-section h3{margin:0 0 12px;font-size:15px;color:#333}.knowledge-actions{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.knowledge-loading,.knowledge-empty{color:#999;font-size:14px;text-align:center;padding:20px 0}.knowledge-table{width:100%;border-collapse:collapse;font-size:13px}.knowledge-table th{text-align:left;padding:8px 10px;background:#f0f0f0;border-bottom:1px solid #ddd;font-weight:600;color:#555;font-size:12px}.knowledge-table td{padding:8px 10px;border-bottom:1px solid #eee}.badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600}.badge-blog{background:#e6f7e6;color:#2db400}.badge-youtube{background:#fee2e2;color:#dc2626}.badge-manual{background:#f3e8fd;color:#7c3aed}.badge-file{background:#e0f2fe;color:#0369a1}@media(max-width:600px){.admin-container{padding:12px}.admin-table{min-width:600px}.stats-cards{flex-direction:column}}.photo-post{--color-primary: #5B6ABF;--color-primary-dark: #4A58A8;--color-accent: #FF8C6B;--color-accent-dark: #E87A5B;--color-success: #4ECDC4;--color-bg: #FAFBFE;--color-card: #FFFFFF;--color-text: #2D3142;--color-muted: #8E94A6;--color-danger: #FF6B6B;--radius-lg: 24px;--radius-md: 16px;--radius-sm: 12px;--radius-pill: 50px;--shadow-card: 0 2px 12px rgba(0, 0, 0, .06);--shadow-elevated: 0 4px 20px rgba(0, 0, 0, .1)}@keyframes pp-fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pp-spin{to{transform:rotate(360deg)}}@keyframes pp-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.photo-post{width:100%;max-width:960px;height:100dvh;margin:0 auto;display:flex;flex-direction:column;background:var(--color-bg);position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--color-text)}.photo-post__header{display:flex;align-items:center;gap:12px;padding:16px 20px;background:linear-gradient(135deg,var(--color-primary) 0%,#7B8AD4 100%);color:#fff;flex-shrink:0;position:relative;z-index:10}.photo-post__header-back{width:36px;height:36px;border:none;border-radius:50%;background:#ffffff2e;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;min-width:36px;transition:background .3s ease,transform .2s ease}.photo-post__header-back:active{background:#ffffff4d;transform:scale(.92)}.photo-post__header-title{font-size:18px;font-weight:700;line-height:1.3;letter-spacing:-.3px}.photo-post__header-right{margin-left:auto;display:flex;align-items:center;gap:8px}.photo-post__header-step{font-size:12px;opacity:.85;font-weight:500}.photo-post__step-dots{display:flex;gap:6px;align-items:center}.photo-post__step-dot{width:8px;height:8px;border-radius:50%;background:#ffffff59;transition:all .3s ease}.photo-post__step-dot--active{background:#fff;width:20px;border-radius:4px}.photo-post__body{flex:1;overflow-y:auto;overflow-x:hidden;padding:20px 20px 24px;display:flex;flex-direction:column;gap:20px;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.photo-post__body--gate{background:linear-gradient(160deg,#3b2e24,#5c4033,#7a5c47 60%,#a8886c);justify-content:center;align-items:center;padding:40px 24px;position:relative;overflow:hidden}.photo-post__body--gate:before{content:"";position:absolute;top:-40%;right:-30%;width:80%;height:80%;background:radial-gradient(circle,rgba(212,175,140,.15) 0%,transparent 70%);pointer-events:none}.photo-post__body--gate:after{content:"";position:absolute;bottom:-20%;left:-20%;width:60%;height:60%;background:radial-gradient(circle,rgba(255,220,180,.08) 0%,transparent 70%);pointer-events:none}.photo-post__gate{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%;max-width:400px;animation:pp-fadeIn .6s ease;position:relative;z-index:1}.photo-post__gate-brand{font-size:36px;font-weight:800;color:#f5e6d3;letter-spacing:6px;margin-bottom:4px;text-shadow:0 2px 12px rgba(0,0,0,.2)}.photo-post__gate-subtitle{font-size:14px;color:#f5e6d3a6;margin:0 0 36px;font-weight:400;letter-spacing:.5px}.photo-post__gate-form{width:100%;display:flex;flex-direction:column;gap:10px;background:#ffffff12;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-lg);padding:28px 24px;border:1px solid rgba(245,230,211,.12);box-shadow:0 8px 32px #00000026}.photo-post__gate-label{font-size:11px;font-weight:600;color:#f5e6d373;text-transform:uppercase;letter-spacing:2.5px}.photo-post__gate-input{width:100%;padding:14px 16px;border:2px solid rgba(245,230,211,.15);border-radius:var(--radius-sm);font-size:16px;font-weight:600;color:#f5e6d3;background:#ffffff0d;outline:none;transition:border-color .2s ease,background .2s ease;font-family:inherit;box-sizing:border-box;letter-spacing:1px;text-align:center}.photo-post__gate-input::placeholder{color:#f5e6d340;font-weight:400;letter-spacing:0;font-size:14px}.photo-post__gate-input:focus{border-color:#f5e6d366;background:#ffffff14}.photo-post__gate-input--error{border-color:#d4756b;background:#d4756b1a}.photo-post__gate-error{font-size:13px;color:#e8a090;font-weight:500;text-align:center}.photo-post__gate-btn{width:100%;min-height:50px;border:none;border-radius:var(--radius-pill);background:linear-gradient(135deg,#d4af8c,#c49a78);color:#3b2e24;font-size:16px;font-weight:700;cursor:pointer;margin-top:6px;transition:transform .2s ease,opacity .2s ease,box-shadow .2s ease;letter-spacing:-.2px;box-shadow:0 4px 16px #a8886c4d}.photo-post__gate-btn:active:not(:disabled){transform:scale(.97);box-shadow:0 2px 8px #a8886c40}.photo-post__gate-btn:disabled{opacity:.35;cursor:default}.photo-post__gate-footer-text{font-size:12px;color:#f5e6d340;margin:28px 0 0;text-align:center}.photo-post__hub{gap:12px}.photo-post__hub .photo-post__gate-subtitle{margin-bottom:20px}.photo-post__hub-card{width:100%;max-width:400px;display:flex;align-items:center;gap:14px;padding:18px 20px;border:none;border-radius:var(--radius-md);cursor:pointer;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease;font-family:inherit;text-align:left}.photo-post__hub-card:active{transform:scale(.97)}.photo-post__hub-card--owl{background:#d4af8c2e;border:1px solid rgba(212,175,140,.25);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.photo-post__hub-card--care{background:#ffffff14;border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.photo-post__hub-card-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.photo-post__hub-card--owl .photo-post__hub-card-icon{background:linear-gradient(135deg,#d4af8c,#c49a78);color:#3b2e24}.photo-post__hub-card--care .photo-post__hub-card-icon{background:linear-gradient(135deg,#fff3,#ffffff1a);color:#f5e6d3}.photo-post__hub-card-text{display:flex;flex-direction:column;gap:4px;flex:1}.photo-post__hub-card-title{font-size:17px;font-weight:700;color:#f5e6d3;letter-spacing:.5px}.photo-post__hub-card-desc{font-size:12px;color:#f5e6d380;font-weight:400}.photo-post__hub-card-arrow{color:#f5e6d34d;flex-shrink:0}.photo-post__class-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;animation:pp-fadeIn .4s ease}.photo-post__class-grid{display:grid;grid-template-columns:1fr;gap:14px;width:100%;max-width:640px}.photo-post__class-welcome{font-size:18px;font-weight:700;color:var(--color-text);text-align:center;margin:0}.photo-post__class-welcome-sub{font-size:11px;font-weight:600;color:var(--color-muted);letter-spacing:3px;text-align:center;margin:0 0 12px}.photo-post__class-card-wrap{position:relative;width:100%}.photo-post__class-card{width:100%;min-height:88px;border:none;border-radius:var(--radius-md);background:var(--color-card);color:var(--color-text);font-size:clamp(14px,2vw,16px);cursor:pointer;display:flex;align-items:center;gap:16px;padding:18px 22px;box-shadow:var(--shadow-card);transition:transform .3s ease,box-shadow .3s ease}.photo-post__class-card:active{transform:scale(.97);box-shadow:var(--shadow-elevated)}.photo-post__class-edit-btn{position:absolute;top:8px;right:8px;width:32px;height:32px;border:none;border-radius:50%;background:#f0f1f5;color:var(--color-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;transition:background .2s ease,color .2s ease}.photo-post__class-edit-btn:active{background:#e0e1e8;color:var(--color-primary)}.photo-post__class-card-icon{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#fff8e1,#ffe8cc);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.photo-post__class-card-info{display:flex;flex-direction:column;gap:4px;flex:1;text-align:left}.photo-post__class-card-name{font-size:17px;font-weight:700;color:var(--color-text)}.photo-post__class-card-teacher{font-size:13px;color:var(--color-muted);font-weight:500}.photo-post__class-card-count{padding:6px 14px;border-radius:var(--radius-pill);background:#e8eaff;color:var(--color-primary);font-size:13px;font-weight:700;flex-shrink:0}.photo-post__select-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;animation:pp-fadeIn .4s ease}.photo-post__select-btn{width:100%;max-width:480px;min-height:80px;border:none;border-radius:var(--radius-md);background:var(--color-card);color:var(--color-text);font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:flex-start;gap:16px;padding:0 24px;box-shadow:var(--shadow-card);transition:transform .3s ease,box-shadow .3s ease}.photo-post__select-btn:active{transform:scale(.97);box-shadow:var(--shadow-elevated)}.photo-post__select-btn .icon-circle{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.photo-post__select-btn .icon-circle--gallery{background:linear-gradient(135deg,#e8eaff,#d4d8f8);color:var(--color-primary)}.photo-post__select-btn .icon-circle--camera{background:linear-gradient(135deg,#ffe8e0,#ffd4c4);color:var(--color-accent)}.photo-post__select-btn svg{width:24px;height:24px;flex-shrink:0}.photo-post__select-hint{font-size:13px;color:var(--color-muted);text-align:center;margin-top:4px}.photo-post__preview-large{width:100%;border-radius:var(--radius-lg);object-fit:cover;max-height:60vh;background:#edeef5;box-shadow:var(--shadow-card);animation:pp-fadeIn .3s ease}.photo-post__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;animation:pp-fadeIn .35s ease}.photo-post__thumb-wrap{position:relative;aspect-ratio:3 / 4;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;box-shadow:var(--shadow-card);transition:transform .3s ease,box-shadow .3s ease}.photo-post__thumb-wrap:active{transform:scale(.95)}.photo-post__thumb{width:100%;height:100%;object-fit:cover}.photo-post__thumb-wrap--selected{outline:3px solid var(--color-primary);outline-offset:-3px;box-shadow:0 0 0 3px #5b6abf33,var(--shadow-card)}.photo-post__thumb-delete{position:absolute;top:6px;right:6px;width:24px;height:24px;border:none;border-radius:50%;background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);color:#fff;font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.photo-post__thumb-delete:active{background:var(--color-danger)}.photo-post__preview-actions{display:flex;gap:8px;animation:pp-fadeIn .4s ease}.photo-post__add-btn{flex:1;min-height:48px;border:2px dashed #D0D3E0;border-radius:var(--radius-sm);background:transparent;color:var(--color-muted);font-size:14px;font-weight:600;cursor:pointer;transition:border-color .3s ease,color .3s ease,background .3s ease}.photo-post__add-btn:active{border-color:var(--color-primary);color:var(--color-primary);background:#5b6abf0d}.photo-post__detect-summary{display:flex;align-items:center;justify-content:center;gap:16px;padding:16px 20px;background:var(--color-card);border-radius:var(--radius-md);box-shadow:var(--shadow-card);animation:pp-fadeIn .3s ease}.photo-post__detect-summary-item{display:flex;flex-direction:column;align-items:center;gap:4px}.photo-post__detect-summary-number{font-size:24px;font-weight:700;color:var(--color-primary)}.photo-post__detect-summary-label{font-size:12px;color:var(--color-muted);font-weight:500}.photo-post__detect-summary-divider{width:1px;height:36px;background:#e8e9f0}.photo-post__detect-item{position:relative;border-radius:var(--radius-md);overflow:hidden;background:#edeef5;box-shadow:var(--shadow-card);animation:pp-fadeIn .4s ease;flex-shrink:0}.photo-post__detect-item--clickable{cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s ease,box-shadow .15s ease}.photo-post__detect-item--clickable:active{transform:scale(.98);box-shadow:var(--shadow-elevated)}.photo-post__detect-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.photo-post__detect-img{width:100%;display:block;min-height:280px;object-fit:cover;pointer-events:none;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.photo-post__detect-tap-hint{position:absolute;bottom:0;left:0;right:0;padding:12px 16px;background:linear-gradient(to top,rgba(0,0,0,.55) 0%,transparent 100%);color:#fff;font-size:14px;font-weight:600;text-align:center;pointer-events:none;z-index:2}.photo-post__detect-badge{position:absolute;top:12px;right:12px;padding:6px 14px;border-radius:var(--radius-pill);font-size:13px;font-weight:700;color:#fff;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);pointer-events:none;z-index:3}.photo-post__detect-badge--found{background:var(--color-success);box-shadow:0 2px 8px #4ecdc459}.photo-post__detect-badge--none{background:var(--color-danger);box-shadow:0 2px 8px #ff6b6b59}.photo-post__detect-badge--inline{position:static}.photo-post__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:48px 0;color:var(--color-text);animation:pp-fadeIn .3s ease}.photo-post__loading-text{font-size:15px;font-weight:600;color:var(--color-text)}.photo-post__loading-progress{font-size:13px;color:var(--color-muted)}.photo-post__footer{padding:12px 20px;padding-bottom:max(12px,env(safe-area-inset-bottom));background:#ffffffeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(0,0,0,.06);flex-shrink:0;position:sticky;bottom:0;z-index:20}.photo-post__action-btn{width:100%;min-height:52px;border:none;border-radius:var(--radius-pill);font-size:16px;font-weight:700;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease,opacity .2s ease;letter-spacing:-.2px}.photo-post__action-btn:active{transform:scale(.97)}.photo-post__action-btn:disabled{cursor:default;opacity:.5;transform:none}.photo-post__action-btn--primary{background:linear-gradient(135deg,var(--color-primary) 0%,#7B8AD4 100%);color:#fff;box-shadow:0 4px 16px #5b6abf59}.photo-post__action-btn--primary:active:not(:disabled){box-shadow:0 2px 8px #5b6abf4d}.photo-post__action-btn--secondary{background:var(--color-card);color:var(--color-text);box-shadow:var(--shadow-card)}.photo-post .spinner{width:36px;height:36px;border:3px solid #E8E9F0;border-top-color:var(--color-accent);border-radius:50%;animation:pp-spin .8s linear infinite}.photo-post__match-header{text-align:center;animation:pp-fadeIn .3s ease}.photo-post__match-title{font-size:20px;font-weight:700;margin:0 0 4px;color:var(--color-text)}.photo-post__match-subtitle{font-size:14px;color:var(--color-muted);margin:0}.photo-post__match-item{background:var(--color-card);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-card);animation:pp-fadeIn .4s ease;flex-shrink:0;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s ease,box-shadow .15s ease}.photo-post__match-item:active{transform:scale(.98);box-shadow:var(--shadow-elevated)}.photo-post__match-img-wrap{position:relative;overflow:hidden}.photo-post__match-img{width:100%;display:block;min-height:280px;object-fit:cover;pointer-events:none;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.photo-post__match-img-hint{position:absolute;bottom:0;left:0;right:0;padding:10px 16px;background:linear-gradient(to top,rgba(0,0,0,.5) 0%,transparent 100%);color:#fff;font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px;pointer-events:none}.photo-post__match-info-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.photo-post__match-hint{font-size:12px;color:var(--color-accent);font-weight:500}.photo-post__detect-badge--manual{background:var(--color-accent);box-shadow:0 2px 8px #ff8c6b59}.photo-post__match-info{padding:12px 16px;display:flex;flex-direction:column;gap:10px;position:relative;z-index:4;background:var(--color-card)}.photo-post__assign-btn{border:none;border-radius:var(--radius-pill);background:linear-gradient(135deg,var(--color-primary) 0%,#7B8AD4 100%);color:#fff;font-size:14px;font-weight:600;padding:10px 20px;cursor:pointer;align-self:flex-start;position:relative;z-index:2;-webkit-tap-highlight-color:transparent;transition:transform .2s ease,box-shadow .2s ease}.photo-post__assign-btn:active{transform:scale(.95);box-shadow:0 2px 8px #5b6abf66}.photo-post__name-chips{display:flex;flex-wrap:wrap;gap:8px}.photo-post__name-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-pill);background:#e8eaff;color:var(--color-primary);font-size:13px;font-weight:600}.photo-post__name-chip-remove{border:none;background:none;color:var(--color-primary);font-size:16px;line-height:1;cursor:pointer;padding:0;opacity:.6;transition:opacity .2s ease}.photo-post__name-chip-remove:active{opacity:1}.photo-post__modal-overlay{position:fixed;inset:0;background:#0006;z-index:100;display:flex;align-items:flex-end;justify-content:center}.photo-post__modal{width:100%;max-width:520px;background:var(--color-card);border-radius:var(--radius-lg) var(--radius-lg) 0 0;animation:slideUp .3s ease;max-height:70vh;display:flex;flex-direction:column}.photo-post__modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 12px;border-bottom:1px solid #F0F1F5;flex-shrink:0}.photo-post__modal-title{font-size:18px;font-weight:700;margin:0;color:var(--color-text)}.photo-post__modal-close{width:32px;height:32px;border:none;border-radius:50%;background:#f0f1f5;color:var(--color-muted);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.photo-post__modal-close:active{background:#e0e1e8}.photo-post__modal-body{padding:12px 20px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:8px}.photo-post__modal-footer{padding:12px 20px 20px;padding-bottom:max(20px,env(safe-area-inset-bottom));flex-shrink:0}.photo-post__child-card{display:flex;align-items:center;gap:12px;padding:14px 16px;border:2px solid #F0F1F5;border-radius:var(--radius-sm);background:var(--color-card);cursor:pointer;transition:border-color .2s ease,background .2s ease;width:100%;text-align:left}.photo-post__child-card:active{background:#fafbfe}.photo-post__child-card--selected{border-color:var(--color-primary);background:#f0f1ff}.photo-post__child-checkbox{width:24px;height:24px;border-radius:6px;border:2px solid #D0D3E0;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .2s ease,background .2s ease}.photo-post__child-card--selected .photo-post__child-checkbox{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.photo-post__child-card-info{display:flex;flex-direction:column;gap:2px}.photo-post__child-card-name{font-size:15px;font-weight:600;color:var(--color-text)}.photo-post__child-card-parent{font-size:13px;color:var(--color-muted)}.photo-post__send-container{display:flex;flex-direction:column;align-items:center;gap:16px;animation:pp-fadeIn .4s ease;padding-top:20px}.photo-post__success-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--color-success) 0%,#3DBDB5 100%);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 20px #4ecdc459;animation:pp-pulse 2s ease infinite}.photo-post__send-title{font-size:22px;font-weight:700;margin:0;color:var(--color-text)}.photo-post__send-subtitle{font-size:14px;color:var(--color-muted);margin:0}.photo-post__send-child-section{width:100%;background:var(--color-card);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-card);animation:pp-fadeIn .4s ease}.photo-post__send-child-header{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid #F0F1F5}.photo-post__send-photo-count{margin-left:auto;font-size:13px;color:var(--color-muted);font-weight:500}.photo-post__send-photos{display:flex;gap:10px;padding:12px 16px;overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}.photo-post__send-photo-wrap{position:relative;flex-shrink:0;width:220px;border-radius:var(--radius-sm);overflow:hidden;box-shadow:0 2px 8px #0000001a;scroll-snap-align:start}.photo-post__send-photo-img{width:100%;height:280px;object-fit:cover;display:block}.photo-post__send-photo-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.photo-post__send-photo-tag{position:absolute;bottom:10px;left:10px;padding:6px 16px;border-radius:var(--radius-pill);background:var(--color-primary);color:#fff;font-size:14px;font-weight:700;box-shadow:0 2px 10px #5b6abf80;letter-spacing:-.2px}.photo-post__send-child-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#e8eaff,#d4d8f8);color:var(--color-primary);font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.photo-post__send-child-info{display:flex;flex-direction:column;gap:2px}.photo-post__send-child-name{font-size:15px;font-weight:600;color:var(--color-text)}.photo-post__send-child-parent{font-size:13px;color:var(--color-muted)}.photo-post__link-container{width:100%;background:var(--color-card);border-radius:var(--radius-md);padding:14px 16px;box-shadow:var(--shadow-card);display:flex;align-items:center;gap:12px}.photo-post__link-text{flex:1;font-size:13px;color:var(--color-muted);word-break:break-all;line-height:1.4}.photo-post__copy-btn{border:none;border-radius:var(--radius-pill);background:linear-gradient(135deg,var(--color-primary) 0%,#7B8AD4 100%);color:#fff;font-size:13px;font-weight:700;padding:10px 20px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:transform .2s ease,background .2s ease}.photo-post__copy-btn:active{transform:scale(.95)}.photo-post__copy-btn--copied{background:linear-gradient(135deg,var(--color-success) 0%,#3DBDB5 100%)}.photo-post__blog-draft-section{width:100%;background:var(--color-card);border-radius:var(--radius-md);padding:24px 20px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;align-items:center;gap:8px;border-top:3px solid #8B6914}.photo-post__blog-draft-textarea{width:100%;min-height:220px;border:1px solid #E0D6C8;border-radius:var(--radius-sm);padding:16px;font-size:14px;line-height:1.8;color:#3c3c3c;background:#fdfbf7;resize:vertical;font-family:inherit;margin-top:8px}.photo-post__blog-draft-textarea:focus{outline:none;border-color:#8b6914;box-shadow:0 0 0 2px #8b691426}.photo-post__blog-draft-actions{display:flex;gap:10px;width:100%;margin-top:4px}.photo-post__blog-draft-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:none;border-radius:var(--radius-sm);background:linear-gradient(135deg,#8b6914,#a67c00);color:#fff;font-size:14px;font-weight:600;cursor:pointer}.photo-post__blog-draft-btn:active{transform:scale(.97)}.photo-post__blog-draft-copy{flex:1;padding:12px 16px;border:1.5px solid #8B6914;border-radius:var(--radius-sm);background:transparent;color:#8b6914;font-size:14px;font-weight:600;cursor:pointer}.photo-post__blog-draft-copy:active{transform:scale(.97)}.photo-post__blog-draft-copy--done{background:#8b6914;color:#fff}.photo-post__blog-section{width:100%;background:var(--color-card);border-radius:var(--radius-md);padding:24px 20px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;align-items:center;gap:8px;border-top:3px solid var(--color-accent)}.photo-post__blog-section-icon{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#ffe8e0,#ffd4c4);color:var(--color-accent);display:flex;align-items:center;justify-content:center;margin-bottom:4px}.photo-post__blog-section-title{font-size:16px;font-weight:700;color:var(--color-text);margin:0}.photo-post__blog-section-desc{font-size:13px;color:var(--color-muted);margin:0;text-align:center;line-height:1.5}.photo-post__blog-progress{display:flex;align-items:center;gap:12px;padding:8px 0}.photo-post__blog-progress .spinner{width:24px;height:24px;border-width:2.5px}.photo-post__blog-progress-text{font-size:14px;color:var(--color-muted);font-weight:500}.photo-post__blog-save-btn{width:100%;min-height:52px;border:none;border-radius:var(--radius-pill);background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-dark) 100%);color:#fff;font-size:15px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:8px;box-shadow:0 4px 16px #ff8c6b59;transition:transform .2s ease,box-shadow .2s ease,opacity .2s ease;letter-spacing:-.2px}.photo-post__blog-save-btn:active:not(:disabled){transform:scale(.97);box-shadow:0 2px 8px #ff8c6b4d}.photo-post__blog-save-btn:disabled{opacity:.6;cursor:default;transform:none}.photo-post__edit-label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:var(--color-muted)}.photo-post__edit-input{width:100%;padding:12px 14px;border:2px solid #E8E9F0;border-radius:var(--radius-sm);font-size:16px;font-weight:600;color:var(--color-text);background:var(--color-bg);outline:none;transition:border-color .2s ease;font-family:inherit;box-sizing:border-box}.photo-post__edit-input:focus{border-color:var(--color-primary)}.photo-post__edit-input::placeholder{color:#c0c3d0;font-weight:400}.photo-post__sending-overlay{position:fixed;inset:0;background:#00000080;z-index:50;display:flex;align-items:center;justify-content:center}.photo-post__sending-content{background:var(--color-card);border-radius:var(--radius-lg);padding:32px 40px;display:flex;flex-direction:column;align-items:center;gap:16px;box-shadow:var(--shadow-elevated);animation:pp-fadeIn .3s ease}.photo-post__sending-text{font-size:15px;font-weight:600;color:var(--color-text);text-align:center}@media(min-width:600px){.photo-post__body{padding:28px 32px}.photo-post__gate-brand{font-size:42px;letter-spacing:8px}.photo-post__gate-subtitle{font-size:15px}.photo-post__gate-form{padding:32px 28px}.photo-post__gate-input{padding:16px 18px;font-size:18px}.photo-post__gate-btn{min-height:54px;font-size:17px}.photo-post__class-grid{grid-template-columns:repeat(2,1fr)}.photo-post__class-welcome{font-size:20px}.photo-post__grid{grid-template-columns:repeat(3,1fr)}.photo-post__detect-img{min-height:340px}.photo-post__hub-card{padding:22px 24px}.photo-post__hub-card-title{font-size:19px}.photo-post__hub-card-desc{font-size:13px}.photo-post__action-btn{max-width:480px;margin:0 auto}.photo-post__footer{display:flex;justify-content:center}.photo-post__send-container{max-width:600px;margin:0 auto}}@media(min-width:900px){.photo-post{max-width:1080px}.photo-post__body{padding:32px 40px}.photo-post__gate-brand{font-size:48px;letter-spacing:10px}.photo-post__gate,.photo-post__hub-card{max-width:440px}.photo-post__class-grid{grid-template-columns:repeat(3,1fr);max-width:840px}.photo-post__grid{grid-template-columns:repeat(4,1fr);gap:14px}.photo-post__detect-img{min-height:400px}.photo-post__select-area{flex-direction:row;flex-wrap:wrap;justify-content:center;gap:20px}.photo-post__select-btn{max-width:280px}.photo-post__send-container{max-width:700px}}@media(max-width:380px){.photo-post__body{padding:14px 14px 20px}.photo-post__gate-brand{font-size:28px;letter-spacing:4px}.photo-post__gate-form{padding:22px 18px}.photo-post__gate-input{font-size:15px;padding:12px}.photo-post__hub-card{padding:14px 16px;gap:10px}.photo-post__hub-card-icon{width:40px;height:40px;border-radius:10px}.photo-post__hub-card-icon svg{width:22px;height:22px}.photo-post__hub-card-title{font-size:15px}.photo-post__class-card{padding:14px 16px;gap:12px}.photo-post__class-card-icon{width:44px;height:44px;font-size:20px}.photo-post__header-title{font-size:16px}.photo-post__action-btn{min-height:48px;font-size:15px}}.pensieve{width:100%;max-width:960px;min-height:100dvh;margin:0 auto;display:flex;flex-direction:column;position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(160deg,#3b2e24,#5c4033,#7a5c47 60%,#a8886c);color:#f5e6d3;overflow:hidden}.pensieve__bg{position:absolute;top:-30%;right:-20%;width:70%;height:70%;background:radial-gradient(circle,rgba(212,175,140,.12) 0%,transparent 70%);pointer-events:none}.pensieve__content{flex:1;display:flex;flex-direction:column;align-items:center;padding:60px 24px 40px;gap:16px;position:relative;z-index:1}.pensieve__brand{font-size:clamp(28px,5vw,40px);font-weight:800;letter-spacing:6px;margin:0;text-shadow:0 2px 12px rgba(0,0,0,.2)}.pensieve__tagline{font-size:clamp(13px,2vw,15px);color:#f5e6d399;margin:0 0 24px;letter-spacing:.5px}.pensieve__search-box{width:100%;max-width:400px;position:relative;margin-bottom:8px}.pensieve__search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#f5e6d366;pointer-events:none}.pensieve__search-input{width:100%;padding:14px 16px 14px 48px;border:1px solid rgba(245,230,211,.15);border-radius:14px;background:#ffffff12;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:#f5e6d3;font-size:15px;outline:none;box-sizing:border-box}.pensieve__search-input::placeholder{color:#f5e6d359}.pensieve__search-input:focus{border-color:#d4af8c66;box-shadow:0 0 0 3px #d4af8c1a}.pensieve__child-list{width:100%;max-width:400px;display:flex;flex-direction:column;gap:8px}.pensieve__child-item{display:flex;align-items:center;gap:14px;width:100%;padding:14px 16px;border:1px solid rgba(245,230,211,.1);border-radius:14px;background:#ffffff0f;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:#f5e6d3;cursor:pointer;text-align:left;transition:background .2s}.pensieve__child-item:active{background:#ffffff1f}.pensieve__child-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#d4af8c4d,#d4af8c1a);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#d4af8c;flex-shrink:0}.pensieve__child-info{flex:1;display:flex;flex-direction:column;gap:2px}.pensieve__child-name{font-size:16px;font-weight:600}.pensieve__child-parent{font-size:13px;color:#f5e6d373}.pensieve__child-arrow{color:#f5e6d34d;flex-shrink:0}.pensieve__empty{text-align:center;color:#f5e6d366;font-size:14px;padding:24px 0;margin:0}.pensieve__header{width:100%;display:flex;align-items:center;gap:12px;margin-bottom:8px}.pensieve__back-btn{width:40px;height:40px;border-radius:12px;border:1px solid rgba(245,230,211,.15);background:#ffffff0f;color:#f5e6d3;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.pensieve__back-btn:active{background:#ffffff1f}.pensieve__header-info{display:flex;align-items:center;gap:12px}.pensieve__header-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#d4af8c4d,#d4af8c1a);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#d4af8c}.pensieve__header-name{font-size:20px;font-weight:700;margin:0;color:#f5e6d3}.pensieve__header-sub{font-size:13px;color:#f5e6d380;margin:2px 0 0}.pensieve__loading{display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px 0;color:#f5e6d399;font-size:14px}.pensieve__spinner{width:32px;height:32px;border:3px solid rgba(212,175,140,.2);border-top-color:#d4af8c;border-radius:50%;animation:pensieve-spin .8s linear infinite}@keyframes pensieve-spin{to{transform:rotate(360deg)}}.pensieve__notice{display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px 24px;text-align:center;color:#f5e6d380;font-size:15px}.pensieve__notice-sub{font-size:13px;color:#f5e6d34d;line-height:1.6;margin:0}.pensieve__retry-btn{padding:10px 24px;border:1px solid rgba(212,175,140,.3);border-radius:10px;background:#d4af8c1a;color:#d4af8c;font-size:14px;font-weight:600;cursor:pointer}.pensieve__retry-btn:active{background:#d4af8c33}.pensieve__section-title{font-size:18px;font-weight:700;color:#f5e6d3;margin:0 0 16px;align-self:flex-start}.pensieve__then-now{width:100%;background:#ffffff0f;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(245,230,211,.1);border-radius:20px;padding:24px 20px}.pensieve__then-now-grid{display:flex;align-items:center;gap:12px}.pensieve__then-now-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px}.pensieve__then-now-label{font-size:12px;font-weight:600;color:#f5e6d380;letter-spacing:.5px;padding:3px 12px;border-radius:20px;background:#f5e6d314}.pensieve__then-now-label--now{background:#d4af8c33;color:#d4af8c}.pensieve__then-now-img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:14px;border:2px solid rgba(245,230,211,.1)}.pensieve__then-now-date{font-size:12px;color:#f5e6d366}.pensieve__then-now-divider{color:#d4af8c66;flex-shrink:0}.pensieve__timeline{width:100%;display:flex;flex-direction:column;gap:0;position:relative;padding-left:16px}.pensieve__timeline:before{content:"";position:absolute;left:22px;top:50px;bottom:16px;width:2px;background:#d4af8c26}.pensieve__timeline-card{position:relative;padding:0 0 24px 24px}.pensieve__timeline-date-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}.pensieve__timeline-dot{width:12px;height:12px;border-radius:50%;background:#d4af8c;border:2px solid #5C4033;flex-shrink:0;position:relative;z-index:1}.pensieve__timeline-date{font-size:15px;font-weight:600;color:#f5e6d3}.pensieve__timeline-class{font-size:12px;color:#f5e6d366;padding:2px 10px;border-radius:20px;background:#f5e6d314}.pensieve__timeline-photos{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;margin-left:24px}.pensieve__timeline-photo{width:100%;aspect-ratio:1;object-fit:cover;border-radius:12px;border:1px solid rgba(245,230,211,.1)}.pensieve__footer{font-size:12px;color:#f5e6d340;margin-top:auto;padding-top:32px;text-align:center}@media(min-width:600px){.pensieve__content{padding:80px 32px 48px}.pensieve__search-box,.pensieve__child-list{max-width:500px}.pensieve__child-list{display:grid;grid-template-columns:repeat(2,1fr)}.pensieve__timeline-photos{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}@media(min-width:900px){.pensieve__content{padding:100px 48px 60px}.pensieve__child-list{max-width:700px;grid-template-columns:repeat(3,1fr)}.pensieve__timeline-photos{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.pensieve__then-now{padding:32px 28px}}.gn{width:100%;margin:0 auto;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#f8f6f1;background:#0a1628;overflow-x:hidden}[data-animate]{opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}[data-animate].gn-animate-in{opacity:1;transform:translateY(0)}.gn__section-label{font-size:clamp(12px,1.5vw,14px);font-weight:700;letter-spacing:4px;text-transform:uppercase;color:#c9a96e;margin:0 0 12px;text-align:center}.gn__section-desc{font-size:clamp(15px,2vw,18px);color:#f8f6f18c;margin:0 0 40px;text-align:center;line-height:1.6}.gn__hero{position:relative;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 24px 60px;overflow:hidden;background:linear-gradient(170deg,#0a1628,#0f1f3a 40%,#162848,#0a1628)}.gn__hero-particles{position:absolute;inset:0;background:radial-gradient(circle 300px at 20% 30%,rgba(201,169,110,.06) 0%,transparent 100%),radial-gradient(circle 200px at 75% 20%,rgba(201,169,110,.04) 0%,transparent 100%),radial-gradient(circle 250px at 60% 70%,rgba(201,169,110,.05) 0%,transparent 100%),radial-gradient(circle 180px at 30% 80%,rgba(201,169,110,.03) 0%,transparent 100%);animation:gn-drift 20s ease-in-out infinite alternate;pointer-events:none}.gn__hero-particles--2{background:radial-gradient(circle 150px at 80% 60%,rgba(248,246,241,.03) 0%,transparent 100%),radial-gradient(circle 220px at 10% 50%,rgba(201,169,110,.04) 0%,transparent 100%);animation:gn-drift2 25s ease-in-out infinite alternate}@keyframes gn-drift{0%{transform:translate(0) scale(1)}to{transform:translate(30px,-20px) scale(1.05)}}@keyframes gn-drift2{0%{transform:translate(0) scale(1)}to{transform:translate(-20px,15px) scale(1.03)}}.gn__hero-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:16px;max-width:720px}.gn__hero-badge{font-size:clamp(10px,1.3vw,13px);font-weight:600;letter-spacing:3px;text-transform:uppercase;color:#c9a96e;margin:0;padding:6px 20px;border:1px solid rgba(201,169,110,.3);border-radius:50px;animation:gn-fadeIn 1s ease-out .2s both}.gn__hero-title{font-size:clamp(48px,10vw,96px);font-weight:800;letter-spacing:clamp(8px,2vw,20px);margin:0;background:linear-gradient(135deg,#f8f6f1,#c9a96e,#e8d5a8);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-shadow:none;animation:gn-fadeIn 1s ease-out .5s both}.gn__hero-subtitle{font-size:clamp(18px,3vw,28px);font-weight:300;color:#f8f6f1d9;margin:0;letter-spacing:1px;animation:gn-fadeIn 1s ease-out .8s both}.gn__hero-desc{font-size:clamp(13px,1.8vw,16px);color:#f8f6f173;margin:8px 0 0;line-height:1.8;animation:gn-fadeIn 1s ease-out 1.1s both}@keyframes gn-fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.gn__hero-scroll{position:absolute;bottom:32px;color:#c9a96e66;animation:gn-bounce 2s ease-in-out infinite}@keyframes gn-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(10px)}}.gn__philosophy{padding:100px 24px;display:flex;flex-direction:column;align-items:center;background:linear-gradient(180deg,#0a1628,#0e1a30)}.gn__philosophy-timeline{display:flex;flex-direction:column;gap:0;max-width:560px;width:100%;margin:24px 0 40px;position:relative}.gn__philosophy-item{display:flex;align-items:flex-start;gap:20px;padding:24px 0;position:relative}.gn__philosophy-year{font-size:clamp(28px,4vw,36px);font-weight:800;color:#c9a96e;min-width:80px;text-align:right;line-height:1;padding-top:2px}.gn__philosophy-line{width:2px;align-self:stretch;background:linear-gradient(180deg,#c9a96e66,#c9a96e1a);flex-shrink:0;position:relative}.gn__philosophy-line:before{content:"";position:absolute;top:6px;left:-4px;width:10px;height:10px;border-radius:50%;background:#c9a96e}.gn__philosophy-text{font-size:clamp(15px,2vw,18px);color:#f8f6f1bf;margin:0;line-height:1.6;padding-top:0}.gn__philosophy-quote{font-size:clamp(14px,2vw,17px);font-style:italic;color:#c9a96e99;margin:0;text-align:center;letter-spacing:.5px}.gn__units{padding:100px 24px;display:flex;flex-direction:column;align-items:center;background:#0a1628}.gn__units-grid{display:grid;grid-template-columns:1fr;gap:20px;width:100%;max-width:960px}.gn__unit-card{background:linear-gradient(145deg,#1a2a44cc,#0f192ae6);border:1px solid rgba(201,169,110,.15);border-radius:20px;padding:36px 28px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;transition:transform .3s ease,border-color .3s ease,box-shadow .3s ease}.gn__unit-card:hover{transform:translateY(-6px);border-color:#c9a96e59;box-shadow:0 12px 40px #c9a96e14}.gn__unit-icon{width:64px;height:64px;border-radius:18px;background:linear-gradient(135deg,#c9a96e26,#c9a96e0d);display:flex;align-items:center;justify-content:center;color:#c9a96e;margin-bottom:4px}.gn__unit-name{font-size:22px;font-weight:800;letter-spacing:3px;margin:0;color:#f8f6f1}.gn__unit-tagline{font-size:15px;font-weight:600;color:#c9a96e;margin:0}.gn__unit-desc{font-size:14px;color:#f8f6f180;margin:0;line-height:1.7}.gn__values{padding:80px 24px;background:linear-gradient(180deg,#0e1a30,#0a1628)}.gn__values-grid{display:grid;grid-template-columns:1fr;gap:32px;max-width:960px;margin:0 auto}.gn__value-item{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}.gn__value-number{font-size:clamp(40px,7vw,64px);font-weight:800;background:linear-gradient(135deg,#c9a96e,#e8d5a8);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1}.gn__value-label{font-size:clamp(14px,2vw,16px);color:#f8f6f18c;letter-spacing:.5px}.gn__tech{padding:100px 24px;display:flex;flex-direction:column;align-items:center;background:#0a1628}.gn__tech-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;width:100%;max-width:720px}.gn__tech-card{background:#1a2a4480;border:1px solid rgba(201,169,110,.08);border-radius:16px;padding:24px 20px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;transition:border-color .3s}.gn__tech-card:hover{border-color:#c9a96e33}.gn__tech-icon{width:52px;height:52px;border-radius:14px;background:#c9a96e14;display:flex;align-items:center;justify-content:center;color:#c9a96e;margin-bottom:4px}.gn__tech-title{font-size:15px;font-weight:700;margin:0;color:#f8f6f1}.gn__tech-desc{font-size:13px;color:#f8f6f166;margin:0;line-height:1.5}.gn__cta{padding:100px 24px;display:flex;flex-direction:column;align-items:center;text-align:center;background:linear-gradient(180deg,#0a1628,#0f1f3a,#0a1628);position:relative}.gn__cta:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:120px;height:1px;background:linear-gradient(90deg,transparent 0%,#C9A96E 50%,transparent 100%)}.gn__cta-title{font-size:clamp(24px,4vw,36px);font-weight:700;margin:0 0 16px;color:#f8f6f1}.gn__cta-desc{font-size:clamp(14px,2vw,16px);color:#f8f6f180;margin:0 0 40px;line-height:1.7}.gn__cta-btn{display:inline-flex;align-items:center;gap:10px;padding:18px 40px;background:linear-gradient(135deg,#c9a96e,#a6873e);color:#0a1628;font-size:clamp(16px,2.5vw,18px);font-weight:700;border-radius:14px;text-decoration:none;letter-spacing:1px;transition:transform .2s,box-shadow .3s;box-shadow:0 4px 20px #c9a96e33}.gn__cta-btn:hover{transform:translateY(-2px);box-shadow:0 8px 32px #c9a96e4d}.gn__cta-btn:active{transform:translateY(0)}.gn__footer{padding:48px 24px;background:#060e1a;border-top:1px solid rgba(201,169,110,.1)}.gn__footer-inner{max-width:960px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}.gn__footer-brand{font-size:20px;font-weight:800;letter-spacing:6px;color:#c9a96e99}.gn__footer-links{font-size:13px;color:#f8f6f14d;letter-spacing:.5px}.gn__footer-info{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#f8f6f133}.gn__footer-copy{font-size:11px;color:#f8f6f126;margin:8px 0 0}@media(min-width:600px){.gn__units-grid{grid-template-columns:repeat(2,1fr)}.gn__values-grid{grid-template-columns:repeat(3,1fr)}.gn__philosophy-item{gap:28px}.gn__philosophy-year{min-width:100px}.gn__footer-info{flex-direction:row;gap:16px}}@media(min-width:900px){.gn__hero{padding:120px 48px 80px}.gn__units-grid{grid-template-columns:repeat(3,1fr)}.gn__tech-grid{grid-template-columns:repeat(4,1fr)}.gn__philosophy,.gn__units,.gn__tech,.gn__cta{padding-left:48px;padding-right:48px}.gn__unit-card{padding:44px 32px}.gn__philosophy-timeline{max-width:640px}}@media(max-width:380px){.gn__hero{padding:60px 16px 40px}.gn__philosophy,.gn__units,.gn__tech,.gn__values,.gn__cta{padding-left:16px;padding-right:16px}.gn__philosophy-year{min-width:56px;font-size:24px}.gn__unit-card{padding:28px 20px}.gn__cta-btn{padding:16px 28px}}
