:root{color-scheme:dark;--bg: #070b14;--bg-soft: rgba(11, 17, 30, .82);--surface: rgba(15, 23, 42, .84);--surface-strong: rgba(15, 23, 42, .96);--border: rgba(148, 163, 184, .16);--border-strong: rgba(96, 165, 250, .3);--text: #e5eefc;--muted: #a9b7cf;--accent: #60a5fa;--accent-strong: #3b82f6;--accent-warm: #f59e0b;--accent-pink: #ec4899;--shadow: 0 24px 70px rgba(0, 0, 0, .32);--radius-xl: 28px;--radius-lg: 22px;--radius-md: 16px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;background:radial-gradient(circle at top left,rgba(59,130,246,.16),transparent 34%),radial-gradient(circle at top right,rgba(236,72,153,.12),transparent 28%),linear-gradient(180deg,#04070d,#08111f 54%,#060b12);color:var(--text);font-family:Manrope,sans-serif;overflow-x:hidden}button,input{font:inherit}button{cursor:pointer}img{display:block;max-width:100%}a{color:inherit;text-decoration:none}#root{min-height:100vh}.app-shell{position:relative;min-height:100vh}.background-canvas{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:-1}.site-header{position:sticky;top:0;z-index:20;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#060a14c7;border-bottom:1px solid var(--border)}.site-header__inner,.page-shell,.site-footer__grid,.site-footer__bar{width:min(1180px,calc(100% - 2rem));margin:0 auto}.site-header__inner{min-height:4.75rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.brand-mark{border:0;background:transparent;color:var(--text);font-family:Space Grotesk,sans-serif;font-size:1.25rem;font-weight:700;letter-spacing:.02em}.desktop-nav{display:flex;align-items:center;gap:1.5rem}.header-actions{display:flex;align-items:center}.auth-session{display:flex;align-items:center;gap:.75rem}.auth-shell{position:relative}.auth-chip,.auth-button,.chip-button{border-radius:999px;border:1px solid var(--border);background:#0f172ab3;color:var(--text);padding:.62rem .95rem;font-weight:700}.auth-chip--admin{border-color:#34d39959;color:#bbf7d0}.auth-button--ghost{background:transparent}.auth-panel{position:absolute;top:calc(100% + .75rem);right:0;width:min(360px,90vw);display:grid;gap:.9rem;padding:1rem;border-radius:20px;border:1px solid var(--border);background:#060a14f5;box-shadow:var(--shadow);z-index:30}.auth-panel__tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem}.auth-panel__tabs button,.auth-panel__actions button{border-radius:12px;border:1px solid var(--border);background:#0f172a99;color:var(--text);padding:.75rem .9rem}.auth-panel__tabs .is-active{border-color:#60a5fa59;background:#2563eb38}.auth-form{display:grid;gap:.8rem}.auth-form label{display:grid;gap:.45rem;color:var(--muted);font-size:.88rem}.auth-form input{width:100%;border-radius:12px;border:1px solid var(--border);background:#020617bf;color:var(--text);padding:.85rem .95rem}.auth-panel__actions{display:grid;gap:.55rem}.auth-status{margin:0;font-size:.85rem;color:#cbd5e1}.nav-link,.mobile-nav__link,.footer-links button{border:0;background:transparent;color:var(--muted);transition:color .18s ease,transform .18s ease}.nav-link{position:relative;padding:.6rem 0;font-weight:600}.nav-link:after{content:"";position:absolute;left:0;right:0;bottom:.35rem;height:2px;border-radius:999px;background:linear-gradient(90deg,var(--accent),#c4b5fd);transform:scaleX(0);transform-origin:left;transition:transform .2s ease}.nav-link:hover,.mobile-nav__link:hover,.footer-links button:hover,.nav-link.is-active,.mobile-nav__link.is-active{color:var(--text)}.nav-link.is-active:after{transform:scaleX(1)}.menu-toggle{display:none;width:2.75rem;height:2.75rem;padding:0;align-items:center;justify-content:center;gap:.22rem;flex-direction:column;border-radius:999px;border:1px solid var(--border);background:#0f172a99}.menu-toggle span{display:block;width:1rem;height:2px;border-radius:999px;background:var(--text)}.mobile-nav{display:none;width:min(1180px,calc(100% - 2rem));margin:0 auto;padding:0 0 1rem;gap:.8rem;flex-direction:column}.mobile-nav.is-open{display:flex}.mobile-nav .auth-session{flex-wrap:wrap;justify-content:space-between}.mobile-nav__link{text-align:left;padding:.85rem 1rem;border-radius:14px;background:#0f172ab3;border:1px solid var(--border)}.page-shell{padding:2rem 0 5rem}.page-stack,.section-stack{display:grid;gap:2rem}.page-stack{gap:3rem}.hero-grid,.about-hero,.spotlight-card,.newsletter-card,.timeline-card,.skill-card,.project-card,.article-card,.cert-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow)}.hero-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(280px,.9fr);gap:2rem;align-items:center;padding:2rem}.hero-copy h1,.about-hero h1,.section-heading h2,.newsletter-card h2,.spotlight-card h2{margin:0;font-family:Space Grotesk,sans-serif;line-height:1.05}.hero-copy h1,.about-hero h1{font-size:clamp(2.7rem,6vw,4.9rem);letter-spacing:-.04em}.hero-copy p,.about-hero p,.section-heading p,.spotlight-card p,.newsletter-card p,.project-card p,.article-card p,.timeline-card li,.skill-card p,.footer-card p,.footer-card li{color:var(--muted);line-height:1.75}.eyebrow{display:inline-flex;align-items:center;gap:.45rem;margin-bottom:.85rem;font-size:.78rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:#93c5fd}.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.5rem}.primary-button,.secondary-button,.newsletter-form button,.text-button{border:0;border-radius:14px;padding:.95rem 1.25rem;font-weight:700;transition:transform .18s ease,box-shadow .18s ease,background .18s ease}.primary-button,.newsletter-form button{color:#fff;background:linear-gradient(135deg,var(--accent-strong),#2563eb 60%,#1d4ed8);box-shadow:0 12px 30px #2563eb47}.secondary-button,.text-button{color:var(--text);background:#94a3b814;border:1px solid var(--border)}.primary-button:hover,.secondary-button:hover,.newsletter-form button:hover,.text-button:hover,.footer-links button:hover{transform:translateY(-1px)}.hero-visual img,.about-hero img,.spotlight-card img,.project-card img,.article-card img,.cert-card img{width:100%;object-fit:cover;border-radius:20px}.hero-visual img{max-height:420px;border:1px solid rgba(255,255,255,.08);box-shadow:0 30px 60px #0000004d}.stat-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem;margin-top:1.5rem}.stat-card{padding:1rem;border-radius:18px;border:1px solid var(--border);background:#0f172a8c}.stat-card strong{display:block;font-family:Space Grotesk,sans-serif;font-size:1.35rem;margin-bottom:.25rem}.stat-card span{color:var(--muted);font-size:.92rem}.section-heading{display:grid;gap:.5rem}.section-heading h2,.newsletter-card h2,.spotlight-card h2{font-size:clamp(1.8rem,3vw,2.7rem)}.section-heading p{max-width:62ch}.spotlight-card{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(260px,.8fr);gap:1.5rem;padding:1.5rem;align-items:center}.spotlight-card__copy{display:grid;gap:1rem}.badge,.chip{display:inline-flex;align-items:center;justify-content:center;padding:.35rem .7rem;border-radius:999px;border:1px solid var(--border);font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.badge--indigo{background:#4f46e529;color:#c7d2fe}.project-grid,.article-list,.timeline-grid,.cert-grid{display:grid;gap:1rem}.project-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.project-card,.article-card,.timeline-card,.cert-card,.newsletter-card,.skill-card{padding:1.2rem}.project-card,.article-card{overflow:visible}.project-card img,.article-card img{height:250px;margin-bottom:1rem}.project-card__body,.article-card__body{display:grid;gap:.8rem}.article-card>.comment-panel{margin-top:1rem}.post-actions{display:flex;flex-wrap:wrap;gap:.5rem}.share-buttons{display:inline-flex;gap:.5rem;align-items:center}.share-buttons .chip-button,.post-actions .chip-button,.share-buttons a.chip-button{text-decoration:none}.chip-button.is-liked{border-color:#f8717166;color:#fecaca}.project-card h3,.article-card h2,.timeline-card h3,.skill-card h3,.cert-card h3{margin:0;font-family:Space Grotesk,sans-serif}.article-card--amber{border-color:#fbbf242e}.article-card--violet{border-color:#a855f72e}.about-hero{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(250px,.75fr);gap:1.5rem;align-items:center;padding:2rem}.timeline-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.timeline-card{display:grid;gap:.8rem}.timeline-card__institution{margin:0;color:#bfdbfe;font-weight:700}.timeline-card ul{margin:0;padding-left:1.1rem;display:grid;gap:.45rem}.skills-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.skill-card{min-height:190px;display:grid;gap:1rem}.skill-card--large{grid-column:span 2;min-height:240px}.skill-card--wide{grid-column:span 2}.skill-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.skill-card__header i{color:var(--accent);font-size:1.3rem}.chip-row{display:flex;flex-wrap:wrap;gap:.5rem}.chip{background:#0f172ab8;color:#cbd5e1}.cert-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.cert-card{display:grid;gap:.8rem}.cert-card img{border:1px solid var(--border)}.newsletter-card{display:grid;gap:1rem;padding:1.5rem;background:linear-gradient(135deg,#0f172af0,#1e293bd1)}.newsletter-form{display:flex;gap:.75rem;flex-wrap:wrap}.newsletter-form input{flex:1 1 260px;border-radius:14px;border:1px solid var(--border);background:#020617bf;color:var(--text);padding:.95rem 1rem}.newsletter-message{margin:0;color:#bbf7d0}.blog-toolbar{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.75rem;align-items:center;padding:1rem 1.25rem;background:#0f172a8c;border:1px solid var(--border);border-radius:var(--radius-xl)}.blog-toolbar input{width:100%;border-radius:14px;border:1px solid var(--border);background:#020617bf;color:var(--text);padding:.95rem 1rem}.blog-toolbar__meta{display:flex;gap:.75rem;color:var(--muted);font-size:.9rem;flex-wrap:wrap}.content-editor{display:grid;gap:1rem;padding:1.2rem;background:#0f172ac2;border:1px solid rgba(96,165,250,.22);border-radius:var(--radius-xl)}.content-editor__header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.content-editor__form{display:grid;gap:1rem}.content-editor__group,.content-editor__group .content-editor__group{display:grid;gap:.9rem;padding:1rem;border-radius:20px;border:1px solid rgba(148,163,184,.14);background:#02061742}.content-editor__group .content-editor__group h3{margin:0;font-family:Space Grotesk,sans-serif}.content-editor__group .content-editor__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem}.content-editor__group .content-editor__grid--three{grid-template-columns:repeat(3,minmax(0,1fr))}.content-editor__group h3{margin:0;font-family:Space Grotesk,sans-serif}.content-editor__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem}.content-editor__grid--three{grid-template-columns:repeat(3,minmax(0,1fr))}.content-editor__form label{display:grid;gap:.45rem;color:var(--muted);font-size:.9rem}.content-editor__form input,.content-editor__form textarea,.content-editor__form select{width:100%;border-radius:14px;border:1px solid var(--border);background:#020617bf;color:var(--text);padding:.95rem 1rem}.content-editor__grid--two{grid-template-columns:repeat(2,minmax(0,1fr))}.edit-create-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.edit-create-card{display:grid;gap:.85rem;padding:1rem;border-radius:18px;border:1px solid rgba(148,163,184,.14);background:#0f172a8c}.edit-create-card__head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.edit-create-card__head h4{margin:.25rem 0 0;font-family:Space Grotesk,sans-serif}.edit-create-card__count{color:var(--muted);font-size:.85rem}.media-dropzone-wrap{display:grid;gap:.6rem}.media-dropzone__label-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;color:var(--muted);font-size:.9rem}.media-dropzone{position:relative;display:grid;gap:.85rem;min-height:170px;padding:.9rem;border-radius:18px;border:1px dashed rgba(96,165,250,.28);background:linear-gradient(180deg,#0206178c,#0f172a59);transition:border-color .18s ease,transform .18s ease,background .18s ease;cursor:pointer}.media-dropzone.is-dragging{border-color:#60a5fabf;background:#2563eb29;transform:translateY(-1px)}.media-dropzone__empty{display:grid;place-items:center;text-align:center;gap:.35rem;color:var(--muted);min-height:130px}.media-dropzone__empty strong{color:var(--text)}.media-dropzone__empty p{margin:0}.media-dropzone__previews{display:grid;grid-template-columns:repeat(auto-fit,minmax(84px,1fr));gap:.6rem}.media-dropzone__preview,.media-dropzone__single-preview{position:relative;overflow:hidden;border-radius:14px;border:1px solid rgba(148,163,184,.14);background:#02061799;aspect-ratio:1 / 1}.media-dropzone__single-preview{aspect-ratio:16 / 10}.media-dropzone__preview img,.media-dropzone__single-preview img{width:100%;height:100%;object-fit:cover}.media-dropzone__remove{position:absolute;top:.4rem;right:.4rem;width:1.8rem;height:1.8rem;border:0;border-radius:999px;background:#020617d9;color:#fff;font-size:1.1rem;line-height:1}.image-carousel{width:100%;display:grid;gap:.45rem}.image-carousel__frame{position:relative;overflow:hidden;border-radius:20px;border:1px solid rgba(255,255,255,.08);background:#02061773}.project-card .image-carousel__frame,.article-card .image-carousel__frame{height:250px}.spotlight-card .image-carousel__frame{min-height:280px;height:100%}.image-carousel__frame img{width:100%;height:100%;object-fit:cover;-webkit-user-select:none;user-select:none}.image-carousel__nav{position:absolute;top:50%;transform:translateY(-50%);width:2.4rem;height:2.4rem;border-radius:999px;border:1px solid rgba(255,255,255,.16);background:#020617a6;color:#fff;font-size:1.4rem;line-height:1;display:grid;place-items:center;z-index:1}.image-carousel__nav--prev{left:.5rem}.image-carousel__nav--next{right:.5rem}.image-carousel__dots{display:flex;justify-content:center;gap:.4rem;flex-wrap:wrap}.image-carousel__dot{width:.55rem;height:.55rem;border-radius:999px;border:0;background:#94a3b859}.image-carousel__dot.is-active{width:1rem;background:linear-gradient(90deg,var(--accent),#c4b5fd)}.project-card__image,.article-card__image,.spotlight-card__image{border-radius:20px}.content-editor__card{display:grid;gap:.9rem;padding:1rem;border-radius:18px;border:1px solid var(--border);background:#0f172a8c}.content-editor__card-head{display:flex;align-items:center;justify-content:space-between;gap:1rem}.comment-panel{display:grid;gap:1rem;padding:1.2rem;border-radius:var(--radius-xl);border:1px solid var(--border);background:#0f172ab3}.article-card .comment-panel{margin-top:.5rem;background:#02061759}.comment-panel__header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.comment-form{display:grid;gap:.75rem}.comment-form textarea{width:100%;resize:vertical;border-radius:14px;border:1px solid var(--border);background:#020617bf;color:var(--text);padding:.95rem 1rem}.comment-form button{justify-self:start}.comment-list{display:grid;gap:.8rem}.comment-item{display:grid;grid-template-columns:2.5rem 1fr;gap:.75rem;align-items:start;padding:.85rem;border-radius:16px;background:#0206178c;border:1px solid rgba(148,163,184,.1)}.comment-item img,.comment-item span{width:2.5rem;height:2.5rem;border-radius:999px;object-fit:cover;display:grid;place-items:center;background:linear-gradient(135deg,#3b82f64d,#a855f74d)}.comment-item p,.comment-empty{margin:.25rem 0 0;color:var(--muted)}.comment-error,.content-editor__status{margin:0;padding:.75rem .9rem;border-radius:12px;background:#0f172a8c;border:1px solid rgba(96,165,250,.18);color:#cbd5e1}.site-footer{border-top:1px solid var(--border);background:#040910b8;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.site-footer__grid{padding:2rem 0;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}.footer-card h3,.footer-card h4{margin:0 0 .8rem;font-family:Space Grotesk,sans-serif}.footer-card ul{list-style:none;margin:0;padding:0;display:grid;gap:.55rem}.footer-links{display:grid;gap:.55rem}.footer-links button{text-align:left;padding:0}.social-links{display:flex;align-items:center;gap:1rem;font-size:1.2rem}.social-links a{display:inline-flex;align-items:center;justify-content:center;width:2.6rem;height:2.6rem;border-radius:999px;border:1px solid var(--border);background:#0f172ab3;color:var(--text)}.social-links a svg{width:1.2rem;height:1.2rem;fill:currentColor}.site-footer__bar{padding:1rem 0 1.5rem;border-top:1px solid var(--border);text-align:center;color:var(--muted);font-size:.88rem}.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease;transition-delay:var(--reveal-delay, 0ms)}.reveal-visible{opacity:1;transform:translateY(0)}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:#050915}::-webkit-scrollbar-thumb{background:#1e293b;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#334155}@media (max-width: 1024px){.hero-grid,.spotlight-card,.about-hero{grid-template-columns:1fr}.project-grid,.timeline-grid,.cert-grid,.site-footer__grid,.skills-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.skill-card--large,.skill-card--wide{grid-column:span 2}.edit-create-grid{grid-template-columns:1fr}.site-header__inner,.page-shell,.site-footer__grid,.site-footer__bar{width:min(1180px,calc(100% - 1.5rem))}}@media (max-width: 780px){.site-header__inner{min-height:auto;flex-wrap:wrap;align-items:center;padding:.75rem 0}.brand-mark{font-size:1.1rem;flex:0 0 auto;margin-right:auto}.desktop-nav{display:none}.header-actions{display:flex;order:2;margin-left:auto}.auth-panel{position:absolute;top:calc(100% + .6rem);right:0;left:auto;transform:none;width:min(380px,calc(100vw - 1rem));max-height:min(86vh,720px);overflow:auto;z-index:60;box-shadow:0 30px 90px #00000073}.menu-toggle{display:inline-flex;order:3;margin-left:.5rem}.mobile-nav{width:min(1180px,calc(100% - 1.5rem))}.project-grid,.timeline-grid,.cert-grid,.site-footer__grid,.skills-grid,.stat-row{grid-template-columns:1fr}.hero-grid,.about-hero,.spotlight-card,.newsletter-card{padding:1.2rem}.newsletter-form{flex-direction:column}.newsletter-form button{width:100%}.blog-toolbar,.content-editor__header,.comment-panel__header{grid-template-columns:1fr;flex-direction:column;align-items:stretch}.content-editor__grid--two{grid-template-columns:1fr}.image-carousel__nav{width:2rem;height:2rem}.hero-grid,.about-hero,.spotlight-card,.newsletter-card,.project-card,.article-card,.timeline-card,.cert-card,.skill-card,.content-editor,.comment-panel{border-radius:22px}.hero-grid,.about-hero,.spotlight-card,.newsletter-card{gap:1rem}.hero-grid,.about-hero,.spotlight-card{padding:1rem}.project-card img,.article-card img,.project-card .image-carousel__frame,.article-card .image-carousel__frame{height:210px}.spotlight-card .image-carousel__frame{min-height:220px}.blog-toolbar,.content-editor__header,.comment-panel__header,.edit-create-card__head,.media-dropzone__label-row{grid-template-columns:1fr;flex-direction:column;align-items:stretch}.post-actions,.share-buttons,.hero-actions,.newsletter-form,.social-links,.chip-row{width:100%}.share-buttons,.hero-actions,.newsletter-form{flex-direction:column;align-items:stretch}.post-actions{flex-direction:row;align-items:center;gap:.5rem}.share-buttons .chip-button,.hero-actions .primary-button,.hero-actions .secondary-button,.newsletter-form button,.newsletter-form input{width:100%}.post-actions .chip-button,.post-actions .share-buttons .chip-button{width:auto}.social-links{justify-content:center;flex-wrap:wrap}.content-editor__grid,.content-editor__grid--two,.content-editor__grid--three,.edit-create-grid,.project-grid,.timeline-grid,.cert-grid,.skills-grid,.site-footer__grid,.stat-row{grid-template-columns:1fr}.skill-card--large,.skill-card--wide{grid-column:auto}.content-editor__form input,.content-editor__form textarea,.content-editor__form select,.blog-toolbar input,.newsletter-form input,.comment-form textarea,.auth-form input{padding:.85rem .9rem}.auth-panel{width:min(380px,calc(100vw - 1rem))}.page-shell,.site-footer__grid,.site-footer__bar,.site-header__inner,.mobile-nav{width:min(1180px,calc(100% - 1rem))}}@media (max-width: 560px){.hero-copy h1,.about-hero h1{font-size:clamp(2.1rem,12vw,3.2rem)}.section-heading h2,.newsletter-card h2,.spotlight-card h2{font-size:clamp(1.5rem,7vw,2.1rem)}.hero-grid,.about-hero,.spotlight-card,.newsletter-card,.content-editor,.comment-panel{padding:.9rem}.site-header__inner,.page-shell,.site-footer__grid,.site-footer__bar,.mobile-nav{width:min(1180px,calc(100% - .75rem))}.brand-mark{font-size:1rem}.auth-chip,.auth-button,.chip-button,.nav-link,.mobile-nav__link{padding-inline:.8rem}.auth-panel{width:min(360px,calc(100vw - .75rem));max-height:min(88vh,680px)}.project-card img,.article-card img,.project-card .image-carousel__frame,.article-card .image-carousel__frame{height:190px}.spotlight-card .image-carousel__frame{min-height:190px}}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}.reveal,.nav-link,.mobile-nav__link,.primary-button,.secondary-button,.newsletter-form button,.text-button,.footer-links button{transition:none}}
