:root{--page-bg: #faf9f5;--section-bg: #e8e6dc;--text-primary: #141413;--text-secondary: #6b6b6b;--text-muted: #b0aea5;--accent: #da7756;--accent-hover: #c96b48;--accent-blue: #6a9bcc;--accent-green: #788c5d;--border: #e0ddd8;--border-subtle: rgba(0, 0, 0, .08);--white: #ffffff;--card-bg: #ffffff;--max-width: 1920px;--section-padding-v: 32px;--section-padding-h: 24px;--radius: 12px;--radius-btn: 8px;--radius-input: 8px}@media (max-width: 768px){:root{--section-padding-v: 56px;--section-padding-h: 24px}}*,*:before,*:after{box-sizing:border-box}html{width:100%;height:100%;min-height:100%;-webkit-text-size-adjust:100%}body{width:100%;min-height:100%;height:100%;margin:0;font-family:Lora,Georgia,serif;font-size:1rem;line-height:1.6;color:var(--text-primary);background:var(--page-bg);-webkit-font-smoothing:antialiased}#root{width:100%;min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4{font-family:Inter,Lora,sans-serif;font-weight:500;letter-spacing:-.02em;line-height:1.15;margin:0 0 .5em}h1{font-size:clamp(1.75rem,4vw,3rem);font-weight:600}h2{font-size:clamp(1.5rem,3vw,2.25rem)}h3{font-size:1.25rem}p{max-width:65ch}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}a.text{color:var(--text-primary)}a.text:hover{color:var(--accent)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;border-radius:var(--radius-btn);font-family:Inter,sans-serif;font-weight:500;font-size:1rem;border:none;cursor:pointer;transition:background-color .15s ease}.btn--primary{background:var(--accent);color:var(--white)}.btn--primary:hover{background:var(--accent-hover)}.btn--secondary{background:transparent;color:var(--text-primary);border:1px solid var(--text-primary)}.btn--secondary:hover{background:var(--section-bg)}.btn--secondary-muted{border-color:var(--text-muted);color:var(--text-primary)}.btn--secondary-muted:hover{background:var(--section-bg)}.input{width:100%;border:1px solid var(--border);border-radius:var(--radius-input);padding:12px 16px;font-family:inherit;font-size:1rem;color:var(--text-primary);background:var(--white)}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #da775633}.card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:24px 32px;box-shadow:0 1px 3px #0000000f}.layout{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--section-padding-h)}.layout--fyp{padding-top:24px}.section{width:100%;padding:var(--section-padding-v) var(--section-padding-h)}.section--alt{background:var(--section-bg)}.section--centered{display:flex;flex-direction:column;align-items:center}main{flex:1 1 auto;width:100%;min-width:0;min-height:0}.nav{position:sticky;top:0;z-index:100;width:100%;background:var(--page-bg);border-bottom:1px solid var(--border)}.nav__inner{width:100%;max-width:var(--max-width);margin:0 auto;padding:12px var(--section-padding-h);display:flex;align-items:center;justify-content:space-between;gap:24px}.nav__logo{font-family:Inter,sans-serif;font-weight:600;font-size:1.25rem;color:var(--text-primary);text-decoration:none}.nav__logo:hover{text-decoration:none;color:var(--text-primary)}.nav__links{display:flex;align-items:center;gap:24px}.nav__link{font-family:Inter,sans-serif;font-size:.9375rem;color:var(--text-secondary);text-decoration:none}.nav__link:hover{color:var(--accent);text-decoration:none}.fyp__header{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:32px}.fyp__title{font-size:clamp(1.75rem,3vw,2.5rem);margin-bottom:8px}.fyp__subtitle{font-size:.95rem;color:var(--text-secondary);max-width:40rem}.fyp__actions{display:flex;gap:12px;flex-wrap:wrap}.footer{width:100%;background:var(--section-bg);color:var(--text-secondary);font-size:.875rem;padding:32px var(--section-padding-h) 24px;margin-top:48px}.footer__inner{width:100%;max-width:var(--max-width);margin:0 auto;display:flex;flex-wrap:wrap;justify-content:space-between;gap:24px}.footer__links{display:flex;gap:24px}.footer__link{color:var(--text-secondary)}.footer__link:hover{color:var(--accent)}.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}@media (min-width: 1400px){.video-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}}.video-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;text-decoration:none;color:inherit;display:block;transition:box-shadow .15s ease}.video-card:hover{box-shadow:0 2px 8px #00000014;text-decoration:none;color:inherit}.video-card__thumb-wrap{position:relative;aspect-ratio:16/9;background:var(--section-bg)}.video-card__thumb{width:100%;height:100%;object-fit:cover;display:block}.video-card__body{padding:16px}.video-card__title{font-family:Inter,sans-serif;font-weight:500;font-size:1rem;margin:0 0 4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.video-card__meta{font-size:.875rem;color:var(--text-secondary)}.watch__player-wrap{max-width:var(--max-width);margin:0 auto;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}.watch__player{aspect-ratio:16/9;background:#141413;width:100%;max-height:80vh;display:block}.watch__info{padding:24px 0;border-bottom:1px solid var(--border)}.watch__title{font-size:1.5rem;margin-bottom:8px}.watch__meta{font-size:.875rem;color:var(--text-secondary);margin-bottom:16px}.watch__actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.watch__description{padding:24px 0;color:var(--text-secondary);font-size:.9375rem;white-space:pre-wrap}.comments__list{margin-top:24px}.comment{padding:16px 0;border-bottom:1px solid var(--border)}.comment__header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.comment__author{font-weight:500;font-size:.9375rem}.comment__date{font-size:.875rem;color:var(--text-secondary)}.comment__body{font-size:.9375rem}.comment__replies{margin-left:32px;margin-top:12px}.form__group{margin-bottom:20px}.form__label{display:block;font-size:.875rem;margin-bottom:6px;color:var(--text-secondary)}.form__actions{margin-top:24px}.upload-form{width:100%;max-width:560px}.text-secondary{color:var(--text-secondary)}.text-small{font-size:.875rem}
