.header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background-color:var(--background);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:1rem;text-decoration:none}.logo{height:65px;width:auto}.site-title{font-size:1.5rem;font-weight:var(--font-weight-medium);color:var(--foreground);margin:0;line-height:1.5}.header-right{display:flex;align-items:center;gap:1rem}.user-info{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.username{font-weight:var(--font-weight-medium);font-size:1rem;color:var(--foreground);line-height:1.5}.karma-display{display:flex;gap:.5rem;align-items:center;font-size:.875rem}.karma-points{background-color:var(--secondary);color:var(--secondary-foreground);padding:.25rem .75rem;border-radius:var(--radius);font-weight:var(--font-weight-medium)}.user-level{background-color:var(--accent);color:var(--accent-foreground);padding:.25rem .75rem;border-radius:var(--radius);font-weight:var(--font-weight-medium);font-size:.8rem}.login-button{background-color:var(--primary);color:var(--primary-foreground);border:none;padding:.5rem 1.5rem;border-radius:var(--radius);font-size:1rem;font-weight:var(--font-weight-medium);cursor:pointer;transition:all .2s ease;line-height:1.5}.login-button:hover{opacity:.9;transform:translateY(-1px)}.logout-button{background-color:var(--destructive);color:var(--destructive-foreground);border:none;padding:.5rem 1.5rem;border-radius:var(--radius);font-size:1rem;font-weight:var(--font-weight-medium);cursor:pointer;transition:all .2s ease;line-height:1.5}.logout-button:hover{opacity:.9;transform:translateY(-1px)}@media(max-width:768px){.header{padding:.75rem 1rem;flex-wrap:wrap}.header-left{flex:1;min-width:0}.logo{height:45px}.header-left h1{font-size:1.1rem}.site-title{font-size:1.25rem}.header-right{gap:.5rem;flex-wrap:wrap;justify-content:flex-end}.user-info{align-items:flex-end;gap:.2rem}.username{font-size:.9rem}.karma-display{flex-direction:column;gap:.25rem;align-items:flex-end}.karma-points,.user-level{font-size:.75rem;padding:.2rem .5rem}.login-button,.logout-button{padding:.4rem 1rem;font-size:.9rem}}@media(max-width:480px){.header{padding:.5rem .75rem}.logo{height:35px}.header-left h1{font-size:.95rem}.header-right{width:100%;margin-top:.5rem;justify-content:space-between}.user-info{flex:1}.username{font-size:.85rem}.karma-points,.user-level{font-size:.7rem;padding:.15rem .4rem}.login-button,.logout-button{padding:.35rem .75rem;font-size:.85rem}}:root{--font-size: 16px;--background: #ffffff;--foreground: oklch(.145 0 0);--card: #ffffff;--card-foreground: oklch(.145 0 0);--primary: #030213;--primary-foreground: oklch(1 0 0);--secondary: oklch(.95 .0058 264.53);--secondary-foreground: #030213;--muted: #ececf0;--muted-foreground: #717182;--accent: #e9ebef;--accent-foreground: #030213;--border: rgba(0, 0, 0, .1);--input-background: #f3f3f5;--font-weight-medium: 500;--font-weight-normal: 400;--radius: .625rem;--popover: oklch(1 0 0);--popover-foreground: oklch(.145 0 0);--destructive: #d4183d;--destructive-foreground: #ffffff;--input: transparent;--switch-background: #cbced4;--ring: oklch(.708 0 0);--chart-1: oklch(.646 .222 41.116);--chart-2: oklch(.6 .118 184.704);--chart-3: oklch(.398 .07 227.392);--chart-4: oklch(.828 .189 84.429);--chart-5: oklch(.769 .188 70.08);--sidebar: oklch(.985 0 0);--sidebar-foreground: oklch(.145 0 0);--sidebar-primary: #030213;--sidebar-primary-foreground: oklch(.985 0 0);--sidebar-accent: oklch(.97 0 0);--sidebar-accent-foreground: oklch(.205 0 0);--sidebar-border: oklch(.922 0 0);--sidebar-ring: oklch(.708 0 0);--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem}*{border-color:var(--border);box-sizing:border-box}body{background:var(--background);color:var(--foreground);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0;padding:0;font-size:var(--font-size);line-height:1.5;font-weight:var(--font-weight-normal)}.app-shell{min-height:100vh;background:var(--background)}.page-content{flex:1;background:var(--background)}h1{font-size:var(--text-2xl);font-weight:var(--font-weight-medium);line-height:1.5;color:var(--foreground)}h2{font-size:var(--text-xl);font-weight:var(--font-weight-medium);line-height:1.5;color:var(--foreground)}h3{font-size:var(--text-lg);font-weight:var(--font-weight-medium);line-height:1.5;color:var(--foreground)}h4{font-size:var(--text-base);font-weight:var(--font-weight-medium);line-height:1.5;color:var(--foreground)}p{font-size:var(--text-base);font-weight:var(--font-weight-normal);line-height:1.5;color:var(--foreground)}label{font-size:var(--text-base);font-weight:var(--font-weight-medium);line-height:1.5;color:var(--foreground)}button{font-size:var(--text-base);font-weight:var(--font-weight-medium);line-height:1.5}input,select,textarea{font-size:var(--text-base);font-weight:var(--font-weight-normal);line-height:1.5}.auth-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.auth-modal{background:#fff;padding:2rem;border-radius:8px;max-width:400px;width:90%;position:relative}.auth-modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666}.auth-modal-close:hover{color:#000}.auth-modal h2{margin-top:0;margin-bottom:1.5rem}.auth-form-group{margin-bottom:1rem}.auth-form-group label{display:block;margin-bottom:.5rem;font-weight:500}.auth-form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;box-sizing:border-box}.auth-form-group input:focus{outline:none;border-color:#4a90e2}.auth-error{background:#fee;color:#c33;padding:.75rem;border-radius:4px;margin-bottom:1rem}.auth-submit-button{width:100%;padding:.75rem;background:#4a90e2;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;margin-top:1rem}.auth-submit-button:hover:not(:disabled){background:#357abd}.auth-submit-button:disabled{opacity:.6;cursor:not-allowed}.auth-switch{text-align:center;margin-top:1rem;color:#666}.auth-link-button{background:none;border:none;color:#4a90e2;cursor:pointer;text-decoration:underline}.auth-link-button:hover{color:#357abd}@media(max-width:768px){.auth-modal{padding:1.5rem;max-width:95%}.auth-modal h2{font-size:1.25rem;margin-bottom:1rem}.auth-form-group input,.auth-submit-button{padding:.65rem;font-size:.95rem}}@media(max-width:480px){.auth-modal{padding:1.25rem}.auth-modal h2{font-size:1.1rem}.auth-form-group input{padding:.6rem;font-size:.9rem}}.search-container{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:2rem;margin-bottom:2rem}.search-input{width:400px;padding:.75rem 1.5rem;border:1px solid var(--border);border-radius:var(--radius);outline:none;font-size:var(--text-base);font-weight:var(--font-weight-normal);background-color:var(--input-background);color:var(--foreground);transition:all .2s ease;line-height:1.5}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--ring);background-color:var(--background)}.search-input::placeholder{color:var(--muted-foreground)}.search-button{padding:.75rem 1.5rem;background-color:var(--primary);color:var(--primary-foreground);border:none;border-radius:var(--radius);cursor:pointer;font-size:var(--text-base);font-weight:var(--font-weight-medium);transition:all .2s ease;line-height:1.5}.search-button:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.search-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.search-error{color:var(--destructive);margin-top:.5rem;text-align:center;font-size:var(--text-sm);font-weight:var(--font-weight-normal)}@media(max-width:768px){.search-container{flex-direction:column;gap:.75rem;margin-top:1.5rem;margin-bottom:1.5rem;padding:0 1rem}.search-input{width:100%;max-width:100%;padding:.65rem 1.25rem;font-size:.95rem}.search-button{width:100%;max-width:100%;padding:.65rem 1.25rem}}@media(max-width:480px){.search-container{margin-top:1rem;margin-bottom:1rem;padding:0 .75rem}.search-input,.search-button{padding:.6rem 1rem;font-size:.9rem}}.content-wrapper{max-width:1200px;margin:0 auto;padding:2rem;background:var(--background);color:var(--foreground)}.content-wrapper h2{color:var(--foreground);margin-bottom:.75rem;font-size:1.5rem;font-weight:var(--font-weight-medium);line-height:1.5}.content-wrapper>p{color:var(--muted-foreground);margin-bottom:2rem;font-size:1rem;font-weight:var(--font-weight-normal);line-height:1.5}.course-list{display:grid;gap:1.5rem}.course-item{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #0000001a}.course-item:hover{box-shadow:0 4px 6px #0000001a;border-color:var(--primary);transform:translateY(-2px);background:var(--accent)}.course-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.course-code{color:var(--foreground);font-size:1.25rem;margin:0;font-weight:var(--font-weight-medium);line-height:1.5}.credits-badge{background:var(--secondary);color:var(--secondary-foreground);padding:.25rem .75rem;border-radius:1rem;font-size:.875rem;font-weight:var(--font-weight-medium)}.course-name{color:var(--foreground);font-size:1.125rem;margin:0 0 .75rem;font-weight:var(--font-weight-medium);line-height:1.5}.course-description{color:var(--muted-foreground);margin:0 0 .75rem;line-height:1.5;font-weight:var(--font-weight-normal)}.course-department{color:var(--muted-foreground);margin:0;font-size:.875rem;font-weight:var(--font-weight-normal)}.course-department strong{color:var(--foreground);font-weight:var(--font-weight-medium)}@media(max-width:768px){.content-wrapper{padding:1rem}.content-wrapper h2{font-size:1.25rem}.course-list{gap:1rem}.course-item{padding:1rem}.course-header{flex-direction:column;gap:.5rem;align-items:flex-start}.course-code{font-size:1.125rem}.course-name{font-size:1rem}.course-description{font-size:.9rem}.course-department{font-size:.8rem}.credits-badge{font-size:.8rem;padding:.2rem .6rem}}@media(max-width:480px){.content-wrapper{padding:.75rem}.content-wrapper h2{font-size:1.1rem}.course-item{padding:.75rem}.course-code{font-size:1rem}.course-name{font-size:.95rem}}.footer{display:flex;justify-content:space-between;align-items:flex-start;background-color:var(--background);color:var(--foreground);border-top:1px solid var(--border);padding:2rem 3rem;margin-top:3rem;flex-wrap:wrap;text-align:left}.footer-title{font-size:var(--text-xl);font-weight:var(--font-weight-medium);color:var(--primary);line-height:1.5}.footer-center{display:flex;gap:3rem;justify-content:center;align-items:flex-start;flex:1}.footer-section{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem}.footer-section h4{margin-bottom:.5rem;font-size:var(--text-base);font-weight:var(--font-weight-medium);color:var(--foreground);line-height:1.5}.footer-section a{text-decoration:none;color:var(--primary);font-weight:var(--font-weight-normal);font-size:var(--text-base);transition:color .2s ease;line-height:1.5}.footer-section a:hover{color:var(--secondary-foreground)}.footer-bottom{font-size:var(--text-sm);color:var(--muted-foreground);text-align:right;font-weight:var(--font-weight-normal);line-height:1.5}@media(max-width:768px){.footer{flex-direction:column;align-items:center;text-align:center;gap:1.5rem;padding:1.5rem 1rem}.footer-title{text-align:center}.footer-center{flex-direction:column;gap:1.5rem;width:100%;align-items:center}.footer-section{align-items:center;text-align:center;width:100%}.footer-bottom{text-align:center;width:100%;margin-top:.5rem}}@media(max-width:480px){.footer{padding:1.25rem .75rem;gap:1.25rem}.footer-title{font-size:1rem}.footer-section h4,.footer-section a{font-size:.9rem}.footer-bottom{font-size:.8rem}}.course-detail{background:#fff;color:#111;min-height:100vh;padding:40px 60px;box-sizing:border-box;font-family:Inter,system-ui,sans-serif}@media(max-width:768px){.course-detail{padding:20px 16px}.course-title{font-size:1.5rem;margin-bottom:8px}.course-description{font-size:.95rem}.course-department{font-size:.85rem}.back-button{font-size:.9rem;margin-bottom:15px}.tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{padding:10px 16px;font-size:.9rem;white-space:nowrap}.materials-grid{grid-template-columns:1fr;gap:16px}.material-tile{padding:12px}.material-tile-title{font-size:1rem}.material-tile-description{font-size:.9rem;line-clamp:2;-webkit-line-clamp:2;min-height:2.6em}.material-tile-footer{flex-direction:column;align-items:flex-start;gap:8px}.material-tile-votes{width:100%;justify-content:center}.material-tile-file-link{width:100%;justify-content:center;padding:6px 12px}.add-material-button{width:100%;padding:12px;font-size:.95rem}.chat-content{margin-top:20px}.chat-materials-selection{padding:15px}.chat-materials-selection h3{font-size:1rem}.material-checkboxes{flex-direction:column}.material-checkbox{width:100%}.chat-interface{height:50vh;margin-top:20px}.chat-messages{padding:15px;height:60vh}.chat-message-content{max-width:85%;font-size:.9rem;padding:8px 12px}.chat-input-container{padding:10px;flex-direction:column}.chat-input{width:100%;padding:12px;font-size:1rem}.chat-send-button{width:100%;padding:12px 20px;font-size:1rem;min-height:44px}}@media(max-width:480px){.course-detail{padding:16px 12px}.course-title{font-size:1.25rem}.vote-button{font-size:1.2rem;padding:6px 10px;min-width:36px}.vote-score{font-size:1rem}}.back-button{background:none;border:none;color:#36f;font-size:1rem;font-weight:500;cursor:pointer;margin-bottom:20px;transition:color .3s ease}.back-button:hover{color:#1f45e6}.course-header{border-bottom:1px solid #e5e5e5;padding-bottom:20px;margin-bottom:25px}.course-title{font-size:2rem;font-weight:700;margin-bottom:10px}.course-description{color:#444;font-size:1.05rem;line-height:1.5}.course-department{color:#666;font-size:.95rem;margin-top:5px}.tabs-section{margin-top:20px}.tabs{display:flex;border-bottom:1px solid #ddd}.tab{background:none;border:none;font-size:1rem;font-weight:500;padding:12px 20px;cursor:pointer;color:#555;transition:all .2s ease}.tab:hover{color:#000;background:#f5f5f5}.tab.active{border-bottom:3px solid #3366ff;color:#000;font-weight:600}.resources-content{margin-top:25px}.add-material-section{display:flex;justify-content:flex-end;margin-bottom:15px}.add-material-button{background:#36f;color:#fff;font-weight:600;border:none;border-radius:6px;padding:10px 18px;cursor:pointer;transition:background .2s ease}.add-material-button:hover{background:#254eda}.loading-text{color:#777;text-align:center}.error-message{color:#d93025;background:#fff1f1;border:1px solid #f2bcbc;padding:10px;border-radius:6px;margin:10px 0;text-align:center}.materials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:20px;margin-top:15px}.material-tile{background:#fafafa;border:1px solid #eaeaea;border-radius:10px;padding:15px;cursor:pointer;transition:all .25s ease}.material-tile:hover{transform:translateY(-4px);box-shadow:0 6px 14px #00000014;background:#fff}.material-tile-header{display:flex;justify-content:space-between;align-items:center}.material-tile-title{font-weight:600;font-size:1.05rem;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.material-tile-header-right{display:flex;align-items:center;gap:6px}.material-tile-type{background:#eef2ff;color:#3346ff;font-size:.85rem;padding:2px 8px;border-radius:6px}.delete-material-button{background:none;border:none;color:#d93025;font-size:1rem;cursor:pointer;transition:transform .2s ease}.delete-material-button:hover{transform:scale(1.1)}.material-tile-description{font-size:.95rem;color:#444;margin:10px 0;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;line-height:1.4;min-height:3.9em}.material-tile-footer{display:flex;justify-content:space-between;align-items:center;margin-top:10px;gap:10px}.material-tile-votes{display:flex;align-items:center;gap:8px}.material-tile-file-link{font-size:.9rem;color:#36f;text-decoration:none;display:flex;align-items:center;gap:4px;padding:4px 8px;border-radius:4px;transition:all .2s ease;white-space:nowrap}.material-tile-file-link:hover{background:#f0f4ff;color:#254eda}.material-tile-file{font-size:.85rem;color:#111;margin-top:8px;display:flex;align-items:center;gap:4px}.vote-button{border:none;background:#f0f0f0;cursor:pointer;font-size:1.4rem;line-height:1;padding:8px 12px;border-radius:6px;transition:all .2s ease;min-width:40px;display:flex;align-items:center;justify-content:center}.vote-button.upvote:hover{background:#e8f5e9;color:#28a745;transform:translateY(-2px)}.vote-button.downvote:hover{background:#ffebee;color:#d93025;transform:translateY(2px)}.vote-button:active{transform:scale(.95)}.vote-score{font-weight:600;color:#333;font-size:1.1rem;min-width:30px;text-align:center}.no-materials{text-align:center;color:#666;font-style:italic;margin-top:20px}.chat-content{margin-top:30px}.chat-materials-selection{background:#f8f8f8;border:1px solid #e0e0e0;padding:20px;border-radius:10px}.chat-materials-selection h3{margin-bottom:10px}.material-checkboxes{display:flex;flex-wrap:wrap;gap:10px}.material-checkbox{display:flex;align-items:center;gap:5px;background:#fff;border:1px solid #e0e0e0;padding:6px 10px;border-radius:6px;cursor:pointer;transition:background .2s ease}.material-checkbox:hover{background:#f0f0f0}.has-file{margin-left:4px}.chat-interface{display:flex;flex-direction:column;margin-top:25px;border:1px solid #e0e0e0;border-radius:10px;overflow:hidden;height:40vh}.chat-messages{flex:1;padding:20px;overflow-y:auto;background:#fff}.chat-placeholder{text-align:center;color:#888;margin-top:10vh;font-size:.95rem}.chat-message{margin-bottom:15px;display:flex}.chat-message.user{justify-content:flex-end}.chat-message.assistant{justify-content:flex-start}.chat-message-content{background:#f2f2f2;color:#000;padding:10px 14px;border-radius:10px;max-width:65%;line-height:1.4}.chat-message.user .chat-message-content{background:#36f;color:#fff}.chat-message-content p{margin:0}.chat-message.user .chat-message-content p{color:#fff}.chat-input-container{display:flex;border-top:1px solid #e0e0e0;background:#f8f8f8;padding:12px;gap:8px}.chat-input{flex:1;padding:10px 14px;font-size:1rem;border-radius:8px;border:1px solid #ccc;outline:none}.chat-input:disabled{background:#f2f2f2}.chat-send-button{background:#36f;color:#fff;border:none;border-radius:8px;padding:0 20px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s ease}.chat-send-button:hover{background:#254eda}.chat-send-button:disabled{opacity:.6;cursor:not-allowed}.graph-image{position:absolute;width:100vw;z-index:0;color:gray}.material-form-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.material-form{background:#fff;padding:2rem;border-radius:8px;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;position:relative}.material-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.material-form-header h2{margin:0}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.close-button:hover{color:#000;background:#f0f0f0;border-radius:4px}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input[type=text],.form-group textarea,.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;box-sizing:border-box;font-family:inherit}.form-group input[type=text]:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#36f;box-shadow:0 0 0 3px #4a90e21a}.form-group textarea{resize:vertical}.form-group input[type=file]{padding:.5rem}.file-info{margin-top:.5rem;color:#666;font-size:.9rem}.form-error{background:#fee;color:#c33;padding:.75rem;border-radius:4px;margin-bottom:1rem}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.cancel-button,.submit-button{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;cursor:pointer;font-weight:500}.cancel-button{background:#f0f0f0;color:#333}.cancel-button:hover{background:#e0e0e0}.submit-button{background:#357abd;color:#fff}.submit-button:hover:not(:disabled){background:#36f}.submit-button:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.material-form{padding:1.5rem;max-width:95%}.material-form-header h2{font-size:1.25rem}.form-group input[type=text],.form-group textarea,.form-group select{padding:.65rem;font-size:.95rem}.form-actions{flex-direction:column-reverse;gap:.75rem}.cancel-button,.submit-button{width:100%;padding:.75rem}}@media(max-width:480px){.material-form{padding:1.25rem}.material-form-header h2{font-size:1.1rem}.form-group input[type=text],.form-group textarea,.form-group select{padding:.6rem;font-size:.9rem}}.material-detail-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1500}.material-detail-modal{background:#fff;border-radius:8px;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 4px 20px #00000026}.material-detail-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.material-detail-header h2{margin:0;color:#1f2937;font-size:1.5rem}.material-detail-header .close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:4px}.material-detail-header .close-button:hover{color:#000;background:#f0f0f0}.material-detail-content{padding:1.5rem}.material-detail-section{margin-bottom:1.5rem}.material-detail-section h3{margin:0 0 .5rem;color:#374151;font-size:1rem;font-weight:600}.material-detail-section p{margin:0;color:#6b7280;line-height:1.6}.material-badge{display:inline-block;background:#dbeafe;color:#1e40af;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:500}.file-link{display:inline-block;color:#2563eb;text-decoration:none;font-weight:500;padding:.5rem 0}.file-link:hover{text-decoration:underline}.material-detail-meta{display:flex;gap:2rem;padding-top:1rem;border-top:1px solid #e5e7eb;margin-top:1.5rem}.meta-item{display:flex;flex-direction:column;gap:.25rem}.meta-label{font-size:.875rem;color:#6b7280}.meta-value{font-size:1.25rem;font-weight:600;color:#1f2937}.material-detail-footer{padding:1rem 1.5rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end}.close-modal-button{padding:.5rem 1.5rem;background:#4a90e2;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;font-weight:500}.close-modal-button:hover{background:#357abd}@media(max-width:768px){.material-detail-modal{max-width:95%;margin:1rem}.material-detail-header{padding:1rem}.material-detail-header h2{font-size:1.25rem}.material-detail-content{padding:1rem}.material-detail-section{margin-bottom:1rem}.material-detail-meta{flex-direction:column;gap:1rem}.material-detail-footer{padding:.75rem 1rem}.close-modal-button{width:100%;padding:.65rem}}@media(max-width:480px){.material-detail-modal{max-width:98%;margin:.5rem}.material-detail-header h2{font-size:1.1rem}}.karma-alert{position:fixed;top:100px;right:20px;background:#36f;color:#fff;padding:1rem 1.5rem;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:2000;animation:slideIn .3s ease-out,fadeOut .3s ease-out 2.7s;min-width:250px}.karma-alert-content{display:flex;align-items:center;gap:1rem}.karma-alert-icon{font-size:2rem;animation:pulse 1s ease-in-out infinite}.karma-alert-text{flex:1}.karma-alert-title{font-weight:600;font-size:1.1rem;margin-bottom:.25rem}.karma-alert-level{font-size:.9rem;opacity:.9}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.landing-container{display:flex;justify-content:space-between;align-items:center;height:100vh;width:100%;overflow:hidden;font-family:Inter,sans-serif}.landing-container{background:linear-gradient(277deg,#136ac7,#45be9f);background-size:400% 400%;-webkit-animation:bg 5s ease infinite;-moz-animation:bg 5s ease infinite;-o-animation:bg 5s ease infinite;animation:bg 5s ease infinite}@-webkit-keyframes bg{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@-moz-keyframes bg{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@-o-keyframes bg{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes bg{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.landing-left{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding-left:8vw;color:#fff;z-index:2}.landing-left h1{font-size:3.5rem;font-weight:700;margin-bottom:15px;background:#fff;color:#fff;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.landing-left p{font-size:1.25rem;max-width:500px;line-height:1.6;color:#fff;margin-bottom:30px}.signup-button{padding:14px 36px;font-size:1.2rem;font-weight:600;background:#36f;border:none;border-radius:50px;color:#fff;cursor:pointer;box-shadow:0 8px 20px #3250ff4d;transition:all .3s ease}.signup-button:hover{transform:translateY(-3px);box-shadow:0 12px 24px #3250ff66}.landing-right{flex:1;height:100%;background:url(https://images.unsplash.com/photo-1522204507491-51b8b22f66d1?auto=format&fit=crop&w=1200&q=80) center/cover no-repeat;filter:brightness(.9);clip-path:polygon(15% 0%,100% 0,100% 100%,0 100%)}@media(max-width:900px){.landing-container{flex-direction:column}.landing-right{display:none}.landing-left{align-items:center;text-align:center;padding-left:0}.landing-left h1{font-size:2.5rem}}/*!* Simplified Design System - Only essential variables *!*//*!* Base styles *!*//*!* Typography *!*/
