:root{--color-primary: #4f6d7a;--color-primary-light: #6a8e9e;--color-bg: #f8f9fb;--color-surface: #ffffff;--color-border: #e2e6ea;--color-text: #1e293b;--color-text-muted: #64748b;--color-tag-bg: #eef2f7;--color-tag-text: #475569;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{line-height:1.3}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.rp-backdrop{position:fixed;inset:0;background:#00000059;opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:200}.rp-backdrop--visible{opacity:1;pointer-events:all}.resource-panel{position:fixed;top:0;right:0;bottom:0;width:380px;max-width:100vw;background:var(--color-surface);border-left:1px solid var(--color-border);box-shadow:-4px 0 24px #0000001a;display:flex;flex-direction:column;transform:translate(100%);transition:transform .3s ease;z-index:201;overflow:hidden}.resource-panel--open{transform:translate(0)}.rp-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border);flex-shrink:0;background:var(--color-surface)}.rp-title{margin:0;font-size:1.1rem;color:var(--color-primary)}.rp-close-btn{background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--color-text-muted);padding:.25rem .5rem;border-radius:6px;transition:background .15s,color .15s;line-height:1}.rp-close-btn:hover{background:var(--color-tag-bg);color:var(--color-text)}.rp-body{flex:1;overflow-y:auto;padding:1.25rem}.rp-section-group{display:flex;flex-direction:column;gap:1.5rem}.rp-section{padding-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.rp-section:last-child{border-bottom:none;padding-bottom:0}.rp-section h3{margin:0 0 .6rem;font-size:.95rem;color:var(--color-primary);text-transform:uppercase;letter-spacing:.04em;font-weight:700}.rp-section p{margin:0;font-size:.92rem;color:var(--color-text);line-height:1.6}.rp-steps{margin:0;padding-left:1.25rem;display:flex;flex-direction:column;gap:.5rem}.rp-steps li{font-size:.92rem;color:var(--color-text);line-height:1.55}.rp-list{margin:0;padding-left:1.25rem;display:flex;flex-direction:column;gap:.45rem}.rp-list li{font-size:.92rem;color:var(--color-text);line-height:1.55}.rp-persona-overview{display:flex;align-items:center;gap:1rem}.rp-persona-avatar{font-size:3rem;flex-shrink:0}.rp-persona-name{margin:0 0 .15rem;font-size:1.15rem;color:var(--color-text)}.rp-persona-label{display:inline-block;font-size:.8rem;font-weight:600;color:var(--color-primary);margin-bottom:.3rem}.rp-persona-difficulty{font-size:.8rem;font-weight:600;margin-top:.15rem}.rp-tags{display:flex;flex-wrap:wrap;gap:.4rem}.rp-tag{background:var(--color-tag-bg);color:var(--color-tag-text);font-size:.75rem;padding:.2rem .55rem;border-radius:99px;font-weight:500}@media(max-width:480px){.resource-panel{width:100vw;border-left:none}}.rp-legal-link{color:var(--color-primary);font-size:.92rem;text-decoration:none;transition:opacity .15s}.rp-legal-link:hover{opacity:.75;text-decoration:underline}.rp-blog-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.75rem}.rp-blog-item{border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.rp-blog-link{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;text-decoration:none;color:inherit;transition:background .15s}.rp-blog-link:hover{background:var(--color-tag-bg)}.rp-blog-title{font-size:.88rem;font-weight:600;color:var(--color-primary);line-height:1.4}.rp-blog-excerpt{font-size:.8rem;color:var(--color-text-muted);line-height:1.5;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.home-page{max-width:960px;margin:0 auto;padding:2rem 1.5rem 4rem}.home-header{text-align:center;margin-bottom:2rem}.home-header-top{display:flex;align-items:center;justify-content:center;gap:.75rem;flex-wrap:wrap;margin-bottom:.5rem}.home-header h1{font-size:2.2rem;color:var(--color-primary);margin:0}.about-btn{background:none;border:1px solid var(--color-border);border-radius:8px;padding:.35rem .8rem;font-size:.88rem;color:var(--color-text-muted);cursor:pointer;transition:border-color .2s,color .2s;white-space:nowrap;text-decoration:none}.about-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.user-menu{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.user-greeting{font-size:.88rem;color:var(--color-text-muted);white-space:nowrap}.chats-badge{font-size:.82rem;color:var(--color-primary);font-weight:600;white-space:nowrap;cursor:default}.subtitle{color:var(--color-text-muted);font-size:1.05rem;max-width:600px;margin:0 auto;line-height:1.6}.api-key-section{margin-bottom:2.5rem;text-align:center}.api-key-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;max-width:500px;margin:0 auto}.api-key-form label{display:block;font-weight:600;margin-bottom:.5rem;text-align:left}.api-key-input-row{display:flex;gap:.5rem}.api-key-input-row input{flex:1;padding:.6rem .8rem;border:1px solid var(--color-border);border-radius:8px;font-size:.95rem;background:var(--color-bg)}.api-key-input-row button{padding:.6rem 1.2rem;background:var(--color-primary);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:opacity .2s}.api-key-input-row button:disabled{opacity:.5;cursor:default}.api-key-note{font-size:.8rem;color:var(--color-text-muted);margin-top:.5rem;text-align:left}.change-key-btn{background:none;border:1px solid var(--color-border);border-radius:8px;padding:.5rem 1rem;cursor:pointer;font-size:.9rem;color:var(--color-text-muted);transition:border-color .2s}.change-key-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.persona-section{margin-bottom:3rem}.persona-section h2{text-align:center;margin-bottom:1.5rem;color:var(--color-text)}.persona-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.persona-card{display:flex;align-items:flex-start;gap:1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.2rem;cursor:pointer;text-align:left;text-decoration:none;transition:transform .15s,box-shadow .15s,border-color .15s;width:100%;font-family:inherit;font-size:inherit;color:inherit}.persona-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000014;border-color:var(--color-primary)}.persona-avatar{font-size:2.5rem;flex-shrink:0;margin-top:.2rem}.persona-info h3{margin:0 0 .15rem;font-size:1.1rem}.persona-label{display:inline-block;font-size:.8rem;font-weight:600;color:var(--color-primary);margin-bottom:.4rem}.persona-desc{font-size:.88rem;color:var(--color-text-muted);line-height:1.5;margin:0 0 .6rem}.persona-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.difficulty{font-size:.78rem;font-weight:600}.tags{display:flex;gap:.35rem;flex-wrap:wrap}.tag{background:var(--color-tag-bg);color:var(--color-tag-text);font-size:.72rem;padding:.15rem .5rem;border-radius:99px;font-weight:500}.progress-summary-section{margin-bottom:3rem}.progress-summary-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.4rem 1.6rem}.progress-summary-text{margin:0;font-size:.95rem;color:var(--color-text);line-height:1.7;white-space:pre-line}.home-news-section{margin-bottom:3rem}.home-section-heading{margin:0 0 1rem;color:var(--color-text)}.home-news-list{display:flex;flex-direction:column;gap:1rem}.home-news-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.2rem 1.4rem;text-decoration:none;color:inherit;display:block;transition:transform .15s,box-shadow .15s,border-color .15s}.home-news-item:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000014;border-color:var(--color-primary)}.home-news-date{font-size:.8rem;color:var(--color-text-muted);display:block;margin-bottom:.3rem}.home-news-title{margin:0 0 .4rem;font-size:1rem}.home-news-content{margin:0;font-size:.9rem;color:var(--color-text-muted);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.home-feature-section{margin-bottom:3rem}.home-feature-header{display:flex;align-items:baseline;gap:1rem;margin-bottom:.5rem;flex-wrap:wrap}.home-feature-link{font-size:.9rem;color:var(--color-primary);text-decoration:none;white-space:nowrap}.home-feature-link:hover{text-decoration:underline}.home-feature-desc{color:var(--color-text-muted);font-size:.95rem;margin:0 0 1.2rem;line-height:1.6}.home-blog-preview{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.home-blog-card{display:flex;flex-direction:column;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;overflow:hidden;padding:0;text-decoration:none;color:inherit;transition:transform .15s,box-shadow .15s,border-color .15s}.home-blog-card-banner{width:100%;height:160px;object-fit:cover;display:block}.home-blog-card-body{padding:1.2rem;display:flex;flex-direction:column;flex:1}.home-blog-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000014;border-color:var(--color-primary)}.home-blog-card-title{margin:0 0 .5rem;font-size:1rem;line-height:1.4}.home-blog-card-excerpt{font-size:.85rem;color:var(--color-text-muted);line-height:1.5;margin:0 0 .75rem;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.how-it-works{text-align:center}.how-it-works h2{margin-bottom:1.5rem}.steps{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap}.step{flex:1;min-width:200px;max-width:260px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem 1.2rem}.step-number{display:inline-flex;align-items:center;justify-content:center;width:2.2rem;height:2.2rem;background:var(--color-primary);color:#fff;border-radius:50%;font-weight:700;font-size:1rem;margin-bottom:.75rem}.step h3{margin:0 0 .4rem;font-size:1rem}.step p{font-size:.88rem;color:var(--color-text-muted);line-height:1.5;margin:0}.report-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.report-modal{background:var(--color-surface, #fff);border-radius:12px;padding:1.5rem;max-width:420px;width:100%;box-shadow:0 8px 32px #0003}.report-modal-title{margin:0 0 .5rem;font-size:1.15rem}.report-modal-description{margin:0 0 1rem;font-size:.92rem;color:var(--color-text-muted, #666);line-height:1.5}.report-modal-label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.4rem;color:var(--color-text, #333)}.report-modal-textarea{width:100%;border:1px solid var(--color-border, #ddd);border-radius:8px;padding:.6rem .8rem;font-family:inherit;font-size:.9rem;resize:vertical;min-height:60px;box-sizing:border-box}.report-modal-textarea:focus{outline:none;border-color:var(--color-primary, #4f46e5)}.report-modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1rem}.report-modal-cancel{background:none;border:1px solid var(--color-border, #ddd);border-radius:8px;padding:.5rem 1rem;font-size:.88rem;cursor:pointer;color:var(--color-text, #333)}.report-modal-cancel:hover:not(:disabled){background:var(--color-bg, #f9fafb)}.report-modal-submit{background:#dc2626;color:#fff;border:none;border-radius:8px;padding:.5rem 1rem;font-size:.88rem;font-weight:600;cursor:pointer;transition:opacity .2s}.report-modal-submit:hover:not(:disabled){background:#b91c1c}.report-modal-submit:disabled,.report-modal-cancel:disabled{opacity:.5;cursor:default}.chat-page{display:flex;flex-direction:column;height:100vh;height:100dvh;max-width:800px;margin:0 auto;overflow:hidden}.opener-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--color-text-muted);font-size:.95rem}.opener-selection{flex:1;display:flex;flex-direction:column;align-items:center;padding:2rem 1.5rem;overflow-y:auto}.opener-selection h2{margin:0 0 .4rem;text-align:center;font-size:1.3rem}.opener-subtitle{color:var(--color-text-muted);font-size:.92rem;margin:0 0 .5rem;text-align:center}.opener-chats-remaining{font-size:.82rem;color:var(--color-primary);font-weight:600;margin:0 0 1.5rem;text-align:center}.opener-cards{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:560px}.opener-card{display:flex;align-items:flex-start;gap:.85rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.1rem 1.2rem;cursor:pointer;text-align:left;font-family:inherit;font-size:.95rem;color:var(--color-text);line-height:1.55;transition:transform .15s,box-shadow .15s,border-color .15s;width:100%}.opener-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000014;border-color:var(--color-primary)}.opener-card p{margin:0}.opener-card-avatar{font-size:1.6rem;flex-shrink:0;margin-top:.1rem}.opener-topic-label{font-weight:700;font-size:.98rem;margin:0 0 .25rem!important;color:var(--color-text)}.opener-topic-hint{font-size:.85rem;color:var(--color-text-muted);margin:0!important;line-height:1.45}.opener-card--random{flex-direction:column;align-items:center;text-align:center;padding:1.2rem;background:var(--color-tag-bg)}.opener-card--random:hover{border-color:var(--color-primary)}.opener-random-icon{font-size:2rem;margin-bottom:.35rem}.opener-random-label{font-weight:700;font-size:1rem;margin:0 0 .25rem!important}.opener-random-hint{font-size:.83rem;color:var(--color-text-muted);margin:0!important}.chat-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:1rem;color:var(--color-text-muted)}.chat-error button{padding:.5rem 1rem;background:var(--color-primary);color:#fff;border:none;border-radius:8px;cursor:pointer}.chat-header{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0}.back-btn{background:none;border:none;font-size:.95rem;cursor:pointer;color:var(--color-primary);font-weight:600;padding:.3rem .5rem}.chat-header-info{display:flex;align-items:center;gap:.6rem;flex:1}.chat-avatar{font-size:1.8rem}.chat-header-info h2{margin:0;font-size:1.1rem;line-height:1.2}.chat-persona-label{font-size:.78rem;color:var(--color-text-muted)}.end-btn{background:var(--color-primary);color:#fff;border:none;border-radius:8px;padding:.5rem 1rem;font-size:.88rem;font-weight:600;cursor:pointer;transition:opacity .2s;white-space:nowrap}.end-btn:disabled{opacity:.4;cursor:default}.chat-turns-left{display:flex;align-items:center;gap:.45rem;font-size:.9rem;color:var(--color-text-muted);white-space:nowrap}.chat-turns-emoji{font-size:1.05rem}.chat-turns-text{font-weight:700;color:var(--color-primary)}@media(max-width:480px){.chat-turns-text{display:none}}.turn-limit-notice{padding:.6rem 1rem;text-align:center;font-size:.9rem;color:var(--color-text-muted);background:linear-gradient(180deg,#ffffff05,#00000003);border-top:1px solid var(--color-border)}@media(max-width:480px){.chat-header{gap:.5rem}.end-btn{font-size:.78rem;padding:.45rem .6rem;white-space:normal;line-height:1.2;text-align:center}}.resources-fab{position:fixed;bottom:5.5rem;right:1rem;width:3.25rem;height:3.25rem;border-radius:50%;background:var(--color-surface);border:1px solid var(--color-border);font-size:1.3rem;cursor:pointer;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;justify-content:center;z-index:99;transition:transform .2s,box-shadow .2s,border-color .2s}.resources-fab:hover{transform:scale(1.08);box-shadow:0 6px 18px #0003;border-color:var(--color-primary)}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.chat-bubble{display:flex;align-items:flex-start;gap:.5rem;max-width:85%}.user-bubble{align-self:flex-end;flex-direction:row-reverse}.assistant-bubble{align-self:flex-start}.bubble-avatar{font-size:1.4rem;flex-shrink:0;margin-top:.15rem}.bubble-content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:.7rem 1rem;line-height:1.55;font-size:.95rem}.user-bubble .bubble-content{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.bubble-content p{margin:0}.typing{display:flex;gap:.3rem;padding:.8rem 1rem}.dot{width:8px;height:8px;background:var(--color-text-muted);border-radius:50%;animation:bounce 1.2s infinite ease-in-out}.dot:nth-child(2){animation-delay:.15s}.dot:nth-child(3){animation-delay:.3s}@keyframes bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-6px)}}.chat-input-area{display:flex;gap:.5rem;padding:.75rem 1rem;border-top:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0}.chat-input-area textarea{flex:1;resize:none;border:1px solid var(--color-border);border-radius:10px;padding:.6rem .8rem;font-family:inherit;font-size:.95rem;line-height:1.4;background:var(--color-bg)}.chat-input-area textarea:focus{outline:none;border-color:var(--color-primary)}.chat-input-area button{flex-shrink:0}.chat-api-error{padding:.6rem 1rem;text-align:center;font-size:.92rem;color:#7f1d1d;background:#fff1f2;border-top:1px solid #fecaca}.hint-btn{align-self:flex-end;width:2.75rem;height:2.75rem;border-radius:50%;background:#fef3c7;color:#92400e;border:1px solid #fde68a;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .2s,background .2s}.hint-btn:hover:not(:disabled){background:#fde68a}.hint-btn:disabled{opacity:.4;cursor:default}.send-btn{align-self:flex-end;width:2.75rem;height:2.75rem;border-radius:50%;background:var(--color-primary);color:#fff;border:none;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .2s}.send-btn:disabled{opacity:.4;cursor:default}.hint-bubble{align-self:center;max-width:90%}.hint-content{background:#fffbeb;border:1px solid #fde68a;color:#78350f}.hint-content .hint-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#b45309;margin:0 0 .3rem}.report-btn{align-self:flex-end;background:none;border:none;font-size:.75rem;cursor:pointer;opacity:.3;padding:.15rem;margin-top:.25rem;transition:opacity .2s;line-height:1}.report-btn:hover:not(:disabled){opacity:.8}.report-btn:disabled{opacity:.2;cursor:default}.assistant-bubble{flex-wrap:wrap}.assistant-bubble .report-btn{margin-left:2.4rem}.eval-page{max-width:800px;margin:0 auto;padding:2rem 1.5rem 4rem}.eval-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem;text-align:center}.spinner{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.eval-loading h2{margin:0}.eval-loading p{color:var(--color-text-muted);margin:0}.eval-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:40vh;gap:1rem;color:var(--color-text-muted)}.eval-error button{padding:.5rem 1rem;background:var(--color-primary);color:#fff;border:none;border-radius:8px;cursor:pointer}.eval-header{text-align:center;margin-bottom:2rem}.eval-header .back-btn{display:inline-block;margin-bottom:1rem;background:none;border:none;color:var(--color-primary);font-weight:600;cursor:pointer;font-size:.95rem}.eval-header h1{margin:0 0 .5rem;color:var(--color-primary)}.eval-subtitle{color:var(--color-text-muted);margin:0}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem;margin-bottom:2rem}.metric-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.2rem}.metric-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.metric-emoji{font-size:1.3rem}.metric-header h3{margin:0;flex:1;font-size:1rem}.metric-explanation{font-size:.9rem;color:var(--color-text);line-height:1.55;margin:0 0 .5rem}.metric-suggestion{font-size:.85rem;color:var(--color-text-muted);background:var(--color-tag-bg);padding:.6rem .8rem;border-radius:8px;line-height:1.5;margin-bottom:.5rem}.metric-example{font-size:.85rem;color:#78350f;background:#fffbeb;border:1px solid #fde68a;padding:.6rem .8rem;border-radius:8px;line-height:1.5}.subscriber-upsell{background:var(--color-surface);border:1px dashed var(--color-border);border-radius:12px;padding:1.5rem 1.4rem;margin-bottom:2rem;text-align:center;color:var(--color-text-muted)}.subscriber-upsell h3{margin:0 0 .5rem;color:var(--color-primary)}.subscriber-upsell p{margin:0;font-size:.95rem;line-height:1.6}.overall-comments{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.2rem 1.4rem;margin-bottom:2rem}.overall-comments h3{margin:0 0 .5rem}.overall-comments p{margin:0;line-height:1.6;color:var(--color-text)}.transcript-section{margin-bottom:2rem}.transcript-section summary{cursor:pointer;font-weight:600;color:var(--color-primary);padding:.5rem 0}.transcript{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1rem;margin-top:.5rem;max-height:400px;overflow-y:auto}.transcript-msg{padding:.4rem 0;line-height:1.55;font-size:.9rem}.transcript-msg.user{color:var(--color-primary)}.transcript-msg.assistant{color:var(--color-text)}.eval-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn-primary{padding:.7rem 1.5rem;background:var(--color-primary);color:#fff;border:none;border-radius:10px;font-weight:600;font-size:.95rem;cursor:pointer;transition:opacity .2s}.btn-primary:hover{opacity:.9}.btn-secondary{padding:.7rem 1.5rem;background:none;color:var(--color-primary);border:1px solid var(--color-primary);border-radius:10px;font-weight:600;font-size:.95rem;cursor:pointer;transition:background .2s}.btn-secondary:hover{background:var(--color-primary);color:#fff}.blog-page{max-width:960px;margin:0 auto;padding:2rem 1.5rem 4rem}.blog-header{text-align:center;margin-bottom:2.5rem}.blog-header-top{display:flex;align-items:center;justify-content:center;gap:.75rem;flex-wrap:wrap;margin-bottom:.5rem}.blog-header h1{font-size:2.2rem;color:var(--color-primary);margin:0}.blog-header .subtitle{color:var(--color-text-muted);font-size:1.05rem;max-width:600px;margin:.5rem auto 0;line-height:1.6}.home-link{background:none;border:1px solid var(--color-border);border-radius:8px;padding:.35rem .8rem;font-size:.88rem;color:var(--color-text-muted);cursor:pointer;text-decoration:none;white-space:nowrap;transition:border-color .2s,color .2s}.home-link:hover{border-color:var(--color-primary);color:var(--color-primary)}.blog-category-bar{display:flex;flex-wrap:wrap;gap:.5rem;margin:0 0 1.75rem}.blog-category-btn{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);border-radius:999px;padding:.3rem .7rem;font-size:.78rem;cursor:pointer;transition:border-color .2s,color .2s,background-color .2s}.blog-category-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.blog-category-btn--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}@keyframes ai-border-spin{0%{border-color:#6366f1}25%{border-color:#8b5cf6}50%{border-color:#ec4899}75%{border-color:#3b82f6}to{border-color:#6366f1}}.blog-category-btn--ai{border-width:2px;animation:ai-border-spin 3s linear infinite;font-weight:600;color:#6366f1;background:var(--color-surface)}.blog-category-btn--ai:hover{color:#8b5cf6}.blog-category-btn--ai.blog-category-btn--active{background:linear-gradient(135deg,#6366f1,#8b5cf6,#ec4899);border-color:transparent;animation:none;color:#fff}.blog-post-list{display:flex;flex-direction:column;gap:2rem}.blog-post-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s;text-decoration:none;color:inherit}.blog-post-card:hover{box-shadow:0 4px 20px #00000014}.blog-post-banner{width:100%;height:200px;object-fit:cover;display:block}.blog-post-banner-placeholder{width:100%;height:160px;background:var(--color-tag-bg);display:flex;align-items:center;justify-content:center;font-size:3rem}.blog-post-card-body{padding:1.5rem;display:flex;flex-direction:column;gap:.5rem}.blog-post-meta{display:flex;gap:1rem;font-size:.82rem;color:var(--color-text-muted)}.blog-post-card h2{margin:0;font-size:1.25rem;color:var(--color-text);line-height:1.35}.blog-post-card:hover h2{color:var(--color-primary)}.blog-post-excerpt{margin:0;font-size:.92rem;color:var(--color-text-muted);line-height:1.6}.blog-post-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.25rem}.read-more{margin-top:.5rem;font-size:.88rem;color:var(--color-primary);font-weight:600}.blog-empty{text-align:center;padding:4rem 1rem;color:var(--color-text-muted)}.blog-favorites-section{margin-bottom:3rem}.blog-section-heading{font-size:1.3rem;color:var(--color-text);margin:0 0 1.25rem}.favorite-btn{background:none;border:none;padding:0 .15rem;font-size:1rem;line-height:1;color:var(--color-text-muted);cursor:pointer;margin-left:auto;transition:color .15s,transform .15s}.favorite-btn:hover{color:#f59e0b;transform:scale(1.2)}.favorite-btn--active{color:#f59e0b}@media(min-width:640px){.blog-post-list{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}}@media(max-width:480px){.blog-header h1{font-size:1.75rem}}.blog-post-page{max-width:720px;margin:0 auto;padding:2rem 1.5rem 4rem}.blog-post-nav{display:flex;gap:.75rem;margin-bottom:2rem;flex-wrap:wrap}.back-link{background:none;border:1px solid var(--color-border);border-radius:8px;padding:.35rem .8rem;font-size:.88rem;color:var(--color-text-muted);cursor:pointer;text-decoration:none;white-space:nowrap;transition:border-color .2s,color .2s}.back-link:hover{border-color:var(--color-primary);color:var(--color-primary)}.blog-post-full-banner{width:100%;max-height:360px;object-fit:cover;border-radius:12px;margin-bottom:2rem;display:block}.blog-post-full-banner-placeholder{width:100%;height:200px;background:var(--color-tag-bg);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:4rem;margin-bottom:2rem}.blog-post-full-header{margin-bottom:2rem}.blog-post-full-meta{display:flex;gap:1rem;font-size:.85rem;color:var(--color-text-muted);margin-bottom:.75rem;flex-wrap:wrap}.blog-post-full-header h1{margin:0 0 1rem;font-size:2rem;color:var(--color-text);line-height:1.3}.blog-post-full-tags{display:flex;flex-wrap:wrap;gap:.4rem}.blog-tag{background:var(--color-tag-bg);color:var(--color-tag-text);font-size:.75rem;padding:.2rem .55rem;border-radius:99px;font-weight:500}.blog-post-quick-chat{margin-top:2rem}.blog-quick-chat-bubble{display:flex;align-items:flex-start;gap:.5rem;max-width:100%}.blog-quick-chat-bubble .bubble-avatar{font-size:1.4rem;flex-shrink:0;margin-top:.15rem}.blog-quick-chat-bubble .bubble-content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:.7rem 1rem;line-height:1.55;font-size:.95rem}.blog-quick-chat-bubble .bubble-content p{margin:0 0 .55rem}.quick-chat-link{display:inline-block;background:var(--color-tag-bg);border:1px solid var(--color-border);color:var(--color-primary);border-radius:8px;padding:.45rem .85rem;font-size:.88rem;font-weight:600;text-decoration:none;transition:border-color .2s,color .2s}.quick-chat-link:hover{border-color:var(--color-primary)}.blog-post-full-content{font-size:1rem;line-height:1.8;color:var(--color-text)}.blog-post-full-content h2,.blog-post-full-content h3{margin-top:2rem;margin-bottom:.5rem;color:var(--color-primary)}.blog-post-full-content p{margin:0 0 1.25rem}.blog-post-full-content ul,.blog-post-full-content ol{padding-left:1.5rem;margin:0 0 1.25rem}.blog-post-full-content li{margin-bottom:.4rem}.blog-post-full-content a{color:var(--color-primary)}.blog-post-full-content blockquote{border-left:3px solid var(--color-primary);padding-left:1rem;margin-left:0;color:var(--color-text-muted);font-style:italic}.blog-not-found{text-align:center;padding:4rem 1rem;color:var(--color-text-muted)}@media(max-width:480px){.blog-post-full-header h1{font-size:1.6rem}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background:var(--color-bg)}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;padding:2.5rem 2rem;width:100%;max-width:420px;box-shadow:0 4px 24px #00000012}.login-home-link{display:inline-block;font-size:.88rem;color:var(--color-text-muted);text-decoration:none;margin-bottom:1.5rem}.login-home-link:hover{color:var(--color-primary)}.login-site-name{margin:0 0 .35rem;font-size:.82rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted)}.login-card h1{margin:0 0 1.5rem;font-size:1.6rem;color:var(--color-text)}.login-form{display:flex;flex-direction:column;gap:1rem}.login-form label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem;font-weight:500;color:var(--color-text)}.login-form input{padding:.6rem .75rem;border:1px solid var(--color-border);border-radius:8px;font-size:1rem;font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);transition:border-color .2s}.login-form input:focus{outline:none;border-color:var(--color-primary)}.login-form input:disabled{opacity:.6;cursor:not-allowed}.login-optional{font-weight:400;color:var(--color-text-muted);font-size:.82rem}.login-submit-btn{margin-top:.5rem;padding:.7rem 1.5rem;background:var(--color-primary);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.login-submit-btn:hover:not(:disabled){background:var(--color-primary-light)}.login-submit-btn:disabled{opacity:.65;cursor:not-allowed}.login-error{margin:0;padding:.6rem .75rem;background:#fee2e2;color:#991b1b;border-radius:8px;font-size:.88rem}.login-info{margin:0;padding:.6rem .75rem;background:#ecfdf5;color:#065f46;border-radius:8px;font-size:.88rem}.login-instructions{font-size:.92rem;color:var(--color-text-muted);margin:-.5rem 0 1rem;line-height:1.6}.login-switch{margin:1.25rem 0 0;font-size:.9rem;color:var(--color-text-muted);text-align:center}.login-link-btn{background:none;border:none;padding:0;color:var(--color-primary);font-size:.9rem;font-weight:600;cursor:pointer;text-decoration:underline}.login-link-btn:hover{color:var(--color-primary-light)}.legal-page{max-width:720px;margin:0 auto;padding:2rem 1.5rem 4rem}.legal-nav{display:flex;gap:.75rem;margin-bottom:2rem;flex-wrap:wrap}.legal-header{margin-bottom:2rem}.legal-header h1{margin:0 0 .5rem;font-size:1.9rem;color:var(--color-text);line-height:1.3}.legal-updated{margin:0;font-size:.85rem;color:var(--color-text-muted)}.legal-content{font-size:1rem;line-height:1.8;color:var(--color-text)}.legal-content h2{margin-top:2.5rem;margin-bottom:.75rem;font-size:1.35rem;color:var(--color-primary);border-bottom:1px solid var(--color-border);padding-bottom:.35rem}.legal-content h3{margin-top:1.5rem;margin-bottom:.4rem;font-size:1.05rem;color:var(--color-primary)}.legal-content p{margin:0 0 1.1rem}.legal-content ul{padding-left:1.5rem;margin:0 0 1.1rem}.legal-content li{margin-bottom:.5rem;line-height:1.7}.legal-notice{background:var(--color-tag-bg);border-left:3px solid var(--color-primary);padding:.75rem 1rem;border-radius:0 8px 8px 0;font-size:.92rem;color:var(--color-text-muted);font-style:italic}.legal-contact{margin-top:2.5rem;font-size:.9rem;color:var(--color-text-muted);font-style:italic}@media(max-width:480px){.legal-header h1{font-size:1.5rem}}.App{min-height:100vh;background:var(--color-bg);color:var(--color-text)}
