*{margin:0;padding:0;box-sizing:border-box}html{overflow-y:scroll}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%;min-height:100dvh}.chat-container{width:100%;max-width:480px;margin:0 auto;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}.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}.admin-header-btns{display:flex;gap:8px}.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{display:flex;gap:12px;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}.form-hint{margin:4px 0 0;font-size:12px;color:#6b7280}.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}.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}.partners-section{margin-bottom:24px;padding:16px;background:#fafbfc;border:1px solid #e2e8f0;border-radius:10px}.partners-section h2{font-size:17px;margin:0 0 12px;color:#0f2647}.partners-loading,.partners-empty{color:#94a3b8;font-size:14px;padding:20px 0;text-align:center}.partners-table th{font-size:13px;white-space:nowrap}.partners-table td{font-size:13px;vertical-align:middle}.status-badge{display:inline-block;padding:2px 10px;border-radius:10px;font-size:12px;font-weight:600}.status-pending{background:#fef3c7;color:#92400e}.status-paid{background:#d1fae5;color:#065f46}.btn-approve{background:#059669;color:#fff}.btn-approve:hover{background:#047857}.approve-done{color:#28a745;font-size:18px;font-weight:700}.center-name-link{color:#1a56db;cursor:pointer;font-weight:600;text-decoration:underline;text-underline-offset:2px}.center-name-link:hover{color:#0f3aa0}.center-detail-row td{padding:0!important;border-top:none!important}.center-detail-info{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px 20px;margin:4px 8px 12px}.center-detail-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.center-detail-item{display:flex;flex-direction:column;gap:2px}.center-detail-label{font-size:11px;color:#94a3b8;font-weight:600}.center-detail-value{font-size:13px;color:#1e293b;font-weight:500}.btn-section{background:#e0f2fe;color:#0284c7}.btn-section:hover{background:#bae6fd}.section-modal{max-width:400px}.section-loading{color:#999;text-align:center;padding:20px 0}.section-list{display:flex;flex-direction:column;gap:10px;margin-bottom:16px;max-height:400px;overflow-y:auto}.section-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:background .15s}.section-item:hover{background:#f1f5f9}.section-item input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#0284c7}.section-label{font-size:14px;font-weight:500;color:#334155}.btn-minihome{background:#fce7f3;color:#be185d}.btn-minihome:hover{background:#fbcfe8}.minihome-modal{max-width:700px;max-height:85vh;display:flex;flex-direction:column;padding:0}.minihome-header{padding:20px 24px 0;border-bottom:1px solid #e5e7eb}.minihome-header h2{margin:0 0 16px;font-size:18px}.minihome-tabs{display:flex;gap:4px}.mh-tab{padding:10px 16px;border:none;background:transparent;font-size:14px;font-weight:500;color:#64748b;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.mh-tab:hover{color:#1e40af}.mh-tab.active{color:#1e40af;border-bottom-color:#1e40af}.mh-loading{padding:40px;text-align:center;color:#94a3b8}.mh-body{flex:1;overflow-y:auto;padding:20px 24px}.mh-tab-content{display:flex;flex-direction:column;gap:16px}.mh-tab-content .form-group{margin-bottom:0}.mh-tab-content .form-group label{font-size:13px;font-weight:600;color:#374151;margin-bottom:6px;display:block}.mh-tab-content .form-group input,.mh-tab-content .form-group select,.mh-tab-content .form-group textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;box-sizing:border-box}.mh-tab-content .form-group textarea{resize:vertical;font-family:inherit}.form-row .form-group{flex:1}.mh-save-btn{padding:12px 20px;background:linear-gradient(135deg,#1a56db,#1e40af);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;margin-top:8px}.mh-save-btn:hover:not(:disabled){opacity:.9}.mh-save-btn:disabled{background:#cbd5e1;cursor:not-allowed}.mh-section-group{background:#f8fafc;border-radius:10px;padding:16px}.mh-section-group h4{margin:0 0 12px;font-size:14px;color:#1e293b}.mh-section-group input,.mh-section-group textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;margin-bottom:8px;box-sizing:border-box}.mh-section-group textarea{resize:vertical;font-family:inherit}.mh-gallery-upload{display:flex;gap:10px;align-items:center;margin-bottom:16px}.mh-gallery-upload input[type=text]{flex:1;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.mh-upload-btn{padding:10px 16px;background:linear-gradient(135deg,#4a90d9,#3a7bc8);color:#fff;font-size:14px;font-weight:600;border-radius:6px;cursor:pointer;white-space:nowrap}.mh-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.mh-gallery-item{position:relative;border-radius:8px;overflow:hidden;background:#f3f4f6}.mh-gallery-item img{width:100%;aspect-ratio:1;-o-object-fit:cover;object-fit:cover}.mh-gallery-caption{padding:6px 8px;font-size:11px;color:#6b7280;margin:0;background:#f9fafb;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mh-gallery-delete{position:absolute;top:4px;right:4px;padding:4px 8px;background:#ef4444e6;color:#fff;font-size:11px;font-weight:600;border:none;border-radius:4px;cursor:pointer;opacity:0;transition:opacity .2s}.mh-gallery-item:hover .mh-gallery-delete{opacity:1}.mh-empty{text-align:center;color:#9ca3af;padding:24px;background:#f9fafb;border-radius:8px}.mh-add-notice-btn{padding:10px 16px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer}.mh-notice-form{background:#f8fafc;border-radius:10px;padding:16px;display:flex;flex-direction:column;gap:10px}.mh-notice-form select,.mh-notice-form input,.mh-notice-form textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;box-sizing:border-box}.mh-notice-form textarea{resize:vertical;font-family:inherit}.mh-notice-options{display:flex;gap:16px}.mh-notice-options label{display:flex;align-items:center;gap:6px;font-size:14px;color:#374151;cursor:pointer}.mh-notice-form-actions{display:flex;gap:8px;justify-content:flex-end}.mh-notice-form-actions button{padding:8px 16px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer}.mh-notice-form-actions button:first-child{background:#e5e7eb;color:#374151}.mh-notice-form-actions button:last-child{background:linear-gradient(135deg,#1a56db,#1e40af);color:#fff}.mh-notices-list{display:flex;flex-direction:column;gap:10px;margin-top:12px}.mh-notice-item{background:#f9fafb;border-radius:8px;padding:12px 14px;border-left:3px solid #e5e7eb}.mh-notice-badges{display:flex;gap:6px;margin-bottom:6px}.mh-badge{padding:2px 8px;font-size:11px;font-weight:600;border-radius:4px}.mh-badge--general{background:#f3f4f6;color:#374151}.mh-badge--newsletter{background:#dbeafe;color:#1e40af}.mh-badge--event{background:#fce7f3;color:#be185d}.mh-badge--menu{background:#d1fae5;color:#065f46}.mh-badge--pin{background:#dbeafe;color:#1e40af}.mh-badge--popup{background:#fef3c7;color:#b45309}.mh-notice-item h5{font-size:14px;font-weight:600;color:#111827;margin:0 0 4px}.mh-notice-item p{font-size:13px;color:#6b7280;margin:0 0 8px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.mh-notice-actions{display:flex;gap:6px}.mh-notice-actions button{padding:4px 10px;font-size:12px;font-weight:500;border:none;border-radius:4px;cursor:pointer}.mh-notice-actions button:first-child{background:#e5e7eb;color:#374151}.mh-notice-actions button:last-child{background:#fee2e2;color:#dc2626}.mh-footer{padding:16px 24px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end}@media(max-width:600px){.admin-container{padding:12px}.admin-table{min-width:600px}.stats-cards{flex-direction:column}.center-detail-grid{grid-template-columns:repeat(2,1fr)}}.service-container{min-height:100dvh;background:linear-gradient(145deg,#f0f4f9,#e8edf5)}.service-header{background:linear-gradient(135deg,#0f2647,#1a3a6e,#1a56db);padding:28px 24px 24px;color:#fff;display:flex;justify-content:space-between;align-items:flex-start}.service-header-left h1{margin:0;font-size:22px;font-weight:800;letter-spacing:-.5px}.service-header-left p{margin:4px 0 0;font-size:13px;color:#ffffffb3}.service-header-right{display:flex;align-items:center;gap:12px}.header-user{font-size:13px;color:#fffc}.service-logout{padding:6px 16px;border:1px solid rgba(255,255,255,.3);border-radius:6px;background:transparent;color:#fff;font-size:13px;cursor:pointer;transition:background .2s}.service-logout:hover{background:#ffffff1f}.service-main{max-width:900px;margin:0 auto;padding:32px 20px 60px}.service-welcome{margin-bottom:32px}.service-welcome h2{margin:0;font-size:22px;font-weight:700;color:#0f2647}.service-welcome-desc{margin:8px 0 0;font-size:15px;color:#4b5563;line-height:1.6}.service-identity-tags{display:flex;gap:10px;margin-top:14px}.identity-tag{display:inline-block;padding:4px 14px;border:1.5px solid;border-radius:20px;font-size:13px;font-weight:600;letter-spacing:.3px;background:#fff}.service-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.service-card{background:#fff;border-radius:14px;border:1px solid #e2e8f0;padding:28px 24px;display:flex;flex-direction:column;transition:transform .15s,box-shadow .15s;cursor:default;position:relative;overflow:hidden}.service-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.service-card--owlpost:before{background:linear-gradient(90deg,#d97706,#fbbf24)}.service-card--carebot:before{background:linear-gradient(90deg,#059669,#34d399)}.service-card--pensieve:before{background:linear-gradient(90deg,#7c3aed,#a78bfa)}.service-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0f26471a}.card-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:26px;margin-bottom:18px;flex-shrink:0}.card-icon--owlpost{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706}.card-icon--carebot{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669}.card-icon--pensieve{background:linear-gradient(135deg,#ede9fe,#ddd6fe);color:#7c3aed}.card-title{font-size:18px;font-weight:700;color:#0f2647;margin:0 0 4px}.card-tagline{font-size:14px;font-weight:600;color:#374151;margin:0 0 10px;letter-spacing:-.2px}.card-desc{font-size:14px;color:#6b7280;line-height:1.65;margin:0 0 20px;flex:1}.card-btn{display:inline-block;padding:10px 0;text-align:center;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s;text-decoration:none;color:#fff}.card-btn--owlpost{background:#d97706}.card-btn--owlpost:hover{background:#b45309}.card-btn--carebot{background:#059669}.card-btn--carebot:hover{background:#047857}.card-btn--pensieve{background:#7c3aed}.card-btn--pensieve:hover{background:#6d28d9}.card-badge-soon{display:inline-block;background:#f1f5f9;color:#94a3b8;font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px;margin-left:8px}.service-footer{text-align:center;margin-top:48px;padding-top:24px;border-top:1px solid #e2e8f0}.service-footer-brand{font-size:18px;font-weight:800;color:#0f2647;letter-spacing:-.5px}.service-footer-services{font-size:12px;color:#94a3b8;margin-top:6px}.service-footer-info{display:flex;flex-direction:column;gap:2px;margin-top:12px}.service-footer-info span,.service-footer-info a{font-size:12px;color:#9ca3af}.service-footer-info a{text-decoration:none}.service-footer-info a:hover{color:#6b7280;text-decoration:underline}.service-footer-copy{font-size:11px;color:#c0c5cc;margin-top:10px}@media(max-width:640px){.service-header{flex-direction:column;gap:12px}.service-header-right{width:100%;justify-content:space-between}.service-cards{grid-template-columns:1fr}}.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%;margin:0 auto;display:flex;flex-direction:column;position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--color-text);padding:32px 20px 60px}.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:20px;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:600px;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-owl{font-size:128px;margin-bottom:8px;line-height:1}.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::-moz-placeholder{color:#f5e6d340;font-weight:400;letter-spacing:0;font-size:14px}.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:54px;border:none;border-radius:var(--radius-pill);background:linear-gradient(135deg,#d4af8c,#c49a78);color:#3b2e24;font-size:18px;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:600px;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:900px}.photo-post__class-welcome{font-size:21px;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:19px;font-weight:700;color:var(--color-text)}.photo-post__class-card-teacher{font-size:15px;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:600px;min-height:88px;border:none;border-radius:var(--radius-md);background:var(--color-card);color:var(--color-text);font-size:18px;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 .icon-circle--multiple{background:linear-gradient(135deg,#e0f8e8,#c4f0d4);color:#059669}.photo-post__select-btn svg{width:24px;height:24px;flex-shrink:0}.photo-post__select-hint{font-size:15px;color:var(--color-muted);text-align:center;margin-top:6px}.photo-post__preview-large{width:100%;aspect-ratio:4 / 3;border-radius:16px;-o-object-fit:cover;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%;-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center}.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:28px;font-weight:700;color:var(--color-primary)}.photo-post__detect-summary-label{font-size:14px;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;-o-object-fit:cover;object-fit:cover;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.photo-post__detect-tap-hint{position:absolute;bottom:0;left:0;right:0;padding:14px 16px;background:linear-gradient(to top,rgba(0,0,0,.55) 0%,transparent 100%);color:#fff;font-size:16px;font-weight:600;text-align:center;pointer-events:none;z-index:2}.photo-post__detect-badge{position:absolute;top:12px;right:12px;padding:8px 16px;border-radius:var(--radius-pill);font-size:15px;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--auto{background:#2563eb;box-shadow:0 2px 8px #2563eb66}.photo-post__detect-badge--inline{position:static}.photo-post__auto-match-banner{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 20px;background:#2563eb;border-radius:var(--radius-md);animation:pp-fadeIn .4s ease}.photo-post__auto-match-icon{width:36px;height:36px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.photo-post__auto-match-text{font-size:18px;font-weight:700;color:#fff;letter-spacing:-.3px}.photo-post__cluster-info{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;animation:pp-fadeIn .3s ease}.photo-post__cluster-chip{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-pill);background:var(--color-card);box-shadow:var(--shadow-card)}.photo-post__cluster-chip-label{font-size:15px;font-weight:700;color:var(--color-primary)}.photo-post__cluster-chip-detail{font-size:14px;color:var(--color-muted);font-weight:500}.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:17px;font-weight:600;color:var(--color-text)}.photo-post__loading-progress{font-size:15px;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:56px;border:none;border-radius:var(--radius-pill);font-size:18px;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__signup-btn{background:linear-gradient(135deg,#c9a96e,#a6873e);color:#0a1628;box-shadow:0 4px 16px #c9a96e4d;font-weight:700;letter-spacing:.5px;margin-top:6px}.photo-post__signup-btn:active{box-shadow:0 2px 8px #c9a96e40}.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:16px;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;-o-object-fit:cover;object-fit:cover;pointer-events:none;-webkit-user-select:none;-moz-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-name-bar{padding:12px 16px;display:flex;align-items:center;gap:10px;background:#2563eb;position:relative;z-index:4}.photo-post__match-name-list{display:flex;flex-wrap:wrap;gap:6px;flex:1}.photo-post__match-name-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:var(--radius-pill);background:#fff3;color:#fff;font-size:14px;font-weight:700}.photo-post__match-name-remove{border:none;background:none;color:#ffffffb3;font-size:16px;line-height:1;cursor:pointer;padding:0}.photo-post__match-name-bar .photo-post__assign-btn{background:#fff3;box-shadow:none;font-size:13px;padding:6px 14px}.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:8px 14px;border-radius:var(--radius-pill);background:#e8eaff;color:var(--color-primary);font-size:15px;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:17px;font-weight:600;color:var(--color-text)}.photo-post__child-card-parent{font-size:15px;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:24px;font-weight:700;margin:0;color:var(--color-text)}.photo-post__send-subtitle{font-size:16px;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;-o-object-fit:cover;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:18px;font-weight:600;color:var(--color-text)}.photo-post__send-child-parent{font-size:15px;color:var(--color-muted)}.photo-post__send-child-name-bar{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:#2563eb;color:#fff}.photo-post__send-child-name-text{font-size:18px;font-weight:700;letter-spacing:-.2px}.photo-post__send-child-meta{font-size:14px;font-weight:500;opacity:.85}.photo-post__send-photo-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;padding:12px}.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:2;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-title-input{width:100%;padding:14px 16px;border:2px solid #E0D6C8;border-radius:var(--radius-sm);font-size:20px;font-weight:700;color:#3c3c3c;background:#fdfbf7;outline:none;font-family:inherit;box-sizing:border-box;transition:border-color .2s ease,box-shadow .2s ease;letter-spacing:-.3px}.photo-post__blog-title-input::-moz-placeholder{color:#c0b8a8;font-weight:400;font-size:18px}.photo-post__blog-title-input::placeholder{color:#c0b8a8;font-weight:400;font-size:18px}.photo-post__blog-title-input:focus{border-color:#8b6914;box-shadow:0 0 0 2px #8b691426}.photo-post__blog-title-hint{font-size:13px;color:var(--color-muted);margin:0;line-height:1.5;text-align:left;width:100%}.photo-post__blog-save-draft-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;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;transition:transform .2s ease,background .2s ease,color .2s ease}.photo-post__blog-save-draft-btn:active{transform:scale(.97)}.photo-post__blog-save-draft-btn--done{background:#16a34a;border-color:#16a34a;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__finalize-btn{width:100%;min-height:56px;border:none;border-radius:var(--radius-pill);background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;margin-top:8px;box-shadow:0 4px 16px #16a34a59;transition:transform .2s ease,box-shadow .2s ease;letter-spacing:-.2px}.photo-post__finalize-btn:active{transform:scale(.97);box-shadow:0 2px 8px #16a34a4d}.photo-post__finalized-section{width:100%;display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 20px;background:var(--color-card);border-radius:var(--radius-md);box-shadow:var(--shadow-card);border-top:3px solid #16A34A;animation:pp-fadeIn .4s ease}.photo-post__finalized-icon{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#16a34a,#15803d);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 16px #16a34a4d}.photo-post__finalized-text{font-size:18px;font-weight:700;color:var(--color-text);text-align:center;line-height:1.6;margin:0}.photo-post__new-session-btn{width:100%;min-height:56px;border:none;border-radius:var(--radius-pill);background:linear-gradient(135deg,var(--color-primary) 0%,#7B8AD4 100%);color:#fff;font-size:18px;font-weight:700;cursor:pointer;box-shadow:0 4px 16px #5b6abf59;transition:transform .2s ease,box-shadow .2s ease;letter-spacing:-.2px}.photo-post__new-session-btn:active{transform:scale(.97);box-shadow:0 2px 8px #5b6abf4d}.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::-moz-placeholder{color:#c0c3d0;font-weight:400}.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:640px){.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:900px;margin:0 auto}}@media(min-width:900px){.photo-post{max-width:900px;margin:0 auto}.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:600px}.photo-post__class-grid{grid-template-columns:repeat(3,1fr);max-width:900px}.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:400px}.photo-post__send-container{max-width:900px}}@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}}.photo-post__quality-selector{width:100%;max-width:400px;margin-bottom:24px;padding:16px;background:var(--color-card);border-radius:var(--radius-md);box-shadow:var(--shadow-card)}.photo-post__quality-label{display:block;font-size:14px;font-weight:600;color:var(--color-text);margin-bottom:12px;text-align:center}.photo-post__quality-options{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.photo-post__quality-btn{display:flex;flex-direction:column;align-items:center;padding:12px 8px;background:#f5f5f5;border:2px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease}.photo-post__quality-btn:hover{background:#eee}.photo-post__quality-btn--active{background:#e8f0fe;border-color:var(--color-primary)}.photo-post__quality-name{font-size:14px;font-weight:600;color:var(--color-text);margin-bottom:4px}.photo-post__quality-desc{font-size:11px;color:var(--color-muted)}.photo-post__quality-btn--active .photo-post__quality-name{color:var(--color-primary)}@media(max-width:480px){.photo-post__quality-options{grid-template-columns:repeat(2,1fr)}.photo-post__quality-btn{padding:10px 6px}.photo-post__quality-name{font-size:13px}.photo-post__quality-desc{font-size:10px}}.photo-post__child-links-section{margin:24px 0;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:var(--radius-md);color:#fff}.photo-post__child-links-title{margin:0 0 4px;font-size:16px;font-weight:700}.photo-post__child-links-desc{margin:0 0 16px;font-size:13px;opacity:.9}.photo-post__child-links-list{display:flex;flex-direction:column;gap:12px}.photo-post__child-link-item{background:#ffffff26;border-radius:var(--radius-sm);padding:12px 14px}.photo-post__child-link-name{display:block;font-size:14px;font-weight:600;margin-bottom:8px}.photo-post__child-link-row{display:flex;align-items:center;gap:8px}.photo-post__child-link-text{flex:1;font-size:11px;opacity:.85;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.photo-post__child-link-copy-btn{flex-shrink:0;padding:6px 14px;font-size:12px;font-weight:600;color:#667eea;background:#fff;border:none;border-radius:16px;cursor:pointer;transition:transform .15s,box-shadow .15s}.photo-post__child-link-copy-btn:hover{transform:scale(1.05);box-shadow:0 2px 8px #0003}.photo-post__child-link-copy-btn:active{transform:scale(.98)}.photo-post__link-label{display:block;font-size:12px;color:var(--color-muted);margin-bottom:8px}.photo-post__link-row{display:flex;align-items:center;gap:8px}.signup-form-card{background:#fff;border-radius:14px;border:1px solid #e2e8f0;padding:28px 24px}.signup-header{text-align:center;margin-bottom:36px}.header-badge{display:inline-block;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#1a56db;background:#e8f0fe;padding:5px 14px;border-radius:20px;margin-bottom:14px}.signup-header h1{font-size:30px;font-weight:800;color:#0f2647;margin-bottom:6px}.signup-subtitle{font-size:14px;color:#5b7a9d;font-weight:500}.form-section{margin-bottom:8px;padding:20px;background:#f8fafd;border-radius:12px;border:1px solid #e8edf4}.section-title{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:700;color:#1f2937;margin-bottom:16px}.section-number{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:#1a56db;color:#fff;border-radius:50%;font-size:12px;font-weight:700;flex-shrink:0}.section-caption{font-size:12px;color:#6b7280;margin-top:-8px;margin-bottom:14px}.section-badge-soon{display:inline-block;background:#f1f5f9;color:#94a3b8;font-size:11px;font-weight:600;padding:2px 10px;border-radius:10px;margin-left:8px}.card-payment-preview{display:flex;align-items:center;gap:14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:16px 18px;cursor:pointer;transition:background .2s,border-color .2s}.card-payment-preview:hover{background:#f0f4ff;border-color:#1a56db}.card-payment-icon{font-size:28px;flex-shrink:0}.card-payment-text{display:flex;flex-direction:column;gap:2px;flex:1}.card-payment-text strong{font-size:14px;color:#0f2647}.card-payment-text span{font-size:12px;color:#94a3b8}.card-payment-arrow{font-size:18px;color:#94a3b8;flex-shrink:0}.signup-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:5px;flex:1}.form-group+.form-group{margin-top:10px}.form-row{display:flex;gap:12px}.form-row .form-group+.form-group{margin-top:0}.form-group label{font-size:12px;font-weight:600;color:#4b5563}.form-group input{padding:11px 14px;border:1.5px solid #d1d9e6;border-radius:8px;font-size:14px;color:#1f2937;transition:border-color .2s,box-shadow .2s;outline:none;background:#fff}.form-group input::-moz-placeholder{color:#9ca3af}.form-group input::placeholder{color:#9ca3af}.form-group input:focus{border-color:#1a56db;box-shadow:0 0 0 3px #1a56db1a}.form-hint{margin:4px 0 0;font-size:11px;color:#6b7280}.plan-selector{margin-bottom:16px}.plan-select-label{display:block;font-size:12px;font-weight:600;color:#4b5563;margin-bottom:6px}.plan-select-wrap{position:relative}.plan-select{width:100%;padding:12px 40px 12px 14px;border:1.5px solid #d1d9e6;border-radius:8px;font-size:14px;font-weight:500;color:#1f2937;background:#fff;outline:none;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b7280' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;transition:border-color .2s,box-shadow .2s}.plan-select:focus{border-color:#1a56db;box-shadow:0 0 0 3px #1a56db1a}.plan-result{background:#fff;border:1.5px solid #1a56db;border-radius:12px;padding:20px;position:relative;overflow:hidden}.plan-badge{display:inline-block;font-size:11px;font-weight:700;padding:3px 10px;border-radius:12px;margin-bottom:12px}.plan-badge--best{background:#1a56db;color:#fff}.plan-badge--popular{background:#fef3c7;color:#92400e}.plan-result-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.plan-result-label{font-size:12px;color:#6b7280;font-weight:500}.plan-result-value{font-size:14px;font-weight:700;color:#1f2937}.plan-result-price{display:flex;align-items:baseline;gap:8px;margin-bottom:10px}.plan-price-main{font-size:24px;font-weight:800;color:#1a56db;letter-spacing:-.5px}.plan-price-per{font-size:12px;color:#6b7280}.plan-result-usd{font-size:12px;color:#1a56db;background:#f0f5ff;border-radius:6px;padding:6px 10px;margin-bottom:10px;display:inline-block}.plan-result-desc{font-size:12px;color:#6b7280;line-height:1.5;padding-top:10px;border-top:1px solid #e8edf4;margin-bottom:0}.deposit-info{background:#fff;border:1.5px solid #d1d9e6;border-radius:10px;padding:14px 18px}.deposit-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:14px;color:#4b5563}.deposit-row+.deposit-row{border-top:1px solid #f0f2f5}.deposit-row strong{font-weight:700;color:#0f2647}.copy-btn{padding:4px 12px;font-size:12px;font-weight:600;color:#1a56db;background:#e8f0fe;border:1px solid #c3d9f7;border-radius:6px;cursor:pointer;transition:background .15s,color .15s;flex-shrink:0;margin-left:8px}.copy-btn:hover{background:#1a56db;color:#fff}.pending-screen{text-align:center;padding:20px 0}.pending-screen h2{font-size:22px;font-weight:800;color:#0f2647;margin-bottom:8px}.pending-sub{font-size:14px;color:#6b7280;margin-bottom:28px;line-height:1.6}.pending-spinner{width:48px;height:48px;margin:0 auto 20px;border:4px solid #e8edf4;border-top-color:#1a56db;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.bank-info-card{background:#f8fafd;border:1.5px solid #d4e2f7;border-radius:14px;padding:6px 0;margin-bottom:24px;text-align:left}.bank-row{display:flex;justify-content:space-between;align-items:center;padding:13px 22px}.bank-row+.bank-row{border-top:1px solid #e8edf4}.bank-row--total{background:#f0f5ff;border-radius:0 0 12px 12px}.bank-label{font-size:13px;color:#6b7280;font-weight:500}.bank-value{font-size:14px;font-weight:600;color:#1f2937}.bank-account{font-family:SF Mono,Consolas,monospace;letter-spacing:.5px;color:#0f2647;font-weight:700}.bank-amount{font-size:18px;font-weight:800;color:#1a56db;letter-spacing:-.3px}.pending-notice{background:#fef3c7;border:1px solid #fcd34d;border-radius:10px;padding:14px 18px;margin-bottom:20px}.pending-notice p{font-size:13px;color:#92400e;font-weight:600;margin:2px 0}.pending-info{font-size:13px;color:#6b7280;line-height:1.6}.pending-info strong{color:#1f2937;font-weight:700}.agreement-box{background:#fff;border:1px solid #d1d9e6;border-radius:10px;padding:14px 16px}.agreement-all{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:700;color:#1f2937;cursor:pointer;padding:4px 0}.agreement-divider{border:none;border-top:1px solid #e5e9f0;margin:10px 0}.agreement-item{display:flex;align-items:center;gap:10px;font-size:13px;color:#374151;cursor:pointer;padding:6px 0}.agreement-text{flex:1}.agreement-text strong{color:#1a56db;font-weight:600}.agreement-link{font-size:12px;color:#6b7280;text-decoration:underline;flex-shrink:0}.agreement-link:hover{color:#1a56db}.check-icon{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border:1.5px solid #d1d9e6;border-radius:6px;font-size:13px;color:transparent;flex-shrink:0;transition:background .15s,border-color .15s,color .15s}.check-icon.checked{background:#1a56db;border-color:#1a56db;color:#fff}.contract-notice{background:#f0f5ff;border:1px solid #d4e2f7;border-radius:8px;padding:12px 16px;text-align:center}.contract-notice p{font-size:12px;color:#4b5563;line-height:1.5}.contract-notice a{color:#1a56db;font-weight:600;text-decoration:underline}.signup-btn{width:100%;padding:15px;background:linear-gradient(135deg,#1a56db,#1545b8);color:#fff;font-size:16px;font-weight:700;border:none;border-radius:10px;cursor:pointer;transition:opacity .2s;letter-spacing:.3px}.signup-btn:hover{opacity:.92}.signup-btn:disabled{opacity:.5;cursor:not-allowed}.signup-error{color:#dc2626;font-size:13px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:10px 14px;text-align:center}.signup-footer{text-align:center;margin-top:24px;font-size:13px;color:#6b7280}.login-link{color:#1a56db;font-weight:600;text-decoration:none}.login-link:hover{text-decoration:underline}.signup-company-footer{margin-top:28px;padding-top:20px;border-top:1px solid #e8edf4;text-align:center;font-size:12px;color:#9ca3af;line-height:2}.signup-company-footer strong{color:#6b7280}.signup-company-footer a{color:#9ca3af;text-decoration:underline}.signup-company-footer a:hover{color:#1a56db}.signup-company-services{color:#94a3b8;font-size:11px;margin-bottom:4px}.signup-success{text-align:center;padding:24px 0}.success-icon{width:60px;height:60px;margin:0 auto 18px;background:linear-gradient(135deg,#1a56db,#1545b8);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700}.signup-success h2{font-size:20px;color:#0f2647;margin-bottom:10px;font-weight:700}.signup-success p{font-size:15px;color:#374151}.success-sub{color:#6b7280!important;font-size:13px!important;margin-top:6px;margin-bottom:28px;line-height:1.6}@media(max-width:640px){.signup-header h1{font-size:26px}.form-section{padding:16px 14px}.form-row{flex-direction:column;gap:0}.bank-row{padding:11px 16px}}.policy-card{width:100%;max-width:900px;background:#fff;border-radius:16px;box-shadow:0 4px 24px #0000000f;padding:32px 24px}.policy-back{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#1a56db;text-decoration:none;margin-bottom:28px}.policy-back:hover{text-decoration:underline}.policy-badge{display:inline-block;font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:#1a56db;background:#e8f0fe;padding:4px 12px;border-radius:16px;margin-bottom:12px}.policy-card h1{font-size:26px;font-weight:800;color:#0f2647;margin-bottom:6px}.policy-meta{font-size:13px;color:#6b7280;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #e8edf4}.policy-content h2{font-size:17px;font-weight:700;color:#1f2937;margin-top:32px;margin-bottom:12px;padding-left:12px;border-left:3px solid #1a56db}.policy-content h3{font-size:15px;font-weight:600;color:#374151;margin-top:20px;margin-bottom:8px}.policy-content p{font-size:14px;line-height:1.75;color:#4b5563;margin-bottom:10px}.policy-content ul,.policy-content ol{padding-left:20px;margin-bottom:12px}.policy-content li{font-size:14px;line-height:1.75;color:#4b5563;margin-bottom:4px}.policy-content strong{color:#1f2937}.policy-content table{width:100%;border-collapse:collapse;margin:16px 0;font-size:13px}.policy-content th{background:#f0f5ff;color:#1f2937;font-weight:600;padding:10px 14px;text-align:left;border:1px solid #d1d9e6}.policy-content td{padding:10px 14px;border:1px solid #e5e9f0;color:#4b5563;vertical-align:top}.policy-highlight{background:#f0f5ff;border:1px solid #d4e2f7;border-radius:8px;padding:14px 18px;margin:16px 0;font-size:13px;color:#374151;line-height:1.6}.policy-footer{margin-top:40px;padding-top:24px;border-top:1px solid #e8edf4;text-align:center}.policy-footer p{font-size:12px;color:#9ca3af;margin-bottom:4px}.policy-footer a{color:#1a56db;font-weight:600;text-decoration:none}.policy-footer a:hover{text-decoration:underline}@media(max-width:640px){.policy-card{padding:24px 16px;border-radius:12px}.policy-card h1{font-size:22px}.policy-content h2{font-size:16px}.policy-content table{font-size:12px}.policy-content th,.policy-content td{padding:8px 10px}}.login-brand{text-align:center;margin-bottom:32px}.login-brand-badge{display:inline-block;padding:4px 14px;border-radius:20px;background:#eef2ff;color:#1a56db;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:12px}.login-brand-title{font-size:32px;font-weight:800;color:#0f2647;margin:0 0 6px;letter-spacing:-.5px}.login-brand-desc{font-size:14px;color:#6b7280;margin:0}.login-form-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:28px 24px}.login-signup-link{text-align:center;margin-top:16px}.login-signup-link p{font-size:14px;color:#6b7280;margin:0}.login-form-partner{display:flex;flex-direction:column;gap:16px}.login-form-group{display:flex;flex-direction:column;gap:5px}.login-form-group label{font-size:13px;font-weight:600;color:#374151}.login-form-group input{width:100%;padding:12px 14px;border:1px solid #d1d5db;border-radius:10px;font-size:15px;outline:none;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.login-form-group input:focus{border-color:#1a56db;box-shadow:0 0 0 3px #1a56db1a}.login-error{color:#dc2626;font-size:13px;margin:0;padding:8px 12px;background:#fef2f2;border-radius:8px;border:1px solid #fecaca}.login-btn-partner{width:100%;padding:13px;border:none;border-radius:10px;background:linear-gradient(135deg,#1a56db,#0f2647);color:#fff;font-size:16px;font-weight:700;cursor:pointer;transition:opacity .2s;margin-top:4px}.login-btn-partner:hover:not(:disabled){opacity:.9}.login-btn-partner:disabled{opacity:.6;cursor:not-allowed}.login-footer{text-align:center;margin-top:20px;padding-top:20px;border-top:1px solid #f0f0f0}.login-footer p{font-size:14px;color:#6b7280;margin:0}.login-footer-link{color:#1a56db;font-weight:600;text-decoration:none}.login-footer-link:hover{text-decoration:underline}.login-signup-anchor{color:#1a56db;font-weight:600;text-decoration:underline;text-underline-offset:3px}.login-signup-anchor:hover{color:#0f2647}.login-company-footer{text-align:center;margin-top:24px;padding-top:16px;border-top:1px solid #f0f0f0}.login-company-footer p{font-size:11px;color:#9ca3af;margin:2px 0}.login-company-footer a{color:#9ca3af;text-decoration:none}.login-company-footer a:hover{text-decoration:underline}.login-company-services{color:#94a3b8!important;font-size:11px!important;margin-bottom:6px!important}.login-company-copy{color:#c0c5cc!important;margin-top:6px!important}@media(max-width:640px){.login-form-card{padding:24px 16px}.login-brand-title{font-size:28px}}.mypage-fields{flex:1}.mypage-field{margin-bottom:18px}.mypage-field:last-child{margin-bottom:0}.mypage-field label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:6px}.mypage-field input{width:100%;padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:15px;color:#111827;transition:border-color .2s;box-sizing:border-box}.mypage-field input:focus{outline:none;border-color:#1a56db;box-shadow:0 0 0 3px #1a56db1a}.mypage-field input[readonly]{background:#f3f4f6;color:#6b7280;cursor:not-allowed;border-color:#e5e7eb}.mypage-save-btn{width:100%;max-width:900px;margin:24px auto 0;display:block;padding:14px 0;border:none;border-radius:10px;font-size:16px;font-weight:700;color:#fff;background:linear-gradient(135deg,#1a56db,#1e40af);cursor:pointer;transition:opacity .2s}.mypage-save-btn:hover{opacity:.9}.mypage-save-btn:disabled{background:#cbd5e1;cursor:not-allowed}.mypage-msg{text-align:center;padding:10px 14px;border-radius:8px;font-size:14px;font-weight:600;margin-bottom:20px}.mypage-msg--success{background:#d1fae5;color:#065f46}.mypage-msg--error{background:#fee2e2;color:#991b1b}.mypage-hint{font-size:12px;color:#9ca3af;margin-top:4px}.service-card--manage{border-left:4px solid #10b981;transition:transform .2s,box-shadow .2s}.service-card--manage:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98126}.card-icon--manage{background:linear-gradient(135deg,#10b981,#059669)}.service-card--greeting{border-left:4px solid #f59e0b}.card-icon--greeting{background:linear-gradient(135deg,#f59e0b,#d97706)}.service-card--education{border-left:4px solid #8b5cf6}.card-icon--education{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.service-card--classes{border-left:4px solid #ec4899}.card-icon--classes{background:linear-gradient(135deg,#ec4899,#db2777)}.mypage-manage-desc{margin-top:12px;font-size:13px;color:#6b7280;line-height:1.6}.mypage-manage-desc p{margin:0 0 8px}.mypage-manage-desc ul{margin:0;padding-left:18px}.mypage-manage-desc li{margin-bottom:4px}.mypage-manage-btn{margin-top:16px;width:100%;padding:12px 0;border:none;border-radius:8px;font-size:14px;font-weight:600;color:#fff;background:linear-gradient(135deg,#10b981,#059669);cursor:pointer;transition:opacity .2s}.mypage-manage-btn:hover{opacity:.9}.mypage-section{margin-top:40px;padding-top:32px;border-top:1px solid #e5e7eb}.mypage-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.mypage-section-header h3{font-size:20px;font-weight:700;color:#111827;margin:0}.mypage-preview-link{font-size:14px;font-weight:600;color:#1a56db;text-decoration:none;transition:color .2s}.mypage-preview-link:hover{color:#1e40af;text-decoration:underline}.mypage-section-desc{font-size:14px;color:#6b7280;margin:0 0 24px;line-height:1.6}.mypage-field-row{display:flex;gap:12px}.mypage-field-row .mypage-field{flex:1}.mypage-field textarea{width:100%;padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:15px;color:#111827;transition:border-color .2s;box-sizing:border-box;resize:vertical;font-family:inherit;line-height:1.5}.mypage-field textarea:focus{outline:none;border-color:#1a56db;box-shadow:0 0 0 3px #1a56db1a}.mypage-field select{width:100%;padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:15px;color:#111827;transition:border-color .2s;box-sizing:border-box;background:#fff;cursor:pointer}.mypage-field select:focus{outline:none;border-color:#1a56db;box-shadow:0 0 0 3px #1a56db1a}.mypage-save-btn--facility{background:linear-gradient(135deg,#059669,#047857);margin-top:20px}.mypage-save-btn--facility:hover{opacity:.9}.mypage-gallery-section,.mypage-notices-section{margin-top:32px;padding-top:24px;border-top:1px solid #e5e7eb}.mypage-subsection-title{font-size:17px;font-weight:700;color:#111827;margin:0 0 6px}.mypage-subsection-desc{font-size:13px;color:#6b7280;margin:0 0 16px}.mypage-gallery-upload{display:flex;gap:12px;align-items:flex-end;margin-bottom:20px;flex-wrap:wrap}.mypage-gallery-upload .mypage-field{flex:1;min-width:200px;margin-bottom:0}.mypage-gallery-upload-btn{padding:10px 20px;background:linear-gradient(135deg,#4a90d9,#3a7bc8);color:#fff;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;transition:opacity .2s;white-space:nowrap}.mypage-gallery-upload-btn:hover{opacity:.9}.mypage-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px}.mypage-gallery-item{position:relative;border-radius:10px;overflow:hidden;background:#f3f4f6;box-shadow:0 2px 8px #00000014}.mypage-gallery-item img{width:100%;aspect-ratio:1;-o-object-fit:cover;object-fit:cover;display:block}.mypage-gallery-caption{padding:8px 10px;font-size:12px;color:#6b7280;margin:0;background:#f9fafb;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mypage-gallery-delete{position:absolute;top:6px;right:6px;padding:4px 10px;background:#ef4444e6;color:#fff;font-size:12px;font-weight:600;border:none;border-radius:6px;cursor:pointer;opacity:0;transition:opacity .2s}.mypage-gallery-item:hover .mypage-gallery-delete{opacity:1}.mypage-empty-text{color:#9ca3af;font-size:14px;text-align:center;padding:24px;background:#f9fafb;border-radius:10px}.mypage-notices-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.mypage-notice-add-btn{padding:8px 16px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:13px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:opacity .2s}.mypage-notice-add-btn:hover{opacity:.9}.mypage-notice-form{background:#f9fafb;border-radius:12px;padding:20px;margin-bottom:20px}.mypage-notice-options{display:flex;gap:20px;margin:12px 0 16px}.mypage-checkbox{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:14px;color:#374151}.mypage-checkbox input{width:16px;height:16px;cursor:pointer}.mypage-notice-form-actions{display:flex;gap:10px;justify-content:flex-end}.mypage-notice-cancel-btn{padding:10px 20px;background:#e5e7eb;color:#374151;font-size:14px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:background .2s}.mypage-notice-cancel-btn:hover{background:#d1d5db}.mypage-notice-save-btn{padding:10px 20px;background:linear-gradient(135deg,#1a56db,#1e40af);color:#fff;font-size:14px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:opacity .2s}.mypage-notice-save-btn:hover{opacity:.9}.mypage-notice-save-btn:disabled{background:#cbd5e1;cursor:not-allowed}.mypage-notices-list{display:flex;flex-direction:column;gap:12px}.mypage-notice-item{display:flex;justify-content:space-between;align-items:flex-start;padding:16px;background:#f9fafb;border-radius:10px;border-left:3px solid #e5e7eb}.mypage-notice-info{flex:1;min-width:0}.mypage-notice-badges{display:flex;gap:6px;margin-bottom:6px}.mypage-notice-badge{padding:2px 8px;font-size:11px;font-weight:600;border-radius:4px}.mypage-notice-badge--pin{background:#dbeafe;color:#1e40af}.mypage-notice-badge--popup{background:#fef3c7;color:#b45309}.mypage-notice-badge--general{background:#f3f4f6;color:#374151}.mypage-notice-badge--newsletter{background:#dbeafe;color:#1e40af}.mypage-notice-badge--event{background:#fce7f3;color:#be185d}.mypage-notice-badge--menu{background:#d1fae5;color:#065f46}.mypage-notice-item .mypage-notice-title{font-size:15px;font-weight:600;color:#111827;margin:0 0 6px}.mypage-notice-item .mypage-notice-content{font-size:13px;color:#6b7280;margin:0 0 8px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.mypage-notice-item .mypage-notice-date{font-size:12px;color:#9ca3af}.mypage-notice-actions{display:flex;gap:8px;flex-shrink:0;margin-left:12px}.mypage-notice-actions button{padding:6px 12px;font-size:12px;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:background .2s}.mypage-notice-actions button:first-child{background:#e5e7eb;color:#374151}.mypage-notice-actions button:first-child:hover{background:#d1d5db}.mypage-notice-actions button:last-child{background:#fee2e2;color:#dc2626}.mypage-notice-actions button:last-child:hover{background:#fecaca}@media(max-width:600px){.mypage-gallery-upload{flex-direction:column;align-items:stretch}.mypage-gallery-upload .mypage-field{min-width:unset}.mypage-gallery-grid{grid-template-columns:repeat(2,1fr)}.mypage-notice-item{flex-direction:column;gap:12px}.mypage-notice-actions{margin-left:0;width:100%}.mypage-notice-actions button{flex:1}}.sitemap-section{margin-bottom:32px}.sitemap-section-title{font-size:16px;font-weight:700;color:#0f2647;margin:0 0 14px;padding-bottom:10px;border-bottom:2px solid #e2e8f0;display:flex;align-items:center;gap:10px}.sitemap-login-hint{font-size:12px;font-weight:500;color:#94a3b8;background:#f1f5f9;padding:2px 10px;border-radius:10px}.sitemap-login-hint--admin{color:#dc2626;background:#fef2f2}.sitemap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.sitemap-grid--2col{grid-template-columns:repeat(2,1fr)}.sitemap-item{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px;cursor:pointer;transition:transform .15s,box-shadow .15s;display:flex;flex-direction:column;gap:4px}.sitemap-item:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0f264714}.sitemap-item--partner{border-left:3px solid #1a56db}.sitemap-item--admin{border-left:3px solid #dc2626}.sitemap-item--disabled{opacity:.5;cursor:default}.sitemap-item--disabled:hover{transform:none;box-shadow:none}.sitemap-item-icon{font-size:24px;margin-bottom:4px}.sitemap-item-title{font-size:15px;font-weight:700;color:#0f2647}.sitemap-item-desc{font-size:13px;color:#6b7280;line-height:1.5}.sitemap-item-path{font-size:11px;color:#94a3b8;font-family:monospace;margin-top:6px}@media(max-width:640px){.sitemap-grid{grid-template-columns:1fr}}.payment-preparing{text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:40px 24px;margin-bottom:32px}.payment-preparing-icon{font-size:48px;margin-bottom:16px}.payment-preparing h3{font-size:20px;font-weight:700;color:#0f2647;margin:0 0 12px}.payment-preparing p{font-size:15px;color:#6b7280;line-height:1.7;margin:0 0 8px}.payment-preparing-sub{font-size:14px;color:#374151;margin-top:16px!important}.payment-signup-btn{margin-top:20px;padding:12px 32px;border:none;border-radius:10px;background:linear-gradient(135deg,#1a56db,#1e40af);color:#fff;font-size:15px;font-weight:700;cursor:pointer;transition:opacity .2s}.payment-signup-btn:hover{opacity:.9}.payment-section{margin-bottom:32px}.payment-section-title{font-size:16px;font-weight:700;color:#0f2647;margin:0 0 14px;padding-bottom:10px;border-bottom:2px solid #e2e8f0}.payment-plan-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}.payment-plan-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:16px 12px;text-align:center;position:relative;transition:transform .15s,box-shadow .15s}.payment-plan-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0f264714}.payment-plan-card--best{border-color:#1a56db;border-width:2px}.payment-plan-card--popular{border-color:#d97706;border-width:2px}.payment-plan-badge{position:absolute;top:-10px;left:50%;transform:translate(-50%);background:#1a56db;color:#fff;font-size:10px;font-weight:700;padding:2px 10px;border-radius:10px;white-space:nowrap}.payment-plan-card--popular .payment-plan-badge{background:#d97706}.payment-plan-name{font-size:16px;font-weight:800;color:#0f2647;margin-bottom:2px}.payment-plan-capacity{font-size:12px;color:#6b7280;margin-bottom:8px}.payment-plan-price{font-size:14px;font-weight:700;color:#1a56db}.payment-plan-per{font-size:11px;color:#9ca3af;margin-top:2px}.payment-methods{margin-bottom:32px}.card-btn:disabled{background:#cbd5e1!important;cursor:not-allowed}@media(max-width:640px){.payment-plan-grid{grid-template-columns:1fr}}.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::-moz-placeholder{color:#f5e6d359}.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;-o-object-fit:cover;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;-o-object-fit:cover;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}}.share-container{max-width:640px;margin:0 auto;padding:24px 16px 60px;min-height:100dvh;background:#f8fafc}.share-loading{display:flex;align-items:center;justify-content:center;min-height:60dvh;color:#6b7280;font-size:16px}.share-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60dvh;text-align:center;color:#6b7280}.share-error h2{margin:0 0 8px;font-size:20px;color:#374151}.share-error p{margin:0;font-size:14px}.share-header{text-align:center;margin-bottom:24px}.share-header h1{margin:0;font-size:24px;font-weight:800;color:#0f2647;letter-spacing:2px}.share-subtitle{margin:4px 0 0;font-size:14px;color:#6b7280}.share-info{background:#fff;border-radius:12px;padding:16px 20px;margin-bottom:24px;box-shadow:0 1px 3px #0000000f}.share-info-row{display:flex;justify-content:space-between;padding:6px 0}.share-info-row+.share-info-row{border-top:1px solid #f1f5f9}.share-info-label{font-size:13px;color:#6b7280;font-weight:600}.share-info-value{font-size:13px;color:#1f2937;font-weight:500}.share-child-section{margin-bottom:28px}.share-child-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}.share-child-header h3{margin:0;font-size:16px;font-weight:700;color:#0f2647}.share-child-parent{font-size:12px;color:#9ca3af}.share-download-all-btn{margin-left:auto;display:flex;align-items:center;gap:4px;padding:6px 12px;font-size:12px;font-weight:600;color:#fff;background:#5b6abf;border:none;border-radius:20px;cursor:pointer;transition:background .2s}.share-download-all-btn:hover{background:#4a58a8}.share-download-all-btn:active{transform:scale(.97)}.share-photo-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}.share-photo-item{position:relative;border-radius:10px;overflow:hidden;background:#e2e8f0;aspect-ratio:1;width:calc(50% - 4px);max-width:200px}.share-photo-item img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.share-photo-download-btn{position:absolute;bottom:8px;right:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;opacity:0;transition:opacity .2s,transform .2s}.share-photo-item:hover .share-photo-download-btn{opacity:1}.share-photo-download-btn:hover{background:#000c;transform:scale(1.1)}@media(max-width:768px){.share-photo-download-btn{opacity:.9}}.share-empty{text-align:center;color:#9ca3af;padding:60px 20px;font-size:15px}.share-footer{text-align:center;padding:32px 0 0;border-top:1px solid #e2e8f0;margin-top:20px}.share-footer p{margin:0;font-size:12px;color:#9ca3af;letter-spacing:1px}@media(min-width:480px){.share-photo-item{width:calc(33.333% - 6px);max-width:180px}}.share-privacy-notice{font-size:12px;color:#6b7280;margin:0 0 12px;padding:8px 12px;background:#f1f5f9;border-radius:8px;text-align:center}.share-photo-blur-container{width:100%;height:100%;position:relative}.share-photo-canvas{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;opacity:0;transition:opacity .3s}.share-photo-canvas--loaded{opacity:1}.share-photo-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:12px;color:#9ca3af}.share-photo-item--blur{background:#e2e8f0}.manage-main{max-width:900px;margin:0 auto;padding:32px 20px 60px}.manage-title{margin:0 0 24px;font-size:22px;font-weight:700;color:#0f2647}.manage-tabs{display:flex;gap:4px;border-bottom:2px solid #e2e8f0;margin-bottom:20px}.manage-tab{padding:10px 20px;border:none;background:transparent;font-size:14px;font-weight:600;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s}.manage-tab:hover{color:#1a56db}.manage-tab--active{color:#1a56db;border-bottom-color:#1a56db}.manage-toolbar{display:flex;justify-content:flex-end;margin-bottom:16px}.manage-add-btn{padding:8px 20px;border:none;border-radius:8px;background:#1a56db;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.manage-add-btn:hover{background:#1648b8}.manage-table-wrap{overflow-x:auto}.manage-table{width:100%;border-collapse:collapse;font-size:14px}.manage-table th{text-align:left;padding:10px 12px;background:#f8fafc;color:#374151;font-weight:600;border-bottom:2px solid #e2e8f0;white-space:nowrap}.manage-table td{padding:10px 12px;border-bottom:1px solid #f1f5f9;color:#374151}.manage-table tbody tr:hover{background:#f8fafc}.manage-empty{text-align:center;color:#9ca3af;padding:32px 12px!important}.manage-actions{display:flex;gap:6px;white-space:nowrap}.manage-edit-btn,.manage-delete-btn{padding:4px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:background .15s}.manage-edit-btn{background:#fff;color:#1a56db;border-color:#1a56db}.manage-edit-btn:hover{background:#eff6ff}.manage-delete-btn{background:#fff;color:#dc2626;border-color:#dc2626}.manage-delete-btn:hover{background:#fef2f2}.manage-modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.manage-modal{background:#fff;border-radius:14px;padding:28px;width:100%;max-width:440px;box-shadow:0 20px 60px #00000026}.manage-modal-title{margin:0 0 20px;font-size:18px;font-weight:700;color:#0f2647}.manage-modal-error{margin:0 0 12px;padding:8px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;font-size:13px}.manage-form{display:flex;flex-direction:column;gap:14px}.manage-form label{display:flex;flex-direction:column;gap:4px}.manage-form label span{font-size:13px;font-weight:600;color:#374151}.manage-form input,.manage-form select{padding:9px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;color:#1f2937;outline:none;transition:border-color .2s}.manage-form input:focus,.manage-form select:focus{border-color:#1a56db}.manage-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:24px}.manage-cancel-btn{padding:9px 20px;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#6b7280;font-size:14px;font-weight:600;cursor:pointer}.manage-cancel-btn:hover{background:#f9fafb}.manage-save-btn{padding:9px 24px;border:none;border-radius:8px;background:#1a56db;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.manage-save-btn:hover{background:#1648b8}.manage-save-btn:disabled,.manage-cancel-btn:disabled{opacity:.6;cursor:not-allowed}.manage-modal--wide{max-width:680px}.bulk-class-selector{margin-bottom:16px}.bulk-class-selector label{display:flex;flex-direction:column;gap:4px}.bulk-class-selector label span{font-size:13px;font-weight:600;color:#374151}.bulk-class-selector select{padding:9px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;color:#1f2937;outline:none;transition:border-color .2s}.bulk-class-selector select:focus{border-color:#1a56db}.bulk-teacher-display{margin:8px 0 0;padding:8px 12px;background:#f0f9ff;border:1px solid #bae6fd;border-radius:6px;font-size:13px;color:#0369a1}.bulk-table-wrap{overflow-x:auto;margin-bottom:8px}.bulk-table{width:100%;border-collapse:collapse;font-size:13px}.bulk-table th{text-align:left;padding:8px 6px;background:#f8fafc;color:#374151;font-weight:600;border-bottom:2px solid #e2e8f0;white-space:nowrap;font-size:12px}.bulk-table td{padding:4px;border-bottom:1px solid #f1f5f9}.bulk-table input{width:100%;padding:7px 8px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;color:#1f2937;outline:none;box-sizing:border-box;transition:border-color .2s}.bulk-table input:focus,.bulk-table select:focus{border-color:#1a56db}.bulk-table select{width:100%;padding:7px 8px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;color:#1f2937;outline:none;box-sizing:border-box;background:#fff;transition:border-color .2s}.bulk-remove-btn{padding:4px 10px;border:1px solid #fecaca;border-radius:6px;background:#fff;color:#dc2626;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s}.bulk-remove-btn:hover{background:#fef2f2}.bulk-add-row-btn{padding:6px 16px;border:1px dashed #93c5fd;border-radius:8px;background:#eff6ff;color:#1a56db;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;margin-bottom:8px}.bulk-add-row-btn:hover{background:#dbeafe}.bulk-excel-controls{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}.bulk-excel-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s,transform .15s}.bulk-excel-btn--sample{border:1px solid #10b981;background:#ecfdf5;color:#059669}.bulk-excel-btn--sample:hover{background:#d1fae5}.bulk-excel-btn--upload{border:1px solid #3b82f6;background:#eff6ff;color:#1d4ed8}.bulk-excel-btn--upload:hover{background:#dbeafe}.bulk-excel-btn:active{transform:scale(.98)}.manage-account-badge{display:inline-block;padding:3px 8px;border-radius:12px;font-size:11px;font-weight:600}.manage-account-badge--active{background:#d1fae5;color:#065f46}.manage-account-badge--none{background:#f3f4f6;color:#6b7280}.manage-invite-btn{padding:4px 12px;border:1px solid #10b981;border-radius:6px;background:#ecfdf5;color:#059669;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s}.manage-invite-btn:hover{background:#d1fae5}.invite-staff-name{margin:0 0 16px;font-size:16px;font-weight:600;color:#1f2937}.invite-loading{text-align:center;color:#6b7280;padding:20px 0}.invite-desc{margin:0 0 12px;font-size:13px;color:#6b7280;line-height:1.5}.invite-link-box{display:flex;gap:8px}.invite-link-input{flex:1;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:13px;color:#374151;background:#f9fafb}.invite-copy-btn{padding:10px 20px;border:none;border-radius:8px;background:#10b981;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap}.invite-copy-btn:hover{background:#059669}.invite-error{text-align:center;color:#dc2626;padding:20px 0}@media(max-width:640px){.manage-table th,.manage-table td{padding:8px;font-size:13px}.manage-modal,.manage-modal--wide{max-width:100%}.bulk-excel-controls{flex-direction:column}.bulk-excel-btn{justify-content:center}}.staff-auth-container{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0fdf4,#ecfdf5,#d1fae5);padding:20px}.staff-auth-loading{color:#6b7280;font-size:16px}.staff-auth-card{width:100%;max-width:400px;background:#fff;border-radius:16px;padding:32px 28px;box-shadow:0 10px 40px #00000014}.staff-auth-title{margin:0 0 8px;font-size:24px;font-weight:700;color:#065f46;text-align:center}.staff-auth-subtitle{margin:0 0 24px;font-size:14px;color:#6b7280;text-align:center}.staff-auth-error-msg{margin:0 0 20px;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px;text-align:center}.staff-auth-info{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;padding:16px;margin-bottom:24px}.staff-auth-info-row{display:flex;justify-content:space-between;padding:6px 0}.staff-auth-info-row+.staff-auth-info-row{border-top:1px solid #d1fae5}.staff-auth-info-label{font-size:13px;color:#6b7280;font-weight:500}.staff-auth-info-value{font-size:13px;color:#065f46;font-weight:600}.staff-auth-form{display:flex;flex-direction:column;gap:16px}.staff-auth-form-error{margin:0;padding:10px 14px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:13px}.staff-auth-field{display:flex;flex-direction:column;gap:6px}.staff-auth-field label{font-size:13px;font-weight:600;color:#374151}.staff-auth-field input{padding:12px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:15px;color:#1f2937;transition:border-color .2s,box-shadow .2s}.staff-auth-field input:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.staff-auth-field input:disabled{background:#f9fafb;color:#9ca3af}.staff-auth-btn{width:100%;padding:14px 0;border:none;border-radius:10px;font-size:15px;font-weight:600;color:#fff;background:linear-gradient(135deg,#10b981,#059669);cursor:pointer;transition:opacity .2s,transform .15s}.staff-auth-btn:hover{opacity:.9}.staff-auth-btn:active{transform:scale(.98)}.staff-auth-btn:disabled{background:#9ca3af;cursor:not-allowed}.staff-auth-btn--secondary{background:#fff;color:#374151;border:1px solid #d1d5db}.staff-auth-btn--secondary:hover{background:#f9fafb;opacity:1}.staff-auth-divider{display:flex;align-items:center;margin:20px 0}.staff-auth-divider:before,.staff-auth-divider:after{content:"";flex:1;height:1px;background:#e5e7eb}.staff-auth-divider span{padding:0 12px;font-size:12px;color:#9ca3af}.staff-auth-footer{margin:20px 0 0;text-align:center;font-size:13px;color:#6b7280}.staff-auth-footer a{color:#10b981;font-weight:600;text-decoration:none}.staff-auth-footer a:hover{text-decoration:underline}.staff-dashboard-container{min-height:100dvh;background:#f8fafc}.staff-dashboard-loading{display:flex;align-items:center;justify-content:center;min-height:100dvh;color:#6b7280;font-size:16px}.staff-dashboard-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:linear-gradient(135deg,#10b981,#059669);color:#fff}.staff-dashboard-header-left{display:flex;align-items:center;gap:12px}.staff-dashboard-header-left h1{margin:0;font-size:20px;font-weight:800;letter-spacing:1px}.staff-dashboard-badge{padding:4px 10px;background:#fff3;border-radius:12px;font-size:12px;font-weight:600}.staff-dashboard-header-right{display:flex;align-items:center;gap:12px}.staff-dashboard-user{font-size:14px;font-weight:500}.staff-dashboard-logout{padding:6px 14px;border:1px solid rgba(255,255,255,.4);border-radius:6px;background:transparent;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s}.staff-dashboard-logout:hover{background:#ffffff1a}.staff-dashboard-main{max-width:800px;margin:0 auto;padding:24px 20px 60px}.staff-dashboard-welcome{text-align:center;margin-bottom:32px}.staff-dashboard-welcome h2{margin:0 0 4px;font-size:22px;font-weight:700;color:#065f46}.staff-dashboard-welcome p{margin:0;font-size:14px;color:#6b7280}.staff-dashboard-section{margin-bottom:28px}.staff-dashboard-section-title{margin:0 0 12px;font-size:16px;font-weight:700;color:#1f2937}.staff-dashboard-class-card{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:1px solid #a7f3d0;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}.staff-dashboard-class-name{font-size:20px;font-weight:700;color:#065f46}.staff-dashboard-class-info{font-size:14px;color:#047857;flex:1}.staff-dashboard-photo-btn{padding:10px 20px;border:none;border-radius:8px;background:#10b981;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.staff-dashboard-photo-btn:hover{background:#059669}.staff-dashboard-no-class{text-align:center;padding:40px 20px;background:#f9fafb;border:1px dashed #d1d5db;border-radius:12px}.staff-dashboard-no-class p{margin:0;color:#6b7280;font-size:15px}.staff-dashboard-no-class-sub{margin-top:8px!important;font-size:13px!important;color:#9ca3af!important}.staff-dashboard-children-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.staff-dashboard-child-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;transition:box-shadow .2s}.staff-dashboard-child-card:hover{box-shadow:0 2px 8px #0000000f}.staff-dashboard-child-avatar{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#a7f3d0,#6ee7b7);border-radius:50%;font-size:16px;font-weight:700;color:#065f46}.staff-dashboard-child-info{flex:1;min-width:0}.staff-dashboard-child-name{font-size:14px;font-weight:600;color:#1f2937}.staff-dashboard-child-parent{font-size:12px;color:#9ca3af;margin-top:2px}.staff-dashboard-sessions{display:flex;flex-direction:column;gap:8px}.staff-dashboard-session-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#fff;border:1px solid #e5e7eb;border-radius:8px}.staff-dashboard-session-info{display:flex;align-items:center;gap:12px}.staff-dashboard-session-class{font-size:14px;font-weight:600;color:#1f2937}.staff-dashboard-session-date{font-size:13px;color:#9ca3af}.staff-dashboard-session-link{font-size:13px;color:#10b981;font-weight:500;text-decoration:none}.staff-dashboard-session-link:hover{text-decoration:underline}.staff-dashboard-quick-menu{display:flex;gap:12px;flex-wrap:wrap}.staff-dashboard-menu-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 24px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:border-color .2s,box-shadow .2s;min-width:120px}.staff-dashboard-menu-btn:hover:not(:disabled){border-color:#10b981;box-shadow:0 2px 8px #10b9811a}.staff-dashboard-menu-btn:disabled{opacity:.5;cursor:not-allowed}.staff-dashboard-menu-icon{font-size:28px}.staff-dashboard-menu-btn span:last-child{font-size:13px;font-weight:600;color:#374151}.staff-dashboard-footer{text-align:center;padding:20px;border-top:1px solid #e5e7eb;margin-top:20px}.staff-dashboard-footer p{margin:0;font-size:12px;color:#9ca3af}@media(max-width:640px){.staff-dashboard-header{padding:14px 16px}.staff-dashboard-header-left h1{font-size:18px}.staff-dashboard-children-grid{grid-template-columns:1fr}.staff-dashboard-quick-menu{flex-direction:column}.staff-dashboard-menu-btn{flex-direction:row;justify-content:flex-start;min-width:auto;padding:16px 20px}}.blog-editor-container{min-height:100dvh;background:#f8fafc}.blog-editor-loading{display:flex;align-items:center;justify-content:center;min-height:100dvh;color:#6b7280}.blog-editor-header{display:flex;align-items:center;gap:16px;padding:16px 24px;background:#fff;border-bottom:1px solid #e5e7eb}.blog-editor-back{padding:8px 14px;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#374151;font-size:14px;cursor:pointer;transition:background .2s}.blog-editor-back:hover{background:#f9fafb}.blog-editor-header h1{margin:0;font-size:20px;font-weight:700;color:#1f2937}.blog-editor-main{max-width:800px;margin:0 auto;padding:32px 20px 60px}.blog-editor-form{background:#fff;border-radius:12px;padding:28px;box-shadow:0 1px 4px #0000000a}.blog-editor-error{margin:0 0 20px;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px}.blog-editor-field{margin-bottom:24px}.blog-editor-field label{display:block;font-size:14px;font-weight:600;color:#374151;margin-bottom:8px}.blog-editor-field input{width:100%;padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:15px;color:#1f2937;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.blog-editor-field input:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.blog-editor-field textarea{width:100%;padding:14px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:15px;color:#1f2937;line-height:1.6;resize:vertical;min-height:300px;font-family:inherit;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.blog-editor-field textarea:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.blog-editor-field input:disabled,.blog-editor-field textarea:disabled{background:#f9fafb;color:#9ca3af}.blog-editor-thumbnail-preview{margin-top:12px;border-radius:8px;overflow:hidden;max-width:300px}.blog-editor-thumbnail-preview img{width:100%;height:auto;display:block}.blog-editor-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:24px;border-top:1px solid #e5e7eb}.blog-editor-cancel{padding:12px 24px;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#6b7280;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.blog-editor-cancel:hover{background:#f9fafb}.blog-editor-submit{padding:12px 28px;border:none;border-radius:8px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s}.blog-editor-submit:hover{opacity:.9}.blog-editor-submit:disabled,.blog-editor-cancel:disabled{opacity:.6;cursor:not-allowed}@media(max-width:640px){.blog-editor-header{padding:14px 16px}.blog-editor-main{padding:20px 16px 40px}.blog-editor-form{padding:20px}.blog-editor-actions{flex-direction:column}.blog-editor-cancel,.blog-editor-submit{width:100%}}.blog-list-container{min-height:100dvh;background:#f8fafc}.blog-list-loading{display:flex;align-items:center;justify-content:center;min-height:100dvh;color:#6b7280}.blog-list-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#fff;border-bottom:1px solid #e5e7eb;flex-wrap:wrap;gap:12px}.blog-list-header-left{display:flex;align-items:center;gap:16px}.blog-list-back{padding:8px 14px;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#374151;font-size:14px;cursor:pointer;transition:background .2s}.blog-list-back:hover{background:#f9fafb}.blog-list-header h1{margin:0;font-size:20px;font-weight:700;color:#1f2937}.blog-list-new-btn{padding:10px 20px;border:none;border-radius:8px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s}.blog-list-new-btn:hover{opacity:.9}.blog-list-main{max-width:900px;margin:0 auto;padding:24px 20px 60px}.blog-list-error{margin:0 0 20px;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px}.blog-list-empty{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;border:1px dashed #d1d5db}.blog-list-empty p{margin:0 0 16px;font-size:15px;color:#6b7280}.blog-list-empty button{padding:12px 24px;border:none;border-radius:8px;background:#10b981;color:#fff;font-size:14px;font-weight:600;cursor:pointer}.blog-list-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.blog-list-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 4px #0000000a;cursor:pointer;transition:box-shadow .2s,transform .15s}.blog-list-card:hover{box-shadow:0 4px 16px #00000014;transform:translateY(-2px)}.blog-list-card-thumb{height:160px;background:#e5e7eb;overflow:hidden}.blog-list-card-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.blog-list-card-thumb--empty{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#d1fae5,#a7f3d0)}.blog-list-card-thumb--empty span{font-size:48px}.blog-list-card-body{padding:16px}.blog-list-card-title{margin:0 0 8px;font-size:16px;font-weight:600;color:#1f2937;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.blog-list-card-meta{display:flex;align-items:center;gap:8px;font-size:13px;color:#9ca3af}.blog-list-card-author{color:#6b7280;font-weight:500}.blog-list-card-status{display:inline-block;margin-top:8px;padding:2px 8px;background:#fef3c7;color:#92400e;font-size:11px;font-weight:600;border-radius:4px}.blog-list-card-actions{display:flex;gap:8px;padding:12px 16px;border-top:1px solid #f3f4f6}.blog-list-card-edit,.blog-list-card-delete{flex:1;padding:8px 0;border:1px solid #e5e7eb;border-radius:6px;background:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.blog-list-card-edit{color:#10b981;border-color:#10b981}.blog-list-card-edit:hover{background:#ecfdf5}.blog-list-card-delete{color:#dc2626;border-color:#dc2626}.blog-list-card-delete:hover{background:#fef2f2}@media(max-width:640px){.blog-list-header{padding:14px 16px}.blog-list-grid{grid-template-columns:1fr}}.blog-post-container{min-height:100dvh;background:#f8fafc}.blog-post-loading{display:flex;align-items:center;justify-content:center;min-height:100dvh;color:#6b7280}.blog-post-error-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;text-align:center;padding:20px}.blog-post-error-page h2{margin:0 0 8px;font-size:20px;color:#374151}.blog-post-error-page p{margin:0 0 20px;color:#6b7280}.blog-post-error-page button{padding:12px 24px;border:none;border-radius:8px;background:#10b981;color:#fff;font-size:14px;font-weight:600;cursor:pointer}.blog-post-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#fff;border-bottom:1px solid #e5e7eb}.blog-post-back{padding:8px 14px;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#374151;font-size:14px;cursor:pointer;transition:background .2s}.blog-post-back:hover{background:#f9fafb}.blog-post-edit-btn{padding:8px 18px;border:1px solid #10b981;border-radius:8px;background:#ecfdf5;color:#059669;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.blog-post-edit-btn:hover{background:#d1fae5}.blog-post-main{max-width:720px;margin:0 auto;padding:32px 20px 60px}.blog-post-article{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 4px #0000000a}.blog-post-thumbnail{width:100%;max-height:400px;overflow:hidden}.blog-post-thumbnail img{width:100%;height:auto;display:block}.blog-post-title{margin:0;padding:28px 28px 16px;font-size:26px;font-weight:700;color:#1f2937;line-height:1.4}.blog-post-meta{display:flex;flex-wrap:wrap;align-items:center;gap:12px;padding:0 28px 20px;font-size:14px;color:#9ca3af;border-bottom:1px solid #f3f4f6}.blog-post-author{color:#10b981;font-weight:600}.blog-post-center{color:#6b7280}.blog-post-content{padding:28px;font-size:16px;line-height:1.8;color:#374151}.blog-post-content p{margin:0 0 16px}.blog-post-content p:last-child{margin-bottom:0}.blog-post-footer{text-align:center;padding:24px 20px;border-top:1px solid #e5e7eb;margin-top:20px}.blog-post-footer p{margin:0;font-size:12px;color:#9ca3af}@media(max-width:640px){.blog-post-header{padding:14px 16px}.blog-post-main{padding:20px 16px 40px}.blog-post-title{padding:20px 20px 12px;font-size:22px}.blog-post-meta{padding:0 20px 16px}.blog-post-content{padding:20px;font-size:15px}}:root{--ch-primary: #4a90d9;--ch-primary-dark: #3a7bc8;--ch-warm: #f97316;--ch-warm-light: #fff7ed;--ch-green: #22c55e;--ch-green-light: #f0fdf4;--ch-purple: #a855f7;--ch-text: #1e293b;--ch-text-light: #64748b;--ch-bg: #fafaf9;--ch-white: #ffffff;--ch-border: #e7e5e4}.ch-container{width:100%;min-height:100dvh;background:var(--ch-bg);font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,sans-serif}.ch-loading,.ch-error{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--ch-text-light)}.ch-spinner{width:48px;height:48px;border:4px solid var(--ch-border);border-top-color:var(--ch-primary);border-radius:50%;animation:ch-spin .8s linear infinite}@keyframes ch-spin{to{transform:rotate(360deg)}}.ch-error button{padding:12px 28px;background:var(--ch-primary);color:var(--ch-white);border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer}.ch-nav{position:sticky;top:0;z-index:100;background:var(--ch-white);box-shadow:0 2px 8px #00000014}.ch-nav-inner{max-width:1200px;margin:0 auto;padding:0 20px;height:64px;display:flex;align-items:center;justify-content:space-between}.ch-nav-logo{display:flex;align-items:center;gap:10px;cursor:pointer}.ch-nav-logo img{width:40px;height:40px;border-radius:10px;-o-object-fit:cover;object-fit:cover}.ch-nav-logo-text{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--ch-warm),#fb923c);color:var(--ch-white);font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center}.ch-nav-name{font-size:18px;font-weight:700;color:var(--ch-text)}.ch-nav-menu{display:none;gap:8px}.ch-nav-item{padding:8px 16px;background:none;border:none;border-radius:8px;font-size:15px;font-weight:500;color:var(--ch-text-light);cursor:pointer;transition:all .2s}.ch-nav-item:hover{background:var(--ch-warm-light);color:var(--ch-warm)}.ch-nav-item--active,.ch-nav-item--active:hover{background:var(--ch-warm);color:var(--ch-white)}.ch-nav-mobile-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:none;border:none;color:var(--ch-text);cursor:pointer}.ch-nav-mobile-menu{padding:12px 20px 20px;background:var(--ch-white);border-top:1px solid var(--ch-border);display:flex;flex-direction:column;gap:4px}.ch-nav-mobile-item{padding:12px 16px;background:none;border:none;border-radius:8px;font-size:15px;font-weight:500;color:var(--ch-text-light);text-align:left;cursor:pointer}.ch-nav-mobile-item:hover,.ch-nav-mobile-item--active{background:var(--ch-warm-light);color:var(--ch-warm)}.ch-hero{position:relative;height:300px;overflow:hidden}.ch-hero-bg{position:absolute;inset:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.ch-hero-bg--default{background:linear-gradient(135deg,#fde68a,#fbbf24,#f97316)}.ch-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,#0000001a,#00000080)}.ch-hero-content{position:relative;z-index:1;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;text-align:center}.ch-hero-logo{width:80px;height:80px;border-radius:20px;background:var(--ch-white);box-shadow:0 4px 20px #0003;display:flex;align-items:center;justify-content:center;margin-bottom:16px;overflow:hidden}.ch-hero-logo img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.ch-hero-logo span{font-size:36px;font-weight:700;color:var(--ch-warm)}.ch-hero-title{font-size:28px;font-weight:800;color:var(--ch-white);text-shadow:0 2px 8px rgba(0,0,0,.3);margin-bottom:8px}.ch-hero-badge{padding:6px 16px;border-radius:20px;font-size:13px;font-weight:600;color:var(--ch-white);margin-bottom:12px}.ch-hero-desc{max-width:500px;font-size:15px;color:#ffffffe6;line-height:1.6}.ch-section{max-width:1200px;margin:0 auto;padding:48px 20px}.ch-section-title{font-size:24px;font-weight:800;color:var(--ch-text);text-align:center;margin-bottom:32px;position:relative}.ch-section-title:after{content:"";display:block;width:60px;height:4px;background:var(--ch-warm);border-radius:2px;margin:12px auto 0}.ch-greeting-content{display:flex;flex-direction:column;align-items:center;gap:24px;background:var(--ch-white);border-radius:20px;padding:32px 24px;box-shadow:0 4px 20px #0000000f}.ch-greeting-image{width:140px;height:140px;border-radius:50%;overflow:hidden;border:4px solid var(--ch-warm-light)}.ch-greeting-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.ch-greeting-text{text-align:center}.ch-greeting-text h3{font-size:20px;font-weight:700;color:var(--ch-warm);margin-bottom:16px}.ch-greeting-text p{font-size:15px;line-height:1.8;color:var(--ch-text-light)}.ch-education{background:var(--ch-green-light)}.ch-education-content{max-width:800px;margin:0 auto;background:var(--ch-white);border-radius:20px;padding:32px 24px;box-shadow:0 4px 20px #22c55e1a;border-left:4px solid var(--ch-green)}.ch-education-content p{font-size:16px;line-height:1.8;color:var(--ch-text)}.ch-classes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px}.ch-class-card{background:var(--ch-white);border-radius:16px;padding:24px 16px;text-align:center;box-shadow:0 4px 12px #0000000f;transition:transform .2s,box-shadow .2s}.ch-class-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a}.ch-class-icon{width:56px;height:56px;margin:0 auto 12px;background:var(--ch-warm-light);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ch-warm)}.ch-class-name{font-size:16px;font-weight:700;color:var(--ch-text);margin-bottom:4px}.ch-class-teacher{font-size:13px;color:var(--ch-text-light)}.ch-gallery-filters,.ch-notices-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px;justify-content:center}.ch-filter-btn{padding:8px 16px;background:var(--ch-white);border:1px solid var(--ch-border);border-radius:20px;font-size:14px;font-weight:500;color:var(--ch-text-light);cursor:pointer;transition:all .2s}.ch-filter-btn:hover{border-color:var(--ch-warm);color:var(--ch-warm)}.ch-filter-btn--active{background:var(--ch-warm);border-color:var(--ch-warm);color:var(--ch-white)}.ch-gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.ch-gallery-item{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;cursor:pointer;box-shadow:0 2px 8px #0000001a}.ch-gallery-item img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .3s}.ch-gallery-item:hover img{transform:scale(1.05)}.ch-gallery-class{position:absolute;bottom:8px;left:8px;padding:4px 10px;background:#0009;color:var(--ch-white);font-size:11px;font-weight:600;border-radius:12px}.ch-notices-list{display:flex;flex-direction:column;gap:12px}.ch-notice-item{background:var(--ch-white);border-radius:12px;padding:16px;box-shadow:0 2px 8px #0000000f;border-left:3px solid var(--ch-border)}.ch-notice-item--pinned{border-left-color:var(--ch-warm);background:var(--ch-warm-light)}.ch-notice-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}.ch-notice-pin{padding:2px 8px;background:var(--ch-warm);color:var(--ch-white);font-size:11px;font-weight:600;border-radius:4px}.ch-notice-category{padding:2px 8px;background:var(--ch-green-light);color:var(--ch-green);font-size:11px;font-weight:600;border-radius:4px}.ch-notice-title{flex:1;font-size:15px;font-weight:600;color:var(--ch-text)}.ch-notice-content{font-size:14px;color:var(--ch-text-light);line-height:1.6;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.ch-notice-date{font-size:12px;color:#94a3b8}.ch-chat{background:linear-gradient(135deg,#eff6ff,#dbeafe)}.ch-chat-content{text-align:center;max-width:500px;margin:0 auto}.ch-chat-content p{font-size:16px;color:var(--ch-text-light);margin-bottom:24px}.ch-chat-btn{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;background:linear-gradient(135deg,var(--ch-primary),var(--ch-primary-dark));color:var(--ch-white);border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;box-shadow:0 4px 16px #4a90d94d;transition:transform .2s,box-shadow .2s}.ch-chat-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4a90d966}.ch-map-content{background:var(--ch-white);border-radius:20px;padding:32px 24px;box-shadow:0 4px 20px #0000000f;max-width:700px;margin:0 auto}.ch-map-embed{margin-bottom:24px;border-radius:12px;overflow:hidden;box-shadow:0 2px 12px #0000001a}.ch-map-embed iframe{display:block}.ch-map-info{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.ch-map-row{display:flex;align-items:flex-start;gap:12px;color:var(--ch-text);font-size:15px;line-height:1.5}.ch-map-row svg{flex-shrink:0;color:var(--ch-warm);margin-top:2px}.ch-map-row a{color:var(--ch-primary);text-decoration:none}.ch-map-buttons{display:flex;gap:12px}.ch-map-btn{flex:1;padding:14px 24px;background:#4285f4;color:var(--ch-white);border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s}.ch-map-btn:hover{background:#3367d6}.ch-map-btn--kakao{background:#fee500;color:#3c1e1e}.ch-map-btn--kakao:hover{background:#fdd800}@media(max-width:480px){.ch-map-buttons{flex-direction:column}}.ch-footer{background:#292524;color:#a8a29e;padding:40px 20px}.ch-footer-inner{max-width:1200px;margin:0 auto;text-align:center}.ch-footer-name{font-size:18px;font-weight:700;color:var(--ch-white);margin-bottom:12px}.ch-footer p{font-size:14px;margin-bottom:8px}.ch-footer-copy{margin-top:16px;font-size:12px;color:#78716c}.ch-lightbox{position:fixed;inset:0;z-index:9999;background:#000000f2;display:flex;align-items:center;justify-content:center}.ch-lightbox-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--ch-white);cursor:pointer;padding:8px;z-index:10}.ch-lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;border:none;color:var(--ch-white);cursor:pointer;padding:12px;border-radius:50%;transition:background .2s;z-index:10}.ch-lightbox-nav:hover{background:#fff3}.ch-lightbox-nav--prev{left:16px}.ch-lightbox-nav--next{right:16px}.ch-lightbox-content{max-width:90vw;max-height:80vh;display:flex;flex-direction:column;align-items:center}.ch-lightbox-content img{max-width:100%;max-height:70vh;-o-object-fit:contain;object-fit:contain;border-radius:8px}.ch-lightbox-caption{margin-top:16px;color:var(--ch-white);font-size:14px;text-align:center}.ch-lightbox-counter{position:absolute;bottom:24px;left:50%;transform:translate(-50%);color:#ffffffb3;font-size:14px}.ch-popup-overlay{position:fixed;inset:0;z-index:9998;background:#00000080;display:flex;align-items:center;justify-content:center;padding:20px}.ch-popup{background:var(--ch-white);border-radius:20px;max-width:420px;width:100%;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:ch-popup-in .25s ease-out}@keyframes ch-popup-in{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.ch-popup-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--ch-border)}.ch-popup-header h3{font-size:18px;font-weight:700;color:var(--ch-text)}.ch-popup-header button{background:none;border:none;color:#94a3b8;cursor:pointer;padding:4px}.ch-popup-content{padding:24px;overflow-y:auto;flex:1}.ch-popup-content p{font-size:15px;line-height:1.7;color:var(--ch-text-light);white-space:pre-wrap}.ch-popup-footer{padding:16px 24px;border-top:1px solid var(--ch-border);display:flex;justify-content:flex-end}.ch-popup-footer button{padding:12px 28px;background:var(--ch-warm);color:var(--ch-white);border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer}.ch-blog{background:linear-gradient(135deg,#fef3c7,#fde68a)}.ch-blog-content{text-align:center;max-width:480px;margin:0 auto}.ch-blog-content p{font-size:15px;color:var(--ch-text-light);margin-bottom:24px;line-height:1.6}.ch-blog-btn{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;background:#f59e0b;color:var(--ch-white);border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #f59e0b4d}.ch-blog-btn:hover{background:#d97706;transform:translateY(-2px);box-shadow:0 6px 20px #f59e0b66}.ch-admission{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.ch-admission-content{max-width:800px;margin:0 auto}.ch-admission-text{background:var(--ch-white);border-radius:16px;padding:32px;box-shadow:0 4px 16px #00000014}.ch-admission-text p{font-size:15px;line-height:1.8;color:var(--ch-text);white-space:pre-wrap}.ch-admission-default{display:grid;grid-template-columns:1fr;gap:20px}.ch-admission-card{background:var(--ch-white);border-radius:16px;padding:28px;text-align:center;box-shadow:0 4px 16px #00000014}.ch-admission-icon{width:64px;height:64px;margin:0 auto 16px;background:#dbeafe;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#2563eb}.ch-admission-card h3{font-size:18px;font-weight:700;color:var(--ch-text);margin-bottom:8px}.ch-admission-card p{font-size:14px;color:var(--ch-text-light);margin-bottom:16px}.ch-admission-phone{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:#2563eb;color:var(--ch-white);border-radius:24px;font-size:15px;font-weight:600;text-decoration:none;transition:all .2s}.ch-admission-phone:hover{background:#1d4ed8}@media(min-width:640px){.ch-nav-menu{display:flex}.ch-nav-mobile-btn{display:none}.ch-hero{height:400px}.ch-hero-logo{width:100px;height:100px}.ch-hero-title{font-size:36px}.ch-section{padding:64px 32px}.ch-section-title{font-size:28px}.ch-greeting-content{flex-direction:row;text-align:left;padding:40px}.ch-greeting-text{text-align:left}.ch-gallery-grid{grid-template-columns:repeat(3,1fr);gap:16px}.ch-classes-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.ch-admission-default{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.ch-hero{height:480px}.ch-hero-logo{width:120px;height:120px;border-radius:24px}.ch-hero-title{font-size:42px}.ch-section{padding:80px 40px}.ch-section-title{font-size:32px;margin-bottom:48px}.ch-gallery-grid{grid-template-columns:repeat(4,1fr)}.ch-greeting-content{padding:48px 56px;gap:48px}.ch-greeting-image{width:180px;height:180px}.ch-greeting-text h3{font-size:24px}.ch-greeting-text p{font-size:16px}}
