body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.app-container{color:#333;font-family:Inter,Segoe UI,Roboto,sans-serif;line-height:1.6;margin:0 auto;max-width:1200px;padding:0 20px}.navbar{align-items:center;border-bottom:1px solid #eaeaea;display:flex;justify-content:space-between;margin-bottom:40px;padding:20px 0}.logo a{color:#2563eb;font-size:24px;font-weight:700;text-decoration:none}.nav-links li{margin-left:30px}.nav-links a{color:#555;font-weight:500;text-decoration:none;transition:color .3s ease}.nav-links a:hover{color:#2563eb}.content{min-height:calc(100vh - 200px);padding-bottom:40px}.footer{border-top:1px solid #eaeaea;color:#888;font-size:14px;padding:20px 0}.profile-header,.profile-section{margin-bottom:60px}.profile-header{align-items:center;display:flex;gap:40px}.profile-photo{border:3px solid #fff;border-radius:50%;box-shadow:0 10px 25px #0000001a;height:200px;object-fit:cover;width:200px}.profile-intro{flex:1 1}.profile-intro h1{color:#1e3a8a;font-size:36px;margin-top:0}.tagline{color:#4b5563;font-size:18px}.degree,.tagline{margin-bottom:20px}.degree{color:#6b7280;font-style:italic}.resume-link{background-color:#2563eb;border-radius:5px;color:#fff;display:inline-block;font-weight:500;padding:10px 20px;text-decoration:none;transition:background-color .3s ease}.resume-link:hover{background-color:#1e40af}.about-section{background-color:#f9fafb;border-radius:8px;box-shadow:0 4px 6px #0000000d;margin-bottom:40px;padding:30px}.about-section h2{color:#1e3a8a;margin-top:0}.skills-section{margin-bottom:40px}.skills-section h2{color:#1e3a8a;margin-bottom:20px}.skills-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.skill-category{background-color:#fff;border-radius:8px;box-shadow:0 4px 6px #0000000d;padding:20px}.skill-category h3{color:#2563eb;margin-bottom:15px;margin-top:0}.skill-category ul{list-style:none;margin:0;padding:0}.skill-category li{padding:5px 0 5px 20px;position:relative}.skill-category li:before{color:#2563eb;content:"→";left:0;position:absolute}.featured-projects{margin-bottom:60px}.featured-projects h2{color:#1e3a8a;margin-bottom:20px}.project-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-bottom:20px}.project-card{background-color:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;color:inherit;display:block;padding:20px;transition:transform .3s ease,box-shadow .3s ease}.project-card:hover{box-shadow:0 10px 15px #0000001a;transform:translateY(-5px)}.project-card h3{color:#2563eb;margin-top:0}.view-all{color:#2563eb;display:block;font-weight:500;text-align:right;text-decoration:none}.projects{margin:0 auto;max-width:1200px;padding:20px 0}.projects-header{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:16px;box-shadow:0 4px 6px #0000000d;margin-bottom:60px;padding:50px;text-align:center}.projects-header h1{color:#1e3a8a;font-size:42px;margin-bottom:20px}.projects-header p{color:#4b5563;font-size:18px;margin:0 auto;max-width:800px}.project-category{margin-bottom:60px}.category-header{background-color:#fff;border-left:4px solid #2563eb;border-radius:12px;box-shadow:0 2px 4px #0000000d;margin-bottom:30px;padding:30px}.category-header h2{color:#1e3a8a;font-size:28px;margin:0 0 10px}.category-header p{color:#6b7280;font-size:16px}.project-grid{grid-gap:25px;gap:25px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.project-item{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 6px #0000000d;padding:30px;transition:all .3s ease}.project-item:hover{box-shadow:0 8px 20px #0000001a;transform:translateY(-3px)}.project-item.featured{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:2px solid #10b981}.project-item h3{color:#1e3a8a;font-size:20px;margin-bottom:15px;margin-top:0}.project-item h3 a{color:inherit;transition:color .3s ease}.project-item h3 a:hover{color:#2563eb}.project-item p{color:#374151;line-height:1.6;margin-bottom:20px}.project-meta{flex-wrap:wrap;gap:10px;margin-bottom:15px}.course-code{background-color:#e0e7ff;color:#4338ca;text-transform:uppercase}.course-code,.grade{border-radius:20px;font-size:13px;font-weight:600;padding:4px 12px}.grade{background-color:#d1fae5;color:#065f46}.status{border-radius:20px;font-size:13px;font-weight:600;padding:4px 12px;text-transform:uppercase}.status.ongoing{background-color:#fef3c7;color:#92400e}.status.recent{background-color:#e0f2fe;color:#0369a1}.tech-stack{gap:8px;margin-bottom:15px}.tech-stack span{background-color:#f1f5f9;border:1px solid #e2e8f0;border-radius:20px;color:#475569;font-size:13px;font-weight:500;padding:6px 12px}.project-actions{margin-top:20px}.demo-link{background:linear-gradient(135deg,#10b981,#059669);border-radius:8px;box-shadow:0 2px 4px #10b98133;color:#fff;display:inline-block;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.demo-link:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 8px #10b9814d;transform:translateY(-2px)}.contact h2{color:#1e3a8a;margin-bottom:30px}.contact-form{background-color:#fff;border-radius:8px;box-shadow:0 4px 10px #00000014;padding:30px}.form-group input,.form-group textarea{border:1px solid #d1d5db;border-radius:4px;font-family:inherit;font-size:16px;padding:12px}.submit-button{background-color:#2563eb;border:none;border-radius:5px;color:#fff;transition:background-color .3s ease}.submit-button:hover{background-color:#1e40af}.contact-info{background-color:#f9fafb;border-radius:8px;padding:25px}.contact-info p{margin:10px 0}.contact-info a{color:#2563eb}.thesis-page{background:#fff;min-height:100vh}.thesis-container{margin:0 auto;max-width:1000px;padding:20px 0}.thesis-header{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:12px;box-shadow:0 4px 6px #0000000d;margin-bottom:60px;padding:40px;text-align:center}.thesis-header h1{color:#1e3a8a;font-size:42px;font-weight:700;margin-bottom:20px}.thesis-subtitle{color:#4b5563;font-size:20px;font-weight:500;margin:0}.thesis-overview{background-color:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d;margin-bottom:40px;padding:40px}.thesis-overview h2{color:#1e3a8a;font-size:28px;margin-bottom:25px;margin-top:0}.thesis-overview p{color:#374151;font-size:16px;line-height:1.7}.thesis-features{margin-bottom:40px}.thesis-features h2{color:#1e3a8a;font-size:28px;margin-bottom:30px}.features-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.feature-card{background-color:#fff;border-left:4px solid #2563eb;border-radius:12px;box-shadow:0 4px 6px #0000000d;padding:30px;transition:transform .3s ease}.feature-card:hover{transform:translateY(-2px)}.feature-card h3{color:#2563eb;font-size:18px;margin-bottom:15px;margin-top:0}.feature-card p{color:#6b7280;line-height:1.6;margin:0}.thesis-technology{background-color:#f9fafb;border-radius:12px;margin-bottom:40px;padding:30px}.thesis-technology h2{color:#1e3a8a;font-size:28px;margin-bottom:25px;margin-top:0}.sample-drawings{background-color:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d;margin-bottom:40px;padding:40px}.sample-drawings h2{color:#1e3a8a;font-size:28px;margin-bottom:25px;margin-top:0}.drawing-categories{margin-bottom:30px}.category h3{color:#2563eb;margin-bottom:15px}.category ul{list-style:none;padding:0}.category li{padding:8px 0 8px 20px;position:relative}.category li:before{color:#2563eb;content:"•";font-weight:700;left:0;position:absolute}.sample-gallery h3{color:#1e3a8a;margin-bottom:20px}.image-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.drawing-thumbnail{background-color:#f8fafc;border-radius:8px;box-shadow:0 2px 4px #0000001a;cursor:pointer;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.drawing-thumbnail:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-3px)}.drawing-thumbnail img{height:150px;object-fit:cover;width:100%}.drawing-thumbnail p{color:#374151;font-size:14px;font-weight:500;margin:0;padding:15px}.thesis-objectives{background-color:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d;margin-bottom:40px;padding:40px}.thesis-objectives h2{color:#1e3a8a;font-size:28px;margin-bottom:25px;margin-top:0}.thesis-objectives ol{counter-reset:step-counter;list-style:none;padding:0}.thesis-objectives li{color:#374151;counter-increment:step-counter;line-height:1.6;margin-bottom:20px;padding-left:40px;position:relative}.thesis-objectives li:before{align-items:center;background-color:#2563eb;border-radius:50%;color:#fff;content:counter(step-counter);display:flex;font-size:14px;font-weight:700;height:25px;justify-content:center;left:0;position:absolute;top:0;width:25px}.thesis-status{margin-bottom:40px}.thesis-status h2{color:#1e3a8a;font-size:28px;margin-bottom:30px}.status-timeline{background-color:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d;padding:30px}.timeline-item{border-left:3px solid #e5e7eb;margin-bottom:30px;padding-left:25px;position:relative}.timeline-item:before{background-color:#e5e7eb;border-radius:50%;content:"";height:12px;left:-7px;position:absolute;top:0;width:12px}.timeline-item.completed{border-left-color:#10b981}.timeline-item.completed:before{background-color:#10b981}.timeline-item.in-progress{border-left-color:#f59e0b}.timeline-item.in-progress:before{background-color:#f59e0b}.timeline-item.pending{border-left-color:#6b7280}.timeline-item.pending:before{background-color:#6b7280}.timeline-item h4{color:#1e3a8a;margin-bottom:10px;margin-top:0}.timeline-item p{color:#6b7280;line-height:1.6;margin:0}.thesis-impact{background-color:#f0f9ff;border-left:4px solid #0ea5e9;border-radius:12px;margin-bottom:40px;padding:40px}.thesis-impact h2{color:#1e3a8a;font-size:28px;margin-bottom:25px;margin-top:0}.thesis-impact p{color:#374151;font-size:16px;line-height:1.7;margin:0}.thesis-links{background-color:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d;padding:40px;text-align:center}.thesis-links h2{color:#1e3a8a;font-size:28px;margin-bottom:30px;margin-top:0}.link-buttons{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}.thesis-link-button{background-color:#2563eb;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#fff;display:inline-block;font-weight:500;padding:15px 25px;text-decoration:none;transition:background-color .3s ease,transform .3s ease}.thesis-link-button:hover{background-color:#1e40af;box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.image-modal{align-items:center;background-color:#000c;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.modal-content{border-radius:8px;max-height:90%;max-width:90%;padding:20px;position:relative;text-align:center}.modal-content img{border-radius:4px;max-height:70vh;max-width:100%;object-fit:contain}.modal-content h3{color:#1e3a8a;margin-bottom:0;margin-top:15px}.close-button{color:#6b7280;position:absolute;right:15px;top:10px}.close-button:hover{color:#374151}@media (max-width:768px){.profile-header{align-items:center;flex-direction:column;text-align:center}.project-cards,.project-grid,.skills-grid{grid-template-columns:1fr}.thesis-header h1{font-size:32px}.thesis-subtitle{font-size:18px}.features-grid{grid-template-columns:1fr}.image-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.link-buttons{align-items:center;flex-direction:column}.thesis-link-button{max-width:300px;width:100%}}.demo-container{background:#fff;color:#333;margin:0 auto;max-width:1200px;min-height:100vh;padding:20px}.demo-header{background:linear-gradient(135deg,#0f172a,#1e293b 50%,#334155);border-radius:24px;box-shadow:0 20px 60px #0f172a66;box-sizing:border-box;color:#fff;margin-bottom:60px;overflow:hidden;padding:80px 40px;position:relative;text-align:center}.demo-header:before{background:radial-gradient(circle at 30% 20%,#3b82f61a 0,#0000 70%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.demo-header h1{font-size:48px;font-weight:800;margin-bottom:24px}.demo-header h1,.demo-subtitle{color:#fff;position:relative;z-index:1}.demo-subtitle{font-size:22px;line-height:1.5;margin:0 auto 40px;max-width:600px;opacity:.85;padding:0}.demo-stats{display:flex;gap:60px;justify-content:center;margin-top:40px;padding:0;position:relative;width:100%;z-index:1}.stat-item{align-items:center;display:flex;flex-direction:column;gap:8px}.stat-number{color:#3b82f6;display:block;font-size:32px;font-weight:900}.stat-label{color:#fff;font-size:14px;line-height:1.3;max-width:120px;opacity:.8;text-align:center}.demo-features{display:flex;gap:60px;justify-content:center;margin-top:40px;position:relative;z-index:1}.demo-feature{align-items:center;display:flex;flex-direction:column;gap:8px}.feature-value{color:#60a5fa;font-size:32px;font-weight:900}.feature-text{color:#fffc;font-size:14px;line-height:1.3;max-width:120px;text-align:center}.demo-content{display:flex;flex-direction:column;gap:40px}.model-selection-section{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;border-radius:20px;box-shadow:0 4px 20px #38bdf81a;padding:32px}.model-selection-section h2{color:#0c4a6e;font-size:24px;font-weight:700;margin-bottom:12px;margin-top:0}.model-selection-section>p{color:#0369a1;font-size:16px;line-height:1.5;margin-bottom:24px}.model-options{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.model-card{background:#fff;border:2px solid #e0f2fe;border-radius:16px;cursor:pointer;padding:24px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.model-card:hover{border-color:#0ea5e9;box-shadow:0 8px 24px #0ea5e926;transform:translateY(-2px)}.model-card.selected{background:linear-gradient(135deg,#f0f9ff,#fff);border-color:#0284c7;box-shadow:0 8px 24px #0284c733}.model-header{gap:12px;margin-bottom:12px}.model-header,.model-radio{align-items:center;display:flex}.model-radio{border:2px solid #cbd5e1;border-radius:50%;flex-shrink:0;height:24px;justify-content:center;transition:all .2s ease;width:24px}.model-radio.selected{background:#fff;border-color:#0284c7}.radio-dot{animation:radioFadeIn .2s ease;background:#0284c7;border-radius:50%;height:12px;width:12px}@keyframes radioFadeIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.model-header h3{color:#0c4a6e;font-size:18px;font-weight:700;margin:0}.model-description{color:#475569;font-size:14px;line-height:1.6;margin:0 0 12px}.model-badge{background:linear-gradient(135deg,#10b981,#059669);border-radius:8px;color:#fff;display:inline-block;font-size:12px;font-weight:600;letter-spacing:.5px;padding:4px 12px}.api-test-section{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border:1px solid #cbd5e1;border-radius:20px;box-shadow:0 4px 20px #94a3b81a;padding:32px;position:relative}.api-test-section h2{color:#334155;font-size:24px;font-weight:700;margin-bottom:12px;margin-top:0}.api-test-section p{color:#64748b;font-size:16px;line-height:1.5;margin-bottom:24px}.api-test-controls{align-items:center;display:flex;flex-wrap:wrap;gap:20px}.test-api-button{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:12px;box-shadow:0 4px 12px #3b82f633;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px 28px;transition:all .3s cubic-bezier(.4,0,.2,1)}.test-api-button:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 8px 20px #3b82f64d;transform:translateY(-3px)}.test-api-button:disabled{cursor:not-allowed;opacity:.7;transform:none}.api-test-result{border-radius:8px;flex:1 1;font-weight:500;min-width:250px;padding:15px 20px}.api-test-result.success{background-color:#d1fae5;border:1px solid #10b981;color:#065f46}.api-test-result.error{background-color:#fee2e2;border:1px solid #ef4444;color:#991b1b}.api-test-result p{color:inherit;margin:0}.result-indicator{align-items:center;display:flex;gap:8px;margin-bottom:8px}.status-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.status-dot.success{animation:pulse-success 2s infinite;background-color:#10b981}.status-dot.error{background-color:#ef4444}@keyframes pulse-success{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.result-message{font-size:14px;margin:0}.upload-section{background-color:#fff;border:1px solid #f1f5f9;border-radius:24px;box-shadow:0 8px 32px #00000014;padding:48px}.upload-section h2{color:#1e3a8a;font-size:28px;margin-bottom:30px;margin-top:0}.upload-area{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px dashed #cbd5e1;border-radius:20px;cursor:pointer;margin-bottom:48px;padding:48px 32px;text-align:center;transition:all .4s cubic-bezier(.4,0,.2,1)}.upload-area:hover{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#3b82f6;box-shadow:0 8px 25px #3b82f626;transform:translateY(-2px)}.upload-content{align-items:center;display:flex;flex-direction:column;gap:20px}.upload-icon{color:#64748b;transition:color .3s ease}.upload-area:hover .upload-icon{color:#3b82f6}.upload-button{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:12px;box-shadow:0 4px 12px #3b82f640;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:16px 32px;transition:all .3s cubic-bezier(.4,0,.2,1)}.upload-button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 8px 20px #3b82f64d;transform:translateY(-2px)}.upload-hint{color:#64748b;font-size:14px;font-weight:500;margin:0}.sample-images h3{color:#334155;font-size:24px;font-weight:700;margin-bottom:12px}.sample-description{color:#64748b;font-size:16px;line-height:1.5;margin-bottom:32px}.sample-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.sample-item{background-color:#fff;border:1px solid #f1f5f9;border-radius:16px;box-shadow:0 4px 12px #00000014;cursor:pointer;overflow:hidden;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1)}.sample-item:hover{box-shadow:0 20px 40px #0000001f;transform:translateY(-8px)}.sample-image-container{overflow:hidden;position:relative}.sample-overlay{align-items:center;background:#3b82f6e6;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.sample-item:hover .sample-overlay{opacity:1}.sample-action{background:#0000;border:2px solid #fff;border-radius:8px;color:#fff;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s ease}.sample-overlay:hover .sample-action{background:#fff;color:#3b82f6}.sample-item.reference{border:2px solid #10b981}.sample-item.error{border:2px solid #ef4444}.sample-item img{height:150px;object-fit:cover;width:100%}.sample-info{padding:15px}.sample-label{color:#1e293b;font-weight:600;margin-bottom:8px}.sample-category{border-radius:20px;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px;text-transform:uppercase}.sample-category.reference{background-color:#d1fae5;color:#065f46}.sample-category.error{background-color:#fee2e2;color:#991b1b}.button-spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-top-color:#fff;height:16px;width:16px}.button-spinner,.status-indicator{border-radius:50%;display:inline-block;margin-right:8px}.status-indicator{height:8px;width:8px}.status-indicator.gemini{animation:pulse-success 2s infinite;background-color:#10b981}.status-indicator.mock{background-color:#f59e0b}.info-icon{color:#3b82f6;margin-bottom:16px}.image-preview{background-color:#fff;border-radius:16px;box-shadow:0 4px 6px #0000000d;padding:40px}.image-preview h3{color:#1e3a8a;font-size:24px;margin-bottom:25px;margin-top:0}.preview-container{grid-gap:30px;align-items:start;display:grid;gap:30px;grid-template-columns:1fr 300px}.preview-container img{border-radius:8px;box-shadow:0 4px 12px #0000001a;max-height:400px;object-fit:contain;width:100%}.image-info{background-color:#f8fafc;border-radius:8px;margin-bottom:20px;padding:20px}.image-info p{color:#475569;margin:8px 0}.analyze-button{background:linear-gradient(135deg,#2563eb,#1e40af);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:15px 25px;transition:all .3s ease;width:100%}.analyze-button:hover:not(:disabled){box-shadow:0 8px 20px #2563eb4d;transform:translateY(-2px)}.analyze-button:disabled{cursor:not-allowed;opacity:.7}.error-message{background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:20px;text-align:center}.error-message p{color:#dc2626;font-weight:500;margin:0}.analyzing-spinner{background-color:#fff;border-radius:16px;box-shadow:0 4px 6px #0000000d;padding:60px;text-align:center}.spinner{border:4px solid #e2e8f0;border-top-color:#2563eb;height:60px;margin:0 auto 20px;width:60px}.analyzing-spinner p{color:#475569;font-size:18px;margin:10px 0}.analysing-details{color:#64748b!important;font-size:14px!important}.analysis-results{background-color:#fff;border-radius:16px;box-shadow:0 4px 6px #0000000d;padding:40px}.results-header{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:40px;padding-bottom:20px}.results-header h2{color:#1e3a8a;font-size:32px;margin:0}.overall-score{text-align:center}.score-circle{align-items:center;background-color:#f8fafc;border:6px solid;border-radius:50%;display:flex;flex-direction:column;height:120px;justify-content:center;width:120px}.score-number{color:#1e293b;font-size:32px;font-weight:700}.score-label{color:#64748b;font-size:14px;font-weight:500}.summary-section{background-color:#f8fafc;border-left:4px solid #2563eb;border-radius:12px;margin-bottom:40px;padding:30px}.summary-section h3{color:#1e3a8a;font-size:24px;margin-bottom:15px;margin-top:0}.summary-text{color:#374151;font-size:16px;line-height:1.6;margin-bottom:15px}.analysis-meta{color:#64748b;display:flex;flex-wrap:wrap;font-size:14px;gap:30px}.api-status{border-radius:12px;font-size:12px;font-weight:600;padding:4px 8px}.api-status.gemini{background-color:#d1fae5;border:1px solid #10b981;color:#065f46}.api-status.openai{background-color:#dbeafe;border:1px solid #3b82f6;color:#1e40af}.api-status.mock{background-color:#fef3c7;border:1px solid #f59e0b;color:#92400e}.feedback-categories h3{color:#1e3a8a;font-size:24px;margin-bottom:25px}.categories-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:40px}.category-card{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:25px;transition:all .3s ease}.category-card:hover{box-shadow:0 8px 20px #0000001a;transform:translateY(-2px)}.category-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.category-header h4{color:#1e3a8a;font-size:18px;margin:0}.category-score{font-size:18px;font-weight:700}.status-badge{border-radius:20px;color:#fff;display:inline-block;font-size:11px;font-weight:600;margin-bottom:15px;padding:6px 12px}.category-comments{color:#475569;line-height:1.6;margin:0}.suggestions-section{background-color:#f0f9ff;border-left:4px solid #0ea5e9;border-radius:12px;margin-bottom:40px;padding:30px}.suggestions-section h3{color:#1e3a8a;font-size:24px;margin-bottom:20px;margin-top:0}.suggestions-list{list-style:none;margin:0;padding:0}.suggestions-list li{border-bottom:1px solid #e0f2fe;color:#374151;line-height:1.6;padding:12px 0 12px 30px;position:relative}.suggestions-list li:last-child{border-bottom:none}.suggestions-list li:before{content:"💡";left:0;position:absolute;top:12px}.action-buttons{display:flex;flex-wrap:wrap;gap:15px;justify-content:center}.primary-button,.secondary-button{border:none;border-radius:8px;cursor:pointer;display:inline-block;font-weight:600;padding:12px 24px;text-decoration:none;transition:all .3s ease}.primary-button{background-color:#2563eb;color:#fff}.primary-button:hover{background-color:#1e40af;transform:translateY(-2px)}.secondary-button{background-color:#fff;border:2px solid #2563eb;color:#2563eb}.secondary-button:hover{background-color:#2563eb;color:#fff;transform:translateY(-2px)}.demo-info{background-color:#fff;border-radius:16px;box-shadow:0 4px 6px #0000000d;margin-top:40px;padding:40px}.demo-info h2{color:#1e3a8a;font-size:28px;margin-bottom:30px;margin-top:0;text-align:center}.info-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-card{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:25px}.info-card h3{color:#2563eb;font-size:18px;margin-bottom:15px;margin-top:0}.info-card p{color:#475569;line-height:1.6;margin:0}.demo-button{animation:pulse 2s infinite;background:linear-gradient(135deg,#10b981,#059669)!important}.demo-button:hover{background:linear-gradient(135deg,#059669,#047857)!important}@keyframes pulse{0%{box-shadow:0 0 0 0 #10b981b3}70%{box-shadow:0 0 0 10px #10b98100}to{box-shadow:0 0 0 0 #10b98100}}.rebalance-calculator{background-color:#f8fafc;margin:0 auto;max-width:1200px;min-height:calc(100vh - 200px);padding:20px}.calculator-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 10px 25px #0000001a;color:#fff;margin-bottom:40px;padding:40px;text-align:center}.calculator-header h1{font-size:42px;font-weight:700;margin:0 0 10px}.calculator-header p{font-size:18px;margin:0;opacity:.9}.no-portfolios{background-color:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d;margin:20px 0;padding:60px 20px;text-align:center}.no-portfolios h2{color:#475569;margin-bottom:10px}.no-portfolios p{color:#64748b;margin-bottom:30px}.create-portfolio-btn{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px 28px;transition:all .3s ease}.create-portfolio-btn:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 6px 20px #10b9814d;transform:translateY(-2px)}.calculator-content{background-color:#fff;border-radius:16px;box-shadow:0 4px 6px #0000000d;margin-bottom:30px;padding:30px}.portfolio-selector{align-items:center;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border:1px solid #e2e8f0;border-radius:12px;display:flex;justify-content:space-between;margin-bottom:30px;padding:20px}.portfolio-info h2{color:#1e293b;font-size:24px;margin:0 0 5px}.portfolio-info p{color:#64748b;font-size:14px;margin:0}.portfolio-actions{display:flex;gap:10px}.btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 16px;transition:all .3s ease}.btn-primary{background-color:#3b82f6;color:#fff}.btn-primary:hover{background-color:#2563eb;transform:translateY(-1px)}.btn-secondary{background-color:#fff;border:1px solid #d1d5db;color:#475569}.btn-secondary:hover{background-color:#f8fafc;border-color:#9ca3af}.btn-success{background-color:#10b981;color:#fff}.btn-success:hover{background-color:#059669;transform:translateY(-1px)}.btn-danger{background-color:#ef4444;color:#fff}.btn-danger:hover{background-color:#dc2626;transform:translateY(-1px)}.refresh-prices{gap:10px;margin-bottom:20px}.refresh-btn,.refresh-prices{align-items:center;display:flex}.refresh-btn{background-color:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;gap:8px;padding:10px 16px;transition:all .3s ease}.refresh-btn:hover{background-color:#2563eb;transform:translateY(-1px)}.refresh-btn:disabled{background-color:#9ca3af;cursor:not-allowed;transform:none}.last-updated{color:#64748b;font-size:14px}.tabs{background-color:#f8fafc;border-bottom:1px solid #e2e8f0;border-radius:12px 12px 0 0;display:flex;margin-bottom:30px;padding:0 20px}.tab-button{background:none;border:none;border-bottom:3px solid #0000;color:#64748b;cursor:pointer;font-size:16px;font-weight:500;padding:15px 20px;transition:all .3s ease}.tab-button.active{background-color:#fff;border-bottom-color:#3b82f6;color:#3b82f6}.tab-button:hover{background-color:#3b82f60d;color:#3b82f6}.tab-content{margin-top:0}.holdings-list{grid-gap:15px;display:grid;gap:15px}.holding-item{grid-gap:15px;align-items:center;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:grid;gap:15px;grid-template-columns:2fr 1fr 1fr 1fr 1fr auto;padding:20px;transition:all .3s ease}.holding-item:hover{border-color:#cbd5e1;box-shadow:0 4px 6px #0000000d}.holding-info h4{color:#1e293b;font-size:16px;margin:0 0 5px}.holding-info p{color:#64748b;font-size:14px;margin:0}.holding-value{font-weight:600;text-align:right}.value-positive{color:#059669}.value-negative{color:#dc2626}.value-neutral{color:#64748b}.allocations-grid,.analytics-grid,.portfolio-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:20px}.summary-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 6px #0000001a;color:#fff;padding:25px}.summary-card h3{font-size:18px;margin:0 0 20px}.summary-stat{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.summary-stat:last-child{margin-bottom:0}.stat-value{font-size:18px;font-weight:600}.performance-card{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;padding:25px}.performance-card h3{font-size:18px;margin:0 0 20px}.allocation-item{align-items:center;background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:10px;padding:15px}.allocation-input{border-radius:4px;text-align:right;width:80px}.allocation-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.rebalance-actions{grid-gap:15px;gap:15px}.action-item{grid-gap:15px;align-items:center;background-color:#fff;border-left:4px solid;border-radius:8px;box-shadow:0 2px 4px #0000000d;display:grid;gap:15px;grid-template-columns:auto 2fr 1fr 1fr 1fr 1fr;padding:20px}.action-buy{border-left-color:#059669}.action-sell{border-left-color:#dc2626}.action-badge{border-radius:4px;padding:4px 8px;text-align:center}.badge-buy{background-color:#d1fae5;color:#065f46}.badge-sell{background-color:#fee2e2;color:#991b1b}.modal-overlay{background-color:#00000080}.modal-content{background-color:#fff;border-radius:12px;box-shadow:0 20px 25px #0000001a;max-height:90vh;max-width:500px;overflow-y:auto;padding:30px;width:90%}.modal-header{margin-bottom:20px}.close-btn{align-items:center;background:none;border:none;color:#64748b;cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;width:30px}.close-btn:hover{color:#dc2626}.form-group{margin-bottom:20px}.form-group label{margin-bottom:5px}.form-group input,.form-group select,.form-group textarea{border:1px solid #d1d5db;border-radius:6px;box-sizing:border-box;font-size:16px;padding:10px 12px;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:30px}.search-input{border:1px solid #d1d5db;border-radius:6px;font-size:16px;margin-bottom:10px;padding:10px 12px;width:100%}.search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.search-results{background-color:#fff;border:1px solid #e2e8f0;border-radius:6px}.search-result{border-bottom:1px solid #f1f5f9;transition:background-color .2s ease}.search-result:hover{background-color:#f8fafc}.search-result:last-child{border-bottom:none}.search-result h4{color:#1e293b;font-size:14px;margin:0 0 4px}.search-result p{color:#64748b;font-size:12px;margin:0}.loading-spinner{align-items:center;display:flex;justify-content:center;padding:20px}.spinner{animation:spin 1s linear infinite;border:2px solid #e2e8f0;border-radius:50%;border-top-color:#3b82f6;height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}.empty-state{color:#64748b;padding:40px 20px;text-align:center}.empty-state h3{color:#475569;margin:0 0 10px}.empty-state p{margin:0 0 20px}@media (max-width:768px){.demo-header h1{font-size:36px}.demo-subtitle{font-size:18px}.preview-container{grid-template-columns:1fr}.results-header{flex-direction:column;gap:20px;text-align:center}.categories-grid{grid-template-columns:1fr}.action-buttons{align-items:center;flex-direction:column}.primary-button,.secondary-button{max-width:300px;width:100%}.info-grid{grid-template-columns:1fr}.analysis-meta{flex-direction:column;gap:10px}.rebalance-calculator .tab-content{margin-top:15px}.rebalance-calculator .tabs{flex-direction:column;margin-bottom:20px}.rebalance-calculator .tab-button{margin:2px 0}.rebalance-calculator .allocations-grid,.rebalance-calculator .analytics-grid,.rebalance-calculator .portfolio-grid{grid-template-columns:1fr}.rebalance-calculator .modal-content{margin:10px;max-width:calc(100vw - 20px)}.rebalance-calculator .form-grid{grid-template-columns:1fr}}.rebalance-container{margin:0 auto;max-width:1200px;min-height:calc(100vh - 200px);padding:20px}.rebalance-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;display:flex;justify-content:space-between;margin-bottom:30px;padding:20px}.header-content h1{font-size:28px;margin:0 0 5px}.header-content p{margin:0;opacity:.9}.header-actions{align-items:center;display:flex;gap:10px}.portfolio-selector{background:#fff3;border:none;border-radius:6px;color:#fff;font-size:14px;padding:8px 12px}.portfolio-selector option{color:#333}.create-button,.refresh-button{background:#fff3;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .2s}.create-button:hover,.refresh-button:hover{background:#ffffff4d}.refresh-button:disabled{cursor:not-allowed;opacity:.6}.performance-summary{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.performance-card{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:20px;text-align:center}.performance-card h3{color:#64748b;font-size:14px;font-weight:500;margin:0 0 10px}.performance-value{color:#1e293b;font-size:24px;font-weight:700}.performance-value.small{font-size:16px}.performance-value.positive{color:#059669}.performance-value.negative{color:#dc2626}.performance-percent{font-size:14px;margin-left:8px}.tab-navigation{background:#f1f5f9;border-radius:8px;display:flex;gap:2px;margin-bottom:20px;padding:4px}.tab{background:#0000;border:none;border-radius:6px;cursor:pointer;flex:1 1;font-weight:500;padding:12px 16px;transition:all .2s}.tab.active{background:#fff;box-shadow:0 2px 4px #0000001a;color:#667eea}.tab-content{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:20px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.section-header h2{color:#1e293b;margin:0}.add-button,.primary-button{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px;transition:background-color .2s}.add-button:hover,.primary-button:hover{background:#5a67d8}.secondary-button{background:#e2e8f0;border:none;border-radius:6px;color:#475569;cursor:pointer;font-weight:500;padding:10px 20px;transition:background-color .2s}.secondary-button:hover{background:#cbd5e0}.empty-allocations,.empty-holdings,.no-rebalance{color:#64748b;padding:40px;text-align:center}.holdings-table{overflow-x:auto}.table-header,.table-row{grid-gap:16px;align-items:center;display:grid;gap:16px;grid-template-columns:80px 1fr 80px 100px 100px 120px 120px 80px 80px;padding:12px 0}.table-header{border-bottom:2px solid #e2e8f0;color:#475569;font-weight:600;padding-bottom:8px}.table-row{border-bottom:1px solid #f1f5f9}.table-row:hover{background:#f8fafc}.symbol{color:#1e293b;font-weight:600}.name{color:#64748b;font-size:14px}.positive{color:#059669}.negative{color:#dc2626}.remove-button{background:#fee2e2;border:none;border-radius:4px;color:#dc2626;cursor:pointer;font-size:12px;padding:6px 12px;transition:background-color .2s}.remove-button:hover{background:#fecaca}.allocations-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.allocation-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:20px}.allocation-header h3{color:#1e293b;margin:0 0 4px}.allocation-name{color:#64748b;font-size:14px}.allocation-input-group{align-items:center;display:flex;margin-top:12px}.allocation-input{border:1px solid #d1d5db;border-radius:6px;flex:1 1;font-size:16px;padding:8px 12px}.allocation-unit{color:#64748b;font-weight:500;margin-left:8px}.allocation-summary{align-items:center;display:flex;font-weight:500;gap:10px}.allocation-warning{color:#dc2626;font-size:14px}.rebalance-actions{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.action-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:20px;transition:border-color .2s}.action-card.buy{border-color:#059669}.action-card.sell{border-color:#dc2626}.action-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.action-header h3{color:#1e293b;margin:0}.action-badge{border-radius:20px;font-size:12px;font-weight:600;padding:4px 12px;text-transform:uppercase}.action-badge.buy{background:#dcfce7;color:#059669}.action-badge.sell{background:#fee2e2;color:#dc2626}.action-details{space-y:8px}.action-amount{color:#1e293b;font-size:18px;font-weight:600}.action-value{color:#64748b;font-size:14px;margin-left:8px}.action-allocations{align-items:center;display:flex;gap:8px;margin:8px 0}.current{color:#dc2626}.target{color:#059669}.arrow{color:#64748b}.action-price{color:#64748b;font-size:14px}.analytics-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.analytics-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px}.analytics-card h3{color:#1e293b;margin:0 0 16px}.metrics-list,.sector-breakdown{space-y:12px}.metric,.sector-item{align-items:center;display:flex;justify-content:space-between;padding:8px 0}.metric span:first-child,.sector-name{color:#475569}.metric span:last-child,.sector-value{color:#1e293b;font-weight:600}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{background:#fff;border-radius:12px;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px}.modal-header h2{color:#1e293b;margin:0}.close-button{background:none;border:none;color:#64748b;cursor:pointer;font-size:24px;line-height:1}.modal-body{padding:20px}.modal-actions{border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;padding:20px}.form-group{margin-bottom:16px}.form-group label{color:#374151;margin-bottom:6px}.form-input{border:1px solid #d1d5db;border-radius:6px;font-size:16px;padding:10px 12px;width:100%}.form-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.stock-search{position:relative}.search-results{background:#fff;border:1px solid #d1d5db;border-radius:0 0 6px 6px;border-top:none;left:0;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:10}.search-result{border-bottom:1px solid #f3f4f6;cursor:pointer;display:flex;justify-content:space-between;padding:12px}.search-result:hover{background:#f9fafb}.result-symbol{color:#1e293b;font-weight:600}.result-name{color:#64748b}.selected-stock{background:#dcfce7;border-radius:6px;color:#059669;font-size:14px;margin-top:8px;padding:8px 12px}.empty-state{align-items:center;display:flex;justify-content:center;min-height:60vh}.empty-state-content{max-width:400px;text-align:center}.empty-icon{color:#667eea;margin-bottom:20px}.empty-state h2{color:#1e293b;margin:0 0 10px}.empty-state p{color:#64748b;line-height:1.6;margin:0 0 30px}.empty-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.hero-container{background:#0d1117;background-image:radial-gradient(circle at 20% 50%,#2386361a 0,#0000 50%),radial-gradient(circle at 80% 20%,#0d6efd1a 0,#0000 50%),linear-gradient(180deg,#0d1117,#161b22);color:#c9d1d9;margin-bottom:0;overflow:hidden;padding:100px 0;position:relative}.hero-container:before{background-image:linear-gradient(#21262dcc 1px,#0000 0),linear-gradient(90deg,#21262dcc 1px,#0000 0);background-size:20px 20px;bottom:0;content:"";left:0;opacity:.3;position:absolute;right:0;top:0}.hero-content{grid-gap:80px;align-items:center;display:grid;gap:80px;grid-template-columns:2fr 1fr;margin:0 auto;max-width:1400px;padding:0 40px;position:relative;z-index:2}.hero-text{animation:slideInLeft .8s ease-out}.hero-name{animation:fadeInUp .6s ease-out .2s both;color:#58a6ff;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:4rem;font-weight:700;line-height:1.1;margin:0 0 16px;text-shadow:0 0 20px #58a6ff4d}.hero-name:before{color:#7c3aed;content:"> ";font-weight:400}.hero-tagline{animation:fadeInUp .6s ease-out .4s both;color:#7d8590;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:1.2rem;font-weight:400;margin:0 0 24px}.hero-tagline:before{color:#6e7681;content:"// "}.hero-degree{animation:fadeInUp .6s ease-out .6s both;color:#f0f6fc;font-size:1rem;margin:0 0 8px}.hero-degree,.hero-university{border-left:3px solid #238636;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;padding-left:16px}.hero-university{animation:fadeInUp .6s ease-out .8s both;color:#7d8590;font-size:.95rem;margin:0 0 40px}.hero-actions{animation:fadeInUp .6s ease-out 1s both;display:flex;gap:16px}.cta-button{align-items:center;border-radius:6px;display:inline-flex;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.9rem;font-weight:500;gap:8px;padding:12px 24px;position:relative;text-decoration:none;transition:all .2s ease}.cta-button.primary{background:#238636;border:1px solid #2ea043;box-shadow:0 1px 0 #1b1f240a;color:#f0f6fc}.cta-button.primary:hover{background:#2ea043;border-color:#46954a;box-shadow:0 3px 8px #2386364d;transform:translateY(-1px)}.cta-button.secondary{background:#0000;border:1px solid #30363d;color:#f0f6fc}.cta-button.secondary:hover{background:#21262d;border-color:#8b949e;transform:translateY(-1px)}.hero-image{animation:slideInRight .8s ease-out;display:flex;justify-content:center;position:relative}.hero-image:before{background:linear-gradient(45deg,#58a6ff,#7c3aed,#238636,#ff7b72);border-radius:12px;content:"";filter:blur(20px);inset:-20px;opacity:.3;position:absolute;z-index:-1}.hero-image .profile-photo{border:2px solid #30363d;border-radius:12px;box-shadow:0 0 0 1px #21262d,0 16px 32px #010409d9;height:320px;object-fit:cover;position:relative;transition:all .3s ease;width:320px;z-index:1}.hero-image .profile-photo:hover{border-color:#58a6ff;box-shadow:0 0 0 1px #58a6ff,0 20px 40px #010409e6,0 0 20px #58a6ff33;transform:translateY(-4px) scale(1.02)}.intro-section{grid-gap:80px;align-items:center;background:#0d1117;border-top:1px solid #21262d;display:grid;gap:80px;grid-template-columns:2fr 1fr;margin:0 auto;max-width:1400px;padding:80px 40px}.intro-content h2{color:#f0f6fc;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:2.2rem;font-weight:600;margin:0 0 24px}.intro-content h2:before{color:#ff7b72;content:"function ";font-size:1.8rem}.intro-content h2:after{color:#7d8590;content:"() {"}.intro-content p{border-left:2px solid #21262d;color:#8b949e;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:1.1rem;line-height:1.7;margin:0;padding-left:20px}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr)}.stat-item{background:#161b22;border:1px solid #30363d;border-radius:6px;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;padding:20px;text-align:left;transition:all .2s ease}.stat-item:hover{background:#21262d;border-color:#58a6ff;box-shadow:0 8px 24px #01040926;transform:translateY(-2px)}.stat-number{color:#58a6ff;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:2.2rem;font-weight:700;margin-bottom:4px}.stat-number:before{color:#ff7b72;content:"const ";font-size:.8rem;font-weight:400}.stat-number:after{color:#7d8590;content:" =";font-size:1.2rem;font-weight:400}.stat-label{color:#7d8590;font-size:.85rem;font-weight:400;margin-top:8px}.skills-section{background:#161b22;border-top:1px solid #30363d;margin:0 auto;max-width:1400px;padding:80px 40px}.section-header{margin-bottom:50px;text-align:left}.section-header h2{color:#f0f6fc;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:2rem;font-weight:600;margin:0 0 12px}.section-header h2:before{color:#ff7b72;content:"class "}.section-header h2:after{color:#7d8590;content:" {"}.section-header p{color:#7d8590;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:1rem;margin:0;padding-left:20px}.section-header p:before{color:#6e7681;content:"// "}.skills-container{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.skill-category{background:#0d1117;border:1px solid #30363d;border-radius:6px;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;padding:24px;transition:all .2s ease}.skill-category:hover{background:#21262d;border-color:#58a6ff;transform:translateY(-2px)}.skill-category h3{color:#58a6ff;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:1.1rem;font-weight:600;margin:0 0 16px}.skill-category h3:before{color:#ff7b72;content:"private ";font-size:.9rem}.skill-category h3:after{color:#7d8590;content:"[] = [";font-size:.9rem}.skill-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.skill-tag{background:#21262d;border:1px solid #30363d;border-radius:3px;color:#f79000;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.8rem;font-weight:400;padding:4px 8px;transition:all .2s ease}.skill-tag:after,.skill-tag:before{color:#a5d6ff;content:'"'}.skill-tag:hover{background:#58a6ff;border-color:#58a6ff;color:#0d1117;transform:translateY(-1px)}.skill-category:after{color:#7d8590;content:"];";display:block;font-size:.9rem;margin-top:8px}.coursework-section{background:#0d1117;border-top:1px solid #30363d;margin:0 auto;max-width:1400px;padding:80px 40px}.highlight-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.highlight-item{align-items:flex-start;background:#161b22;border:1px solid #30363d;border-radius:6px;display:flex;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;gap:16px;padding:20px;transition:all .2s ease}.highlight-item:hover{background:#21262d;border-color:#238636;transform:translateY(-2px)}.highlight-grade{background:#238636;border:1px solid #2ea043;border-radius:4px;flex-shrink:0;font-size:.9rem;min-width:50px;padding:8px 12px;text-align:center}.highlight-details h4,.highlight-grade{color:#f0f6fc;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-weight:600}.highlight-details h4{font-size:1rem;margin:0 0 8px}.highlight-details p{color:#7d8590;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.85rem;line-height:1.4;margin:0}.featured-projects{background:#161b22;border-top:1px solid #30363d;margin:0 auto;max-width:1400px;padding:80px 40px}.projects-showcase{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));margin-bottom:40px}.project-card{background:#0d1117;border:1px solid #30363d;border-radius:6px;color:#c9d1d9;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;padding:24px;text-decoration:none;transition:all .2s ease}.project-card:hover{background:#21262d;border-color:#58a6ff;box-shadow:0 8px 24px #01040926;transform:translateY(-2px)}.project-card.featured{background:#0d1521;border:1px solid #238636;position:relative}.project-card.featured:before{background:#238636;border-radius:3px;color:#f0f6fc;content:"main";font-size:.7rem;font-weight:500;padding:2px 6px;position:absolute;right:12px;top:8px}.project-card.featured:hover{border-color:#2ea043}.project-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.project-header h3{color:#58a6ff;font-size:1.1rem;font-weight:600;margin:0}.project-header h3,.project-status{font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace}.project-status{border:1px solid;border-radius:3px;font-size:.7rem;font-weight:500;padding:2px 6px}.project-status.ongoing{background:#1e1e1e;border-color:#f79000;color:#f79000}.project-card.featured .project-status,.project-status.completed{background:#0d1117;border-color:#238636;color:#238636}.project-card p{color:#8b949e;font-size:.9rem;line-height:1.5;margin:0 0 16px}.project-tech{display:flex;flex-wrap:wrap;gap:6px}.tech-tag{background:#21262d;border:1px solid #30363d;border-radius:3px;color:#f79000;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.75rem;font-weight:400;padding:2px 6px}.tech-tag:before{color:#7d8590;content:"#"}.project-card.featured .tech-tag{background:#21262d;border-color:#238636;color:#a5d6ff}.projects-cta{text-align:center}.view-all-button{align-items:center;background:#238636;border:1px solid #2ea043;border-radius:6px;color:#f0f6fc;display:inline-flex;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.9rem;font-weight:500;gap:8px;padding:12px 24px;text-decoration:none;transition:all .2s ease}.view-all-button:hover{background:#2ea043;border-color:#46954a;box-shadow:0 4px 12px #2386364d;transform:translateY(-1px)}.arrow{font-family:monospace;transition:transform .2s ease}.view-all-button:hover .arrow{transform:translateX(2px)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-50px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(50px)}to{opacity:1;transform:translateX(0)}}@media (max-width:768px){.hero-content{gap:40px;grid-template-columns:1fr;padding:0 20px;text-align:center}.hero-name{font-size:2.5rem}.hero-tagline{font-size:1.1rem}.hero-image .profile-photo{height:240px;width:240px}.hero-actions{align-items:center;flex-direction:column;justify-content:center}.intro-section{gap:40px;padding:60px 20px}.intro-section,.stats-grid{grid-template-columns:1fr}.coursework-section,.featured-projects,.skills-section{padding:60px 20px}.highlight-grid,.projects-showcase,.skills-container{grid-template-columns:1fr}.intro-content h2,.section-header h2{font-size:1.8rem}}body{background:#fff;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans,Helvetica,Arial,sans-serif}.app-container.dark-theme{min-height:100vh}.app-container.dark-theme,.content.dark-theme{background:#0d1117;color:#c9d1d9}.app-container.thesis-theme{background:#fff;color:#333;min-height:100vh}.content.thesis-theme{background:#fff;color:#333}.profile-section,.projects{background:#0d1117;color:#c9d1d9}.projects{font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;min-height:100vh}.contact{padding:40px 20px}.projects-header{background:#161b22;border-bottom:1px solid #30363d;padding:60px 40px;position:relative;text-align:left}.projects-header:before{background-image:linear-gradient(#21262dcc 1px,#0000 0),linear-gradient(90deg,#21262dcc 1px,#0000 0);background-size:20px 20px;bottom:0;content:"";left:0;opacity:.3;position:absolute;right:0;top:0}.projects-header h1{color:#58a6ff;font-size:2.5rem;font-weight:700;margin:0 0 16px;position:relative;z-index:2}.projects-header h1:before{color:#ff7b72;content:"class ";font-size:2rem}.projects-header h1:after{color:#7d8590;content:" {"}.projects-header p{color:#8b949e;font-size:1.1rem;line-height:1.6;margin:0;max-width:600px;padding-left:20px;position:relative;z-index:2}.projects-header p:before{color:#6e7681;content:"// "}.project-category{background:#0d1117;border-top:1px solid #21262d;margin:0 auto;max-width:1400px;padding:60px 40px}.category-header{margin-bottom:40px}.category-header h2{color:#58a6ff;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:1.8rem;font-weight:600;margin:0 0 12px}.category-header h2:before{color:#ff7b72;content:"namespace ";font-size:1.4rem}.category-header h2:after{color:#7d8590;content:" {"}.category-header p{color:#7d8590;font-size:1rem;margin:0;padding-left:20px}.category-header p:before{color:#6e7681;content:"// "}.project-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(380px,1fr))}.project-item{background:#161b22;border:1px solid #30363d;border-radius:6px;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;padding:24px;transition:all .2s ease}.project-item:hover{background:#21262d;border-color:#58a6ff;box-shadow:0 8px 24px #01040926;transform:translateY(-2px)}.project-item.featured{background:#0d1521;border-color:#238636;position:relative}.project-item.featured:before{background:#238636;border-radius:3px;color:#f0f6fc;content:"main";font-size:.7rem;font-weight:500;padding:2px 6px;position:absolute;right:12px;top:8px}.project-item.featured:hover{border-color:#2ea043}.project-item h3{font-size:1.1rem;font-weight:600;margin:0 0 12px}.project-item h3 a{color:#58a6ff;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;text-decoration:none}.project-item h3 a:hover{color:#79c0ff;text-decoration:underline}.project-item p{color:#8b949e;font-size:.9rem;line-height:1.5;margin:0 0 16px}.project-meta{align-items:center;display:flex;gap:12px;margin:16px 0}.course-code{background:#21262d;border:1px solid #30363d;border-radius:3px;color:#58a6ff}.course-code,.grade{font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.75rem;font-weight:500;padding:2px 6px}.grade{background:#238636;border:1px solid #2ea043;border-radius:3px;color:#f0f6fc}.status{border:1px solid;border-radius:3px;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.75rem;font-weight:500;padding:2px 6px}.status.ongoing{background:#1e1e1e;border-color:#f79000;color:#f79000}.status.recent{background:#0d1117;border-color:#58a6ff;color:#58a6ff}.tech-stack{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px}.tech-stack span{background:#21262d;border:1px solid #30363d;border-radius:3px;color:#f79000;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.75rem;font-weight:400;padding:2px 6px}.tech-stack span:before{color:#7d8590;content:"#"}.project-actions{margin-top:16px}.demo-link{background:#238636;border:1px solid #2ea043;border-radius:3px;color:#f0f6fc;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.8rem;font-weight:500;padding:6px 12px;text-decoration:none;transition:all .2s ease}.demo-link:hover{background:#2ea043;border-color:#46954a;transform:translateY(-1px)}.contact{background:#0d1117;color:#c9d1d9;margin:0 auto;max-width:800px;min-height:100vh;padding:80px 40px}.contact,.contact h2{font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace}.contact h2{color:#58a6ff;font-size:2.5rem;font-weight:700;margin:0 0 40px}.contact h2:before{color:#ff7b72;content:"interface ";font-size:2rem}.contact h2:after{color:#7d8590;content:" {"}.contact-form{background:#161b22;border:1px solid #30363d;border-radius:6px;margin-bottom:40px;padding:32px;position:relative}.contact-form:after{bottom:8px;color:#7d8590;content:"}";font-size:1.5rem;position:absolute;right:16px}.form-group{margin-bottom:24px}.form-group label{color:#f0f6fc;display:block;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.9rem;font-weight:500;margin-bottom:8px}.form-group label:before{color:#ff7b72;content:"const ";font-size:.8rem}.form-group label:after{color:#7d8590;content:": string =";font-size:.8rem}.form-group input,.form-group textarea{background:#0d1117;border:1px solid #30363d;border-radius:6px;box-sizing:border-box;color:#f0f6fc;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.9rem;padding:12px 16px;transition:border-color .2s ease;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#58a6ff;box-shadow:0 0 0 2px #58a6ff33;outline:none}.form-group input::placeholder,.form-group textarea::placeholder{color:#7d8590;font-style:italic}.form-group input::placeholder:after,.form-group input::placeholder:before,.form-group textarea::placeholder:after,.form-group textarea::placeholder:before{color:#a5d6ff;content:'"'}.submit-button{background:#238636;border:1px solid #2ea043;border-radius:6px;color:#f0f6fc;cursor:pointer;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.9rem;font-weight:500;padding:12px 24px;transition:all .2s ease}.submit-button:hover{background:#2ea043;border-color:#46954a;box-shadow:0 4px 12px #2386364d;transform:translateY(-1px)}.submit-button:before{color:#ff7b72;content:"execute ";font-size:.8rem}.submit-button:after{color:#7d8590;content:"()";font-size:.8rem}.contact-info{background:#161b22;border:1px solid #30363d;border-radius:6px;padding:24px;position:relative}.contact-info:before{color:#ff7b72;content:"const contactInfo = {";display:block;font-size:.9rem;margin-bottom:16px}.contact-info:after{color:#7d8590;content:"};";display:block;font-size:.9rem;margin-top:16px}.contact-info p{color:#f0f6fc;font-size:.9rem;margin:12px 0;padding-left:20px}.contact-info p:before{color:#a5d6ff;content:'"'}.contact-info p:after{color:#a5d6ff;content:'",'}.contact-info a{color:#58a6ff;text-decoration:none;transition:color .2s ease}.contact-info a:hover{color:#79c0ff;text-decoration:underline}.navbar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#161b22;border-bottom:1px solid #30363d;padding:16px 0;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.navbar .logo a{color:#58a6ff;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:1.2rem;font-weight:600;text-decoration:none}.navbar .logo a:before{color:#7c3aed;content:"< "}.navbar .logo a:after{color:#7c3aed;content:" />"}.nav-links{display:flex;gap:8px;list-style:none;margin:0;padding:0}.nav-links li a{border:1px solid #0000;border-radius:6px;color:#c9d1d9;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.9rem;font-weight:500;padding:8px 16px;text-decoration:none;transition:all .2s ease}.nav-links li a:hover{background:#21262d;border-color:#30363d;color:#58a6ff}.nav-links li a.active{background:#238636;border-color:#2ea043;color:#f0f6fc}.footer{background:#161b22;border-top:1px solid #30363d;color:#7d8590;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.9rem;padding:40px 0;text-align:center}.footer p:before{color:#6e7681;content:"// "}.app-container{color:#c9d1d9;min-height:100vh}.app-container,.content{background:#0d1117}@media (max-width:768px){.navbar{padding:12px 20px}.nav-links{flex-direction:column;gap:4px}.nav-links li a{display:block;padding:12px 16px;text-align:center}.contact,.projects{padding:60px 20px}.project-category,.projects-header{padding:40px 20px}.project-grid{grid-template-columns:1fr}}.thesis-app{background:#fff!important;color:#333!important;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans,Helvetica,Arial,sans-serif!important;min-height:100vh!important}.thesis-navbar{background:#fff!important;border-bottom:1px solid #e2e8f0!important;box-shadow:0 1px 3px #0000001a!important;padding:16px 0!important;position:-webkit-sticky!important;position:sticky!important;top:0!important;z-index:1000!important}.thesis-nav-content{align-items:center!important;display:flex!important;justify-content:space-between!important;margin:0 auto!important;max-width:1200px!important;padding:0 40px!important}.thesis-logo a{color:#667eea!important;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans,Helvetica,Arial,sans-serif!important;font-size:1.2rem!important;font-weight:600!important;text-decoration:none!important}.thesis-nav-links{display:flex!important;gap:24px!important;list-style:none!important;margin:0!important;padding:0!important}.thesis-nav-links li a{border-radius:6px!important;color:#333!important;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans,Helvetica,Arial,sans-serif!important;font-size:.9rem!important;font-weight:500!important;padding:8px 16px!important;text-decoration:none!important;transition:all .2s ease!important}.thesis-nav-links li a:hover{background:#f8fafc!important;color:#667eea!important}.thesis-content{background:#fff!important;min-height:calc(100vh - 120px)!important}.thesis-footer{background:#f8fafc!important;border-top:1px solid #e2e8f0!important;color:#64748b!important;font-size:.9rem!important;padding:24px 0!important;text-align:center!important}.thesis-app *,.thesis-footer,.thesis-page{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans,Helvetica,Arial,sans-serif!important}.thesis-app *,.thesis-page{background:#fff!important;color:#333!important}.thesis-page *,.thesis-page h1,.thesis-page h2,.thesis-page h3,.thesis-page h4,.thesis-page h5,.thesis-page h6{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans,Helvetica,Arial,sans-serif!important}.thesis-page h1,.thesis-page h2,.thesis-page h3,.thesis-page h4,.thesis-page h5,.thesis-page h6{color:#333!important}.thesis-page h1:after,.thesis-page h1:before,.thesis-page h2:after,.thesis-page h2:before,.thesis-page h3:after,.thesis-page h3:before,.thesis-page h4:after,.thesis-page h4:before,.thesis-page h5:after,.thesis-page h5:before,.thesis-page h6:after,.thesis-page h6:before{content:none!important}.thesis-page p{color:#666!important}.thesis-page .stat-item{background:#fff!important;border:1px solid #e2e8f0!important;box-shadow:0 2px 4px #0000001a!important;color:#333!important}.thesis-page .stat-number{color:#667eea!important}.thesis-page .stat-number:after,.thesis-page .stat-number:before{content:none!important}.thesis-page .stat-label{color:#64748b!important}.thesis-page a{color:#667eea!important}.thesis-page button{background:#667eea!important;border:none!important;color:#fff!important;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans,Helvetica,Arial,sans-serif!important}.thesis-page .form-group label:after,.thesis-page .form-group label:before,.thesis-page button:after,.thesis-page button:before{content:none!important}.thesis-page input,.thesis-page select,.thesis-page textarea{background:#fff!important;border:1px solid #d1d5db!important;color:#333!important;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans,Helvetica,Arial,sans-serif!important}
/*# sourceMappingURL=main.982cdb53.css.map*/