:root{--color-primary-light:#06c;--color-primary-dark:#39f;--color-primary:var(--color-primary-light);--color-success:#34d399;--color-success-light:#10b981;--color-warning:#fbbf24;--color-warning-light:#f59e0b;--color-error:#f87171;--color-error-light:#ef4444;--color-info:#60a5fa;--color-info-light:#3b82f6;--color-white:#fff;--color-neutral-50:#f9f9f9;--color-neutral-100:#f3f3f3;--color-neutral-200:#e8e8e8;--color-neutral-300:#d4d4d4;--color-neutral-400:#a8a8a8;--color-neutral-500:#717171;--color-neutral-600:#464646;--color-neutral-700:#2a2a2a;--color-neutral-800:#171717;--color-neutral-900:#0a0a0a;--color-bg-primary:#fff;--color-bg-secondary:#f9f9f9;--color-bg-tertiary:#f3f3f3;--color-text-primary:#0a0a0a;--color-text-secondary:#464646;--color-text-tertiary:#717171;--color-text-disabled:#a8a8a8;--color-border:#e8e8e8;--spacing-xs:.25rem;--spacing-sm:.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:2.5rem;--spacing-3xl:3rem;--spacing-4xl:4rem;--spacing-5xl:6rem;--font-sans:system-ui,-apple-system,sans-serif,"Apple Color Emoji";--font-serif:Georgia,"Times New Roman",serif;--font-mono:"Courier New",monospace;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--font-size-5xl:3rem;--font-weight-light:300;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--line-height-tight:1.2;--line-height-normal:1.5;--line-height-relaxed:1.75;--line-height-loose:2;--shadow-none:none;--shadow-xs:0 1px 2px 0 #0000000d;--shadow-sm:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-base:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-md:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadow-lg:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--shadow-xl:0 25px 50px -12px #00000040;--radius-none:0;--radius-sm:.125rem;--radius-base:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--radius-3xl:1.5rem;--radius-full:9999px;--transition-fast:.15s;--transition-base:.2s;--transition-slow:.3s;--transition-slower:.5s;--transition-timing:cubic-bezier(.4,0,.2,1);--z-hide:-1;--z-base:0;--z-dropdown:10;--z-sticky:20;--z-fixed:30;--z-offcanvas:40;--z-modal:50;--z-popover:60;--z-tooltip:70;--z-notification:80;--header-bg:#fff;--header-border:#e2e8f0;--page-bg:#f9fafb;--text-color:#111827;--muted-text:#4b5563;--accent:#0c0259;--accent-soft:#091b55;--accent-hover:#091b55;--accent-strong:#091b55;--focus-ring:2px solid #091b55;--header-max-width:72rem;--shadow-soft:0 8px 28px #0f172a1f;--border-subtle:#e5e7eb;--code-bg:#020617;--code-border:#0f172a}html.dark,html[data-theme=dark]{--color-primary:var(--color-primary-dark);--color-success:#10b981;--color-warning:#f59e0b;--color-error:#ef4444;--color-info:#3b82f6;--color-bg-primary:#0f172a;--color-bg-secondary:#1e293b;--color-bg-tertiary:#334155;--color-text-primary:#f9fafb;--color-text-secondary:#d1d5db;--color-text-tertiary:#9ca3af;--color-text-disabled:#6b7280;--color-border:#374151;--header-bg:#0f172a;--header-border:#374151;--page-bg:#0f172a;--text-color:#f9fafb;--muted-text:#d1d5db;--accent:#39f;--accent-soft:#1e40af;--accent-hover:#1e40af;--accent-strong:#3b82f6;--border-subtle:#374151;--code-bg:#1e293b;--code-border:#334155}*{box-sizing:border-box}body{color:var(--text-color);background:var(--page-bg);margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}a{color:inherit;text-decoration:none}a:hover{text-decoration:none}a:focus-visible,button:focus-visible,[role=button]:focus-visible,input[type=checkbox]:focus-visible+label{outline:var(--focus-ring);outline-offset:3px}.session-timeout-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9998;background:#0009;animation:.2s ease-out fadeIn;position:fixed;inset:0}.session-timeout-modal{border-radius:var(--radius-lg);z-index:9999;text-align:center;background:#fff;width:90%;max-width:450px;padding:2rem;animation:.3s ease-out slideIn;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 20px 60px #0000004d}.session-timeout-icon{margin-bottom:1rem;font-size:3rem;animation:2s ease-in-out infinite pulse}.session-timeout-title{color:var(--text-color);margin:0 0 1rem;font-size:1.5rem;font-weight:700}.session-timeout-message{color:var(--text-color);margin:0 0 .75rem;font-size:1rem;line-height:1.6}.session-timeout-message strong{color:#dc2626;font-size:1.1rem;font-weight:700}.session-timeout-submessage{color:var(--muted-text);margin:0 0 1.5rem;font-size:.875rem;line-height:1.5}.session-timeout-actions{justify-content:center;gap:.75rem;display:flex}.session-timeout-btn{border-radius:var(--radius-md);cursor:pointer;border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s}.session-timeout-btn-primary{background:var(--accent);color:#fff}.session-timeout-btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #0c02594d}.session-timeout-btn-primary:active{transform:translateY(0)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translate(-50%,-48%)}to{opacity:1;transform:translate(-50%,-50%)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.skip-link{color:#f9fafb;border-radius:var(--radius-sm);z-index:50;background:#111827;padding:.5rem .75rem;transition:transform .2s;position:absolute;top:.75rem;left:.75rem;transform:translateY(-200%)}.skip-link:focus{transform:translateY(0)}header.site-header{background:var(--header-bg);border-bottom:1px solid var(--header-border)}.header-inner{max-width:var(--header-max-width);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin:0 auto;padding:.75rem 1rem;display:flex}.brand{align-items:center;gap:.5rem;min-width:0;display:inline-flex}.brand-logo{justify-content:center;align-items:center;display:inline-flex}.brand-logo svg{width:auto;height:2.4rem;display:block}.brand-text{flex-direction:column;min-width:0;display:flex}.brand-title{letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;font-size:1rem;font-weight:700}.brand-subtitle{color:var(--muted-text);max-width:10rem;font-size:.72rem;line-height:1.3}.nav-toggle{opacity:0;pointer-events:none;position:absolute}.nav-toggle-label{border-radius:var(--radius-sm);border:1px solid var(--header-border);cursor:pointer;justify-content:center;align-items:center;min-width:2.5rem;min-height:2.5rem;margin-left:auto;padding:.35rem .5rem;display:inline-flex}.nav-toggle-label:hover{background:#f3f4f6}.nav-toggle-label-bars{flex-direction:column;gap:.18rem;display:inline-flex}.nav-toggle-label-bars span{background:#111827;border-radius:999px;width:1.25rem;height:2px;display:block}nav.primary-nav{flex-basis:100%;width:100%;max-height:0;transition:max-height .2s;overflow:hidden}nav.primary-nav ul{flex-direction:column;gap:.15rem;margin:0;padding:.5rem 0 .25rem;list-style:none;display:flex}nav.primary-nav a{border-radius:var(--radius-sm);padding:.4rem .25rem;font-size:.9rem;display:block}nav.primary-nav a:hover{color:var(--accent-hover);background:#eff6ff;text-decoration:none}nav.primary-nav a[aria-current=page]{color:var(--accent);font-weight:600}.nav-toggle:checked~nav.primary-nav{max-height:18rem}main{max-width:var(--header-max-width);margin:0 auto;padding:2rem 1rem 3rem}.hero{display:block}.hero-grid{flex-direction:column;gap:2rem;display:flex}.hero-copy{max-width:40rem}.hero-label{color:var(--accent-strong);letter-spacing:.06em;text-transform:uppercase;background:#eff6ff;border-radius:999px;align-items:center;gap:.5rem;padding:.25rem .6rem;font-size:.72rem;font-weight:500;display:inline-flex}.hero-label-dot{background:var(--accent-strong);border-radius:999px;width:.38rem;height:.38rem}.hero-title{letter-spacing:.01em;margin:.9rem 0 .5rem;font-size:3.6rem;line-height:1.2}.hero-subtitle{color:var(--muted-text);margin:0 0 .35rem;font-size:.98rem}.hero-location{color:#6b7280;margin:.4rem 0 0;font-size:.82rem}.hero-ctas{flex-wrap:wrap;gap:.6rem;margin:1.3rem 0 1.4rem;display:flex}.btn{cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:9px;justify-content:center;align-items:center;padding:.6rem 1.15rem;font-size:.9rem;font-weight:500;text-decoration:none;display:inline-flex}.btn-primary{background:var(--accent);color:#f9fafb;border-color:#0000}.btn-primary:hover{background:var(--accent-hover);text-decoration:none}.btn-secondary{color:var(--text-color);border-color:var(--border-subtle);background:#fff}.btn-secondary:hover{background:#f9fafb;text-decoration:none}.hero-paths-label{text-transform:uppercase;letter-spacing:.12em;color:#6b7280;margin-bottom:.6rem;font-size:.78rem}.hero-paths{grid-template-columns:minmax(0,1fr);gap:.7rem;display:grid}.hero-path-card{border:1px solid var(--border-subtle);background:#dbdcc3;border-radius:9px;padding:.75rem .9rem;text-decoration:none;display:block;box-shadow:0 10px 18px #0f172a05}.hero-path-card:hover{border-color:var(--accent-soft);background:#f9fafb;text-decoration:none}.hero-path-card h3{margin:0;font-size:.9rem;font-weight:600}.hero-path-card p{color:var(--muted-text);margin:.15rem 0 0;font-size:.8rem}.hero-visual{flex-direction:column;gap:1rem;display:flex}.hero-card{color:#e5e7eb;border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);background:#0b1120;border:1px solid #111827;padding:1rem}.hero-card-header{color:#9ca3af;justify-content:space-between;align-items:center;margin-bottom:.65rem;font-size:.78rem;display:flex}.hero-card-title{color:#e5e7eb;font-size:.88rem;font-weight:500}.hero-architecture-flow{flex-wrap:wrap;align-items:center;gap:.35rem;font-size:.78rem;display:flex}.hero-arch-node{white-space:nowrap;background:#020617;border:1px solid #1e293b;border-radius:999px;padding:.25rem .6rem}.hero-arch-arrow{color:#9ca3af}.hero-stack-card{border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);background:radial-gradient(circle at 0 0,#3b82f647,#0000 50%),#020617;border:1px solid #111827;padding:1rem}.hero-stack-top{color:#cbd5f5;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.8rem;display:flex}.hero-stack-pill{text-transform:uppercase;letter-spacing:.12em;background:#0f172ad9;border:1px solid #1d4ed8;border-radius:999px;padding:.18rem .55rem;font-size:.68rem}.hero-stack-tech-row{flex-wrap:wrap;gap:.25rem;margin-bottom:.6rem;font-size:.76rem;display:flex}.hero-stack-tech{white-space:nowrap;color:#e5e7eb;background:#0f172ae6;border:1px solid #94a3b8d9;border-radius:999px;padding:.18rem .6rem;font-size:.76rem;font-weight:500}.hero-code-snippet{background:var(--code-bg);border:1px solid var(--code-border);color:#e5e7eb;border-radius:.7rem;padding:.65rem .75rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.72rem;overflow-x:auto}.hero-code-snippet code{white-space:pre}.expertise{margin-top:3rem}.expertise-header{max-width:40rem;margin-bottom:1.5rem}.expertise-header h2{letter-spacing:.06em;text-transform:uppercase;color:var(--text-color);margin:0 0 .35rem;font-size:1.2rem;font-weight:700}.expertise-subtitle{color:var(--muted-text);margin:0;font-size:.96rem}.expertise-grid{grid-template-columns:minmax(0,1fr);gap:1rem;display:grid}.expertise-card{border:1px solid var(--border-subtle);background:#fff;border-radius:.9rem;flex-direction:column;justify-content:flex-start;gap:.4rem;padding:1rem 1.05rem 1.1rem;transition:transform .18s,box-shadow .2s,border-color .2s,background .25s;display:flex;position:relative;overflow:hidden;box-shadow:0 14px 28px #0f172a0a}.expertise-card:hover,.expertise-card:focus-within{border-color:var(--accent-soft);transform:translateY(-4px);box-shadow:0 18px 32px #0f172a14}.expertise-card:first-child{background:linear-gradient(135deg,#eff6ff,#fff);border-color:#dbeafe}.expertise-card:nth-child(2){background:linear-gradient(135deg,#ecfdf3,#fff);border-color:#bbf7d0}.expertise-card:nth-child(3){background:linear-gradient(135deg,#f5f3ff,#fff);border-color:#ddd6fe}.expertise-card:nth-child(4){background:linear-gradient(135deg,#fef9c3,#fff);border-color:#fef08a}.expertise-card:before{content:"";background:#2563eb29;border-radius:999px;width:3px;transition:background .2s,width .2s;position:absolute;top:.75rem;bottom:.75rem;left:0}.expertise-card:hover:before,.expertise-card:focus-within:before{background:#2563eb52;width:4px}.expertise-card-title{margin:0 0 .35rem;font-size:1rem;font-weight:600}.expertise-card-body{color:var(--muted-text);margin:0 0 .6rem;font-size:.9rem}.expertise-list{margin:0;padding-left:1.1rem;list-style:none}.expertise-list li{color:#374151;margin:.18rem 0;padding-left:.7rem;font-size:.86rem;position:relative}.expertise-list li:before{content:"";background:var(--accent);border-radius:999px;width:.33rem;height:.33rem;position:absolute;top:.55em;left:0}.projects-section{padding:3.5rem 0 4rem}.projects-container{max-width:var(--header-max-width);margin:0 auto;padding:0 1rem}.projects-heading{letter-spacing:.06em;text-transform:uppercase;color:var(--text-color);margin:0 0 .35rem;font-size:1.2rem;font-weight:700}.projects-subtitle{max-width:42rem;color:var(--muted-text);margin:0 0 2.3rem;font-size:.96rem}.projects-grid{grid-template-columns:minmax(0,1fr);gap:1.6rem;display:grid}.project-card{border-radius:var(--radius-lg);background:linear-gradient(135deg,#0f172afa,#0f172ae6);border:1px solid #1e293b;flex-direction:column;gap:.85rem;padding:1.4rem 1.3rem;transition:transform .25s,box-shadow .25s,border-color .25s,background .25s;display:flex;transform:translateY(0);box-shadow:0 16px 30px #0f172ab3}.project-card:hover,.project-card:focus-within{border-color:var(--accent);background:radial-gradient(circle at 100% 0,#0b1120,#020617);transform:translateY(-6px);box-shadow:0 24px 40px #0f172ae6}.project-title{color:#e5e7eb;font-size:1rem;font-weight:600;line-height:1.4}.project-description{color:#9ca3af;font-size:.9rem;line-height:1.6}.project-depth{color:#94a3b8;font-size:.85rem;line-height:1.55}.project-tags{flex-wrap:wrap;gap:.4rem;font-size:.75rem;display:flex}.project-tags span{color:#cbd5f5;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172ab3;border:1px solid #94a3b880;border-radius:999px;padding:.25rem .7rem}.project-link{color:#7dd3fc;align-items:center;gap:.3rem;margin-top:auto;font-size:.85rem;font-weight:500;text-decoration:none;transition:color .25s,transform .25s;display:inline-flex}.project-link:after{content:"↗";font-size:.8rem;transition:transform .25s}.project-link:hover,.project-link:focus-visible{color:#7dd3fc;transform:translateY(-1px)}.project-link:hover:after,.project-link:focus-visible:after{transform:translate(2px)translateY(-1px)}.cta-section{max-width:var(--header-max-width);color:#f1f5f9;background:radial-gradient(circle at 0 0,#0b1220 0,#020617 50%,#000 100%);border-radius:1.5rem;margin:3.5rem auto 4rem;padding:3.5rem 1rem 4rem;position:relative;overflow:hidden}.cta-inner{max-width:var(--header-max-width);text-align:center;margin:0 auto}.cta-section:before,.cta-section:after{content:"";filter:blur(40px);opacity:.45;pointer-events:none;border-radius:999px;position:absolute}.cta-section:before{background:#3b82f666;width:7rem;height:7rem;top:16%;left:8%}.cta-section:after{background:#94a3b84d;width:10rem;height:10rem;bottom:12%;right:6%}.cta-badge{z-index:1;background:#0f172ab3;border:1px solid #94a3b866;border-radius:999px;align-items:center;gap:.4rem;margin-bottom:.9rem;padding:.4rem .9rem;font-size:.8rem;font-weight:500;display:inline-flex;position:relative}.cta-badge-dot{background:var(--accent);border-radius:999px;width:.45rem;height:.45rem}.cta-title{letter-spacing:.01em;z-index:1;margin:0;font-size:clamp(1.9rem,4vw,2.6rem);font-weight:700;line-height:1.2;position:relative}.cta-title-accent{color:#60a5fa;display:block}.cta-subtitle{color:#e2e8f0;z-index:1;max-width:36rem;margin:.9rem auto 1.8rem;font-size:.98rem;line-height:1.7;position:relative}.cta-actions{z-index:1;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;margin-bottom:2.4rem;display:flex;position:relative}.cta-btn-primary{background:#2563eb;border-color:#3b82f6;box-shadow:0 1px 2px #0000004d}.cta-btn-primary:hover{background:#3b82f6;box-shadow:0 2px 8px #2563eb66}.cta-btn-secondary{color:#f1f5f9;background:0 0;border-color:#f3f4f666}.cta-btn-secondary:hover{color:#020617;background:#f9fafb}.cta-stats{z-index:1;border-top:1px solid #94a3b84d;grid-template-columns:minmax(0,1fr);gap:1.3rem;padding-top:1.7rem;display:grid;position:relative}.cta-stat{text-align:center}.cta-stat-value{color:#60a5fa;margin-bottom:.2rem;font-size:1.6rem;font-weight:700}.cta-stat-label{color:#e2e8f0;letter-spacing:.06em;text-transform:uppercase;font-size:.8rem}@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}@media (min-width:640px){.hero-title{font-size:1.9rem}.hero-subtitle{font-size:1rem}.expertise-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.cta-section{padding-inline:1.5rem}.cta-actions{flex-direction:row}}@media (min-width:768px){.header-inner{flex-wrap:nowrap;padding:.9rem 1.5rem}.brand-subtitle{max-width:12rem}.nav-toggle-label{display:none}nav.primary-nav{flex-basis:auto;width:auto;max-height:none}nav.primary-nav ul{flex-direction:row;align-items:center;gap:.75rem;padding:0}nav.primary-nav a{padding:.3rem .4rem;font-size:.92rem}main{padding:3rem 1.5rem 3.5rem}.hero-grid{grid-template-columns:minmax(0,3fr) minmax(0,2.4fr);align-items:stretch;gap:2.5rem;display:grid}.hero-visual{align-self:stretch}.projects-grid,.cta-stats{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width:1024px){.hero-title{font-size:3.2rem}.hero-subtitle{font-size:1.02rem}.expertise-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (max-width:640px){.projects-container{padding:0 1rem}.project-card{padding:1.25rem 1.1rem}}.site-footer{color:#111827;background:#f5f5f0;border-top:1px solid #e0dfd8;width:100%;margin-top:3rem;padding:3rem 1rem 2.75rem}.footer-inner{max-width:var(--header-max-width);grid-template-columns:minmax(0,1fr);gap:1.75rem;margin:0 auto 2rem;display:grid}.footer-column{font-size:.9rem}.footer-title{letter-spacing:.08em;text-transform:uppercase;color:#111827;margin:0 0 .35rem;font-size:1.05rem;font-weight:700}.footer-role{color:#374151;margin:0 0 .5rem;font-size:.86rem;font-weight:500}.footer-text{color:#4b5563;margin:0 0 .5rem;font-size:.86rem}.footer-text a{color:#111827;text-underline-offset:2px;text-decoration:underline;text-decoration-thickness:1px}.footer-text a:hover{color:var(--accent)}.footer-heading{letter-spacing:.08em;text-transform:uppercase;color:#111827;margin:0 0 .6rem;font-size:.88rem;font-weight:600}.footer-links{margin:0;padding:0;list-style:none}.footer-links li+li{margin-top:.25rem}.footer-links a{color:#374151;opacity:.9;font-size:.86rem;text-decoration:none;transition:color .2s,opacity .2s,transform .15s}.footer-links a:hover,.footer-links a:focus-visible{color:var(--accent);opacity:1;text-decoration:underline;transform:translate(1px)}.footer-social{flex-wrap:wrap;gap:.5rem;margin:.6rem 0 0;padding:0;list-style:none;display:flex}.footer-social a{color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:999px;align-items:center;gap:.35rem;padding:.35rem .75rem;font-size:.8rem;font-weight:500;text-decoration:none;transition:color .2s,border-color .2s,background .2s,transform .15s;display:inline-flex}.footer-social a:hover,.footer-social a:focus-visible{color:var(--accent);border-color:var(--accent);background:#eff6ff;transform:translateY(-1px)}.footer-tech{max-width:var(--header-max-width);text-align:center;color:#4b5563;letter-spacing:.08em;text-transform:uppercase;border-top:1px solid #dddcd5;margin:0 auto 1.4rem;padding-top:1rem;font-size:.78rem}.footer-bottom{max-width:var(--header-max-width);color:#4b5563;text-align:center;border-top:1px solid #dddcd5;flex-direction:column;gap:.4rem;margin:0 auto;padding-top:.7rem;font-size:.78rem;display:flex}.footer-bottom p{margin:0}@media (min-width:768px){.footer-inner{grid-template-columns:minmax(0,1.6fr) minmax(0,.7fr) minmax(0,.7fr) minmax(0,1.2fr)}.footer-bottom{text-align:left;flex-direction:row;justify-content:space-between}}.contact-page{max-width:var(--header-max-width);margin:0 auto;padding:3rem 1rem 4rem}.contact-header{text-align:center;max-width:40rem;margin:0 auto 2.5rem}.contact-title{letter-spacing:.06em;text-transform:uppercase;margin:0 0 .5rem;font-size:1.8rem}.contact-lead{color:var(--muted-text);margin:0;font-size:.98rem}.contact-grid{grid-template-columns:minmax(0,1fr);gap:2rem;display:grid}.contact-section-heading{margin:0 0 .5rem;font-size:1.05rem;font-weight:600}.contact-info-intro,.contact-form-intro{color:var(--muted-text);margin:0 0 1.2rem;font-size:.9rem}.contact-cards{grid-template-columns:minmax(0,1fr);gap:.9rem;margin-bottom:1.8rem;display:grid}.contact-card{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:#fff;align-items:flex-start;gap:.75rem;padding:.9rem 1rem;display:flex;box-shadow:0 10px 20px #0f172a0a}.contact-card-icon{margin-top:.15rem;font-size:1.3rem;line-height:1}.contact-card-body{font-size:.88rem}.contact-card-title{margin:0 0 .1rem;font-size:.9rem;font-weight:600}.contact-card-main{margin:0;font-weight:500}.contact-card-main a{color:var(--accent)}.contact-card-main a:hover{text-decoration:underline}.contact-card-meta{color:#6b7280;margin:.15rem 0 0;font-size:.8rem}.contact-expectations-title{margin:0 0 .3rem;font-size:.9rem;font-weight:600}.contact-expectations-list{color:#374151;margin:.1rem 0 0;padding-left:1.1rem;font-size:.86rem}.contact-form-wrapper{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:#fff;padding:1.4rem 1.3rem 1.6rem;box-shadow:0 12px 30px #0f172a0f}.contact-form,.contact-form-row{flex-direction:column;gap:.85rem;display:flex}.contact-form-row--two .field{flex:1}.field-honeypot{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute;left:-9999px;overflow:hidden}.field label{margin-bottom:.25rem;font-size:.85rem;font-weight:500;display:block}.field-required{color:#b91c1c}.field input,.field select,.field textarea{width:100%;font:inherit;border:1px solid var(--border-subtle);color:var(--text-color);background:#f9fafb;border-radius:.5rem;outline:none;padding:.5rem .55rem;transition:border-color .15s,box-shadow .15s,background .15s}.field input:focus-visible,.field select:focus-visible,.field textarea:focus-visible{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-soft);background:#fff}.field-hint{color:#6b7280;margin:.25rem 0 0;font-size:.78rem}.contact-submit{align-self:flex-start;margin-top:.3rem}@media (min-width:768px){.contact-grid{grid-template-columns:minmax(0,1.05fr) minmax(0,1.1fr);align-items:flex-start;gap:2.5rem}.contact-form-row--two{flex-direction:row}}@media (min-width:1024px){.contact-page{padding-top:3.5rem}}.alert{border:1px solid;border-radius:.5rem;margin-bottom:2rem;padding:1rem 1.25rem}.alert strong{margin-bottom:.25rem;font-weight:600;display:block}.alert p{margin:0;font-size:.95rem}.alert-success{color:#065f46;background-color:#d1fae5;border-color:#6ee7b7}.alert-error{color:#991b1b;background-color:#fee2e2;border-color:#fca5a5}.books-page{max-width:var(--header-max-width);margin:0 auto;padding:3.5rem 1.5rem 4.5rem}.books-header{text-align:center;max-width:44rem;margin:0 auto 3rem}.books-label{color:var(--accent-strong);letter-spacing:.06em;text-transform:uppercase;background:#eff6ff;border-radius:999px;align-items:center;gap:.5rem;margin-bottom:.6rem;padding:.25rem .6rem;font-size:.72rem;font-weight:500;display:inline-flex}.books-label-dot{background:var(--accent-strong);border-radius:999px;width:.38rem;height:.38rem}.books-title{letter-spacing:.06em;text-transform:uppercase;margin:0 0 .6rem;font-size:1.9rem}.books-lead{color:var(--muted-text);margin:0;font-size:1rem}.books-section{background:radial-gradient(circle at 0 0,#eef2ff 0,#f9fafb 45%,#fff 100%);border:1px solid #e5e7eb;border-radius:1.5rem;margin-top:2.8rem;padding:1.75rem 1.5rem 2rem}.books-section-header{max-width:40rem;margin-bottom:1.6rem}.books-section-title{letter-spacing:.04em;text-transform:uppercase;margin:0 0 .3rem;font-size:1.05rem;font-weight:600}.books-section-subtitle{color:var(--muted-text);margin:0;font-size:.9rem}.books-grid{grid-template-columns:minmax(0,1fr);gap:1.5rem;display:grid}.book-card{background:#fff;border:1px solid #e5e7eb;border-radius:1rem;flex-direction:column;transition:transform .18s,box-shadow .22s,border-color .2s;display:flex;overflow:hidden;box-shadow:0 12px 30px #0f172a12}.book-card:hover,.book-card:focus-within{border-color:var(--accent-soft);transform:translateY(-6px);box-shadow:0 24px 60px #0f172a1f}.book-media{aspect-ratio:3/4;background:#020617;position:relative;overflow:hidden}.book-media img{object-fit:cover;width:100%;height:100%;display:block}.book-media--placeholder{aspect-ratio:3/4;justify-content:stretch;align-items:stretch;min-height:0;display:flex}.book-media-overlay{color:#f9fafb;flex-direction:column;justify-content:flex-end;width:100%;min-height:0;padding:.9rem .85rem;display:flex;overflow:hidden}.book-media-tag{letter-spacing:.14em;text-transform:uppercase;background:#0f172a99;border:1px solid #f8fafcb3;border-radius:999px;align-self:flex-start;padding:.16rem .6rem;font-size:.7rem}.book-media-title{margin-top:1.2rem;font-size:1rem;font-weight:600}.book-media-subtitle{color:#e5e7eb;margin-top:.2rem;font-size:.82rem}.book-media--blue{background:radial-gradient(circle at 0 0,#1d4ed8,#020617)}.book-media--purple{background:radial-gradient(circle at 0 0,#7c3aed,#020617)}.book-media--green{background:radial-gradient(circle at 0 0,#16a34a,#022c22)}.book-media--teal{background:radial-gradient(circle at 0 0,#0f766e,#020617)}.book-media--gold{background:radial-gradient(circle at 0 0,#d97706,#111827)}.book-body{flex-direction:column;gap:.4rem;padding:.9rem 1rem 1.1rem;font-size:.88rem;display:flex}.book-title{margin:0;font-size:.95rem;font-weight:600}.book-subtitle{color:var(--muted-text);margin:0;font-size:.85rem}.book-meta{color:#4b5563;grid-template-columns:minmax(0,1fr);gap:.2rem;margin:.45rem 0 .2rem;font-size:.8rem;display:grid}.book-meta dt{font-weight:600;display:inline}.book-meta dd{margin:0;display:inline}.book-meta div+div{margin-top:.1rem}.book-tags{flex-wrap:wrap;gap:.35rem;margin:.45rem 0 .2rem;padding:0;font-size:.75rem;list-style:none;display:flex}.book-tags li{color:#374151;background:#f9fafb;border:1px solid #94a3b8b3;border-radius:999px;padding:.2rem .6rem}.book-card-link{color:inherit;text-decoration:none;display:flex}.book-card-link .book-card{cursor:pointer;width:100%}.book-link{color:var(--accent);margin-top:.25rem;font-size:.85rem;font-weight:500;text-decoration:none}.book-card-link:hover .book-link,.book-card-link:focus-visible .book-link,.book-link:hover,.book-link:focus-visible{text-decoration:underline}@media (min-width:640px){.books-page{padding-inline:1.75rem}.books-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem}}@media (min-width:768px){.books-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:1024px){.books-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.books-page{padding-top:4rem;padding-bottom:5rem}.books-section{padding-inline:2rem}}.book-detail-page{max-width:var(--header-max-width);margin:0 auto;padding:3.5rem 1.5rem 4.5rem}.book-breadcrumb{color:#6b7280;margin-bottom:1.4rem;font-size:.78rem}.book-breadcrumb ol{flex-wrap:wrap;gap:.35rem;margin:0;padding:0;list-style:none;display:flex}.book-breadcrumb li:after{content:"›";color:#9ca3af;margin-left:.35rem}.book-breadcrumb li:last-child:after{content:"";margin:0}.book-breadcrumb a{color:#4b5563;text-decoration:none}.book-breadcrumb a:hover,.book-breadcrumb a:focus-visible{color:var(--accent);text-decoration:underline}.book-detail-hero{background:radial-gradient(circle at 0 0,#eef2ff 0,#f9fafb 40%,#fff 100%);border:1px solid #e5e7eb;border-radius:1.75rem;padding:1.8rem 1.7rem 2.1rem;box-shadow:0 18px 40px #0f172a14}.book-detail-header{max-width:40rem;margin-bottom:1.7rem}.book-label{color:#1e40af;letter-spacing:.09em;text-transform:uppercase;background:#eff6ff;border-radius:999px;align-items:center;gap:.45rem;padding:.2rem .65rem;font-size:.72rem;font-weight:500;display:inline-flex}.book-label-dot{background:#1d4ed8;border-radius:999px;width:.4rem;height:.4rem}.book-detail-title{letter-spacing:.02em;margin:.9rem 0 .3rem;font-size:1.9rem}.book-detail-subtitle{color:var(--muted-text);margin:0;font-size:1rem}.book-detail-author{color:#4b5563;margin:.5rem 0 0;font-size:.9rem}.book-detail-author span{font-weight:600}.book-detail-layout{flex-direction:column;gap:1.9rem;margin-top:1rem;display:flex}.book-detail-media{flex-direction:column;gap:1rem;display:flex}.book-detail-cover{background:#020617;border-radius:1.2rem;position:relative;overflow:hidden;box-shadow:0 22px 50px #0f172a59}.book-detail-cover img{width:100%;height:auto;display:block}.book-detail-badge{color:#f9fafb;letter-spacing:.14em;text-transform:uppercase;background:#0f172abf;border:1px solid #f9fafbcc;border-radius:999px;padding:.18rem .6rem;font-size:.7rem;position:absolute;top:.8rem;left:.8rem}.book-detail-meta-panel{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffc;border:1px solid #e5e7eb;border-radius:1rem;padding:.9rem 1rem 1rem}.book-detail-meta{color:#4b5563;grid-template-columns:minmax(0,1fr);gap:.25rem;margin:0 0 .8rem;font-size:.82rem;display:grid}.book-detail-meta dt{font-weight:600;display:inline}.book-detail-meta dd{margin:0;display:inline}.book-detail-meta div+div{margin-top:.1rem}.book-detail-ctas{flex-direction:column;gap:.65rem;margin-bottom:.4rem;display:flex}.book-detail-btn-main,.book-detail-btn-secondary{cursor:pointer;letter-spacing:.01em;border-radius:10px;justify-content:center;align-items:center;width:100%;padding:.85rem 1.5rem;font-size:.95rem;font-weight:600;text-decoration:none;transition:background-color .15s,transform .1s;display:inline-flex}.book-detail-btn-main{background:var(--accent);color:#fff;border:2px solid #0000}.book-detail-btn-main:hover{background:var(--accent-hover);text-decoration:none;transform:translateY(-1px)}.book-detail-btn-secondary{color:var(--text-color);border:2px solid var(--border-subtle);background:#fff}.book-detail-btn-secondary:hover{border-color:var(--accent);color:var(--accent);background:#f9fafb;text-decoration:none;transform:translateY(-1px)}.book-detail-note{color:#6b7280;margin:0;font-size:.75rem}.book-detail-content{flex-direction:column;gap:1.6rem;display:flex}.book-detail-section{background:#fff;border:1px solid #e5e7eb;border-radius:1rem;padding:1rem 1rem 1.1rem}.book-detail-section-title{margin:0 0 .5rem;font-size:.98rem;font-weight:600}.book-detail-text{color:var(--muted-text);margin:0 0 .4rem;font-size:.9rem}.book-detail-list{color:#374151;margin:.1rem 0 0;padding-left:1.1rem;font-size:.88rem}.book-detail-tags{flex-wrap:wrap;gap:.35rem;margin-top:.2rem;display:flex}.book-detail-tags span{background:#f9fafb;border:1px solid #94a3b8b3;border-radius:999px;padding:.22rem .7rem;font-size:.78rem}.book-detail-toc{color:#374151;font-size:.86rem}.book-toc-table{border-collapse:collapse;width:100%;font-size:.86rem}.book-toc-table thead th{text-align:left;color:#111827;text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid #e5e7eb;padding:.6rem .8rem;font-size:.78rem;font-weight:600}.book-toc-table tbody tr{border-bottom:1px solid #f3f4f6;transition:background-color .15s}.book-toc-table tbody tr:hover{background-color:#f9fafb}.book-toc-table td{vertical-align:top;padding:.55rem .8rem}.book-toc-table td:first-child{white-space:nowrap;color:#6b7280;width:7rem;font-weight:500}.book-toc-table td:last-child{color:#374151}.book-detail-toc-note{color:#6b7280;margin-top:.6rem;font-size:.78rem}@media (min-width:768px){.book-detail-page{padding-inline:1.9rem}.book-detail-layout{flex-direction:row;align-items:flex-start;gap:2.1rem}.book-detail-media{flex:0 0 280px}.book-detail-content{flex:1}.book-detail-ctas{flex-direction:row}.book-detail-btn-main,.book-detail-btn-secondary{width:auto;padding:.9rem 1.8rem}}@media (min-width:1024px){.book-detail-page{padding-top:4rem;padding-bottom:5rem}.book-detail-hero{padding-inline:2.1rem}.book-detail-title{font-size:2.1rem}}.book-detail-section--tabs{padding-top:1.1rem}.book-toc-tabs{grid-template-columns:auto;gap:.7rem;margin-top:.3rem;display:grid}.book-toc-radio{opacity:0;pointer-events:none;position:absolute}.book-toc-tab{letter-spacing:.08em;text-transform:uppercase;color:#4b5563;cursor:pointer;background:#f9fafb;border:1px solid #d1d5db;border-radius:999px;justify-content:center;align-items:center;padding:.4rem .9rem;font-size:.8rem;font-weight:500;transition:background .18s,color .18s,border-color .18s,box-shadow .18s;display:inline-flex}#book-toc-foundation:checked+.book-toc-tab,#book-toc-build:checked+.book-toc-tab,#book-toc-ops:checked+.book-toc-tab{color:#f9fafb;background:#111827;border-color:#111827;box-shadow:0 8px 18px #0f172a4d}.book-toc-panels{background:#fff;border:1px solid #e5e7eb;border-radius:.95rem;padding:.85rem .9rem}.book-toc-panel{color:#374151;font-size:.86rem;display:none}.book-toc-panel ul{margin:0;padding-left:0;list-style:none}#book-toc-foundation:checked~.book-toc-panels #book-toc-panel-foundation,#book-toc-build:checked~.book-toc-panels #book-toc-panel-build,#book-toc-ops:checked~.book-toc-panels #book-toc-panel-ops{display:block}@media (min-width:640px){.book-toc-tabs{grid-template-columns:auto 1fr;align-items:flex-start;gap:.75rem .9rem}.book-toc-tab{margin-right:.4rem}#book-toc-foundation+.book-toc-tab,#book-toc-build+.book-toc-tab,#book-toc-ops+.book-toc-tab{display:inline-flex}}.blog-page{max-width:var(--header-max-width);margin:0 auto;padding:3.5rem 1.5rem 4.5rem}.blog-header{text-align:center;max-width:44rem;margin:0 auto 2.5rem}.blog-label{color:#1e40af;letter-spacing:.09em;text-transform:uppercase;background:#eff6ff;border-radius:999px;align-items:center;gap:.4rem;padding:.2rem .65rem;font-size:.72rem;font-weight:500;display:inline-flex}.blog-label-dot{background:#1d4ed8;border-radius:999px;width:.4rem;height:.4rem}.blog-title{letter-spacing:.02em;margin:.9rem 0 .5rem;font-size:1.9rem;line-height:1.3}.blog-lead{color:var(--muted-text);margin:0;font-size:1rem}.blog-topics{margin-bottom:2.1rem}.blog-topic-list{flex-wrap:wrap;justify-content:center;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.blog-topic-chip{letter-spacing:.05em;text-transform:uppercase;color:#4b5563;cursor:pointer;background:#f9fafb;border:1px solid #d1d5db;border-radius:999px;padding:.3rem .8rem;font-size:.8rem;font-weight:500;transition:background .18s,color .18s,border-color .18s,box-shadow .18s,transform .15s}.blog-topic-chip:hover,.blog-topic-chip:focus-visible{color:#f9fafb;background:#111827;border-color:#111827;outline:none;transform:translateY(-1px);box-shadow:0 10px 22px #0f172a4d}.blog-topic-chip--active{color:#f9fafb;background:#111827;border-color:#111827;font-weight:600}.blog-topic-chip--active:hover{background:#1f2937;border-color:#1f2937}.blog-loading,.blog-error,.blog-empty-state{text-align:center;margin:2rem 0;padding:3rem 1.5rem}.blog-loading p{color:var(--muted-text);font-size:1rem}.blog-error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:.75rem}.blog-error p{margin-bottom:1rem;font-weight:500}.blog-error .btn{color:#fff;background:#dc2626;border:none}.blog-error .btn:hover{background:#b91c1c}.blog-empty-state{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.75rem}.blog-empty-icon{margin-bottom:1rem;font-size:3rem}.blog-empty-title{color:#111827;margin:0 0 .5rem;font-size:1.5rem;font-weight:600}.blog-empty-description{color:var(--muted-text);max-width:500px;margin:0 auto 1.5rem;font-size:1rem}.blog-section-header{margin-bottom:1rem}.blog-section-header--row{flex-direction:column;gap:.4rem;display:flex}.blog-section-title{letter-spacing:.04em;text-transform:uppercase;margin:0;font-size:1.05rem;font-weight:600}.blog-section-subtitle{color:var(--muted-text);margin:0;font-size:.9rem}.blog-featured{margin-bottom:2.5rem}.blog-feature-card-link{color:inherit;text-decoration:none;transition:transform .2s;display:block}.blog-feature-card-link:hover{transform:translateY(-2px)}.blog-feature-card{border:1px solid var(--border-subtle);color:#e5e7eb;background:radial-gradient(circle at 0 0,#0b1120 0,#020617 40%,#000 100%);border-radius:1.3rem;padding:1.5rem 1.4rem 1.6rem;box-shadow:0 22px 60px #0f172ae6}.blog-feature-header{margin-bottom:.7rem}.blog-feature-meta{color:#9ca3af;flex-wrap:wrap;align-items:center;gap:.35rem;font-size:.78rem;display:flex}.blog-feature-meta time{font-variant-numeric:tabular-nums}.blog-feature-tag{letter-spacing:.12em;text-transform:uppercase;background:#0f172a99;border:1px solid #f8fafc99;border-radius:999px;padding:.1rem .6rem;font-size:.72rem}.blog-feature-title{margin:.3rem 0 0;font-size:1.25rem;line-height:1.45}.blog-feature-excerpt{color:#d1d5db;margin:.35rem 0 .75rem;font-size:.95rem}.blog-feature-link{color:#7dd3fc;align-items:center;gap:.3rem;font-size:.88rem;font-weight:500;text-decoration:none;display:inline-flex}.blog-feature-link:after{content:"↗";font-size:.8rem;transition:transform .18s}.blog-feature-link:hover,.blog-feature-link:focus-visible{text-decoration:underline}.blog-feature-link:hover:after,.blog-feature-link:focus-visible:after{transform:translate(2px)translateY(-1px)}.blog-list-section{margin-bottom:2.8rem}.blog-list{grid-template-columns:minmax(0,1fr);gap:1.3rem;display:grid}.blog-card-wrapper{color:inherit;text-decoration:none;display:block}.blog-card{border:1px solid var(--border-subtle);background:#fff;border-radius:1.05rem;padding:1.1rem 1.1rem 1.2rem;transition:transform .16s,box-shadow .2s,border-color .18s;box-shadow:0 14px 32px #0f172a0f}.blog-card-wrapper:hover .blog-card,.blog-card-wrapper:focus .blog-card{border-color:var(--accent-soft);transform:translateY(-4px);box-shadow:0 18px 40px #0f172a1f}.blog-card-header{margin-bottom:.4rem}.blog-card-meta{color:#6b7280;flex-wrap:wrap;align-items:center;gap:.35rem;font-size:.78rem;display:flex}.blog-card-meta time{font-variant-numeric:tabular-nums}.blog-card-tag{letter-spacing:.09em;text-transform:uppercase;background:#f3f4f6;border:1px solid #94a3b899;border-radius:999px;padding:.1rem .55rem;font-size:.72rem}.blog-card-title{margin:.25rem 0 0;font-size:1rem;font-weight:600}.blog-card-excerpt{color:var(--muted-text);margin:.3rem 0 .65rem;font-size:.9rem}.blog-card-link{color:var(--accent);font-size:.86rem;font-weight:500;text-decoration:none}.blog-card-link:hover,.blog-card-link:focus-visible{text-decoration:underline}.blog-newsletter{margin-top:1rem}.blog-newsletter-inner{background:radial-gradient(circle at 0 0,#eef2ff 0,#f9fafb 40%,#fff 100%);border:1px solid #e5e7eb;border-radius:1.4rem;flex-direction:column;gap:1rem;padding:1.4rem 1.3rem 1.5rem;display:flex}.blog-newsletter-form{flex-direction:column;gap:.6rem;display:flex}.blog-newsletter-fields{flex-direction:column;gap:.6rem;width:100%;display:flex}.blog-newsletter-field{flex:1}.blog-newsletter-form input[type=email],.blog-newsletter-form input[type=text]{width:100%;font:inherit;border:1px solid var(--border-subtle);color:var(--text-color);background:#f9fafb;border-radius:.75rem;outline:none;padding:.55rem .6rem;transition:border-color .16s,box-shadow .16s,background .16s}.blog-newsletter-form input[type=email]:focus-visible,.blog-newsletter-form input[type=text]:focus-visible{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-soft);background:#fff}.blog-newsletter-form input[type=email]:disabled,.blog-newsletter-form input[type=text]:disabled,.blog-newsletter-form button:disabled{opacity:.6;cursor:not-allowed}@media (min-width:640px){.blog-page{padding-inline:1.75rem}.blog-feature-card{padding-inline:1.6rem}.blog-list{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:900px){.blog-list{grid-template-columns:repeat(3,minmax(0,1fr))}.blog-newsletter-inner{flex-direction:row;justify-content:space-between;align-items:center;gap:1.5rem}.blog-newsletter-form{flex-direction:row;align-items:flex-end;max-width:32rem}.blog-newsletter-fields{flex-direction:row;gap:.6rem}.blog-newsletter-form input[type=email],.blog-newsletter-form input[type=text]{flex:1}}@media (min-width:1024px){.blog-page{padding-top:4rem;padding-bottom:5rem}}.blog-more{justify-content:center;margin-top:.8rem;display:flex}.blog-more-btn{border:1px solid var(--border-subtle);color:#111827;background:#fff;border-radius:999px;padding-inline:1.3rem;font-size:.88rem;font-weight:500;transition:background .18s,color .18s,box-shadow .2s,transform .15s}.blog-more-btn:hover,.blog-more-btn:focus-visible{color:#f9fafb;background:#111827;transform:translateY(-1px);box-shadow:0 12px 26px #0f172a2e}.post-page{max-width:var(--header-max-width);margin:0 auto;padding:3.5rem 1.5rem 4.5rem}.post-breadcrumb{color:#6b7280;margin-bottom:1.4rem;font-size:.78rem}.post-breadcrumb ol{flex-wrap:wrap;gap:.35rem;margin:0;padding:0;list-style:none;display:flex}.post-breadcrumb li:after{content:"›";color:#9ca3af;margin-left:.35rem}.post-breadcrumb li:last-child:after{content:"";margin:0}.post-breadcrumb a{color:#4b5563;text-decoration:none}.post-breadcrumb a:hover,.post-breadcrumb a:focus-visible{color:var(--accent);text-decoration:underline}.post-header{max-width:46rem;margin-bottom:1.9rem}.post-label{color:#1e40af;letter-spacing:.09em;text-transform:uppercase;background:#eff6ff;border-radius:999px;align-items:center;gap:.4rem;padding:.18rem .65rem;font-size:.72rem;font-weight:500;display:inline-flex}.post-label-dot{background:#1d4ed8;border-radius:999px;width:.4rem;height:.4rem}.post-title{letter-spacing:.02em;margin:.9rem 0 .5rem;font-size:1.9rem;line-height:1.3}.post-meta{color:#6b7280;flex-direction:column;gap:.4rem;font-size:.82rem;display:flex}.post-meta-primary{flex-wrap:wrap;align-items:center;gap:.35rem;display:flex}.post-meta-author span{font-weight:600}.post-meta-date{font-variant-numeric:tabular-nums}.post-meta-tags{flex-wrap:wrap;gap:.35rem;display:flex}.post-meta-tags span{letter-spacing:.09em;text-transform:uppercase;background:#f3f4f6;border:1px solid #94a3b8b3;border-radius:999px;padding:.13rem .55rem;font-size:.72rem}.post-layout{flex-direction:column;gap:1.6rem;margin-top:1rem;display:flex}.post-aside{order:-1}.post-aside-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:1.1rem;padding:.85rem .9rem .95rem}.post-aside-title{margin:0 0 .4rem;font-size:.9rem;font-weight:600}.post-toc ul{color:#4b5563;margin:0;padding-left:0;font-size:.85rem;list-style:none}.post-toc li+li{margin-top:.25rem}.post-toc a{color:inherit;text-decoration:none}.post-toc a:hover,.post-toc a:focus-visible{color:var(--accent);text-decoration:underline}.post-content{color:var(--text-color);background:#fff;border:1px solid #e5e7eb;border-radius:1.4rem;padding:1.4rem 1.3rem 1.6rem;font-size:.95rem;box-shadow:0 18px 40px #0f172a0f}.post-intro{color:#111827;margin-top:0;margin-bottom:.7rem;font-size:1rem}.post-content p{margin:0 0 .7rem;line-height:1.7}.post-section{margin-top:1.4rem}.post-section h2{margin:0 0 .4rem;font-size:1.05rem;font-weight:600}.post-section ul,.post-section ol{margin:.1rem 0 .7rem;padding-left:1.15rem}.post-section li+li{margin-top:.2rem}.post-quote{border-left:3px solid var(--accent-soft);color:#374151;background:#f9fafb;border-radius:.5rem;margin:.8rem 0;padding:.7rem .9rem;font-style:italic}.post-diagram{margin:.8rem 0 .9rem}.post-diagram-row{flex-wrap:wrap;justify-content:flex-start;align-items:center;gap:.3rem;display:flex}.post-diagram-node{background:#f9fafb;border:1px solid #d1d5db;border-radius:999px;padding:.35rem .7rem;font-size:.8rem;font-weight:500}.post-diagram-arrow{color:#6b7280;font-size:.85rem}.post-code-inline{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:.35rem;padding:.1rem .35rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.82em}.post-footer{border-top:1px solid #e5e7eb;flex-direction:column;gap:.6rem;margin-top:1.6rem;padding-top:1rem;display:flex}.post-footer-tags{flex-wrap:wrap;gap:.35rem;display:flex}.post-footer-tags span{background:#f9fafb;border:1px solid #94a3b8b3;border-radius:999px;padding:.18rem .6rem;font-size:.75rem}.post-footer-meta p{color:#4b5563;margin:0;font-size:.86rem}.post-nav{grid-template-columns:minmax(0,1fr);gap:.9rem;margin-top:2.2rem;display:grid}.post-nav-link{color:#111827;background:#f9fafb;border:1px solid #e5e7eb;border-radius:1rem;flex-direction:column;gap:.15rem;padding:.85rem .95rem;text-decoration:none;transition:background .18s,border-color .18s,box-shadow .2s,transform .16s;display:flex}.post-nav-label{text-transform:uppercase;letter-spacing:.09em;color:#6b7280;font-size:.78rem}.post-nav-title{font-size:.9rem;font-weight:500}.post-nav-link:hover,.post-nav-link:focus-visible{color:#f9fafb;background:#111827;border-color:#111827;transform:translateY(-2px);box-shadow:0 14px 30px #0f172a38}@media (min-width:640px){.post-page{padding-inline:1.75rem}.post-content{padding-inline:1.6rem}}@media (min-width:900px){.post-layout{flex-direction:row;align-items:flex-start;gap:2.2rem}.post-aside{flex:0 0 230px;order:0}.post-content{flex:1}.post-nav{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:1024px){.post-page{padding-top:4rem;padding-bottom:5rem}.post-title{font-size:2.1rem}.post-content{padding-inline:1.9rem}}.about-page{max-width:var(--header-max-width);margin:0 auto;padding:3.5rem 1.5rem 4.5rem}.about-header{text-align:center;max-width:44rem;margin:0 auto 2.5rem}.about-label{color:#1e40af;letter-spacing:.09em;text-transform:uppercase;background:#eff6ff;border-radius:999px;align-items:center;gap:.4rem;padding:.2rem .65rem;font-size:.72rem;font-weight:500;display:inline-flex}.about-label-dot{background:#1d4ed8;border-radius:999px;width:.4rem;height:.4rem}.about-title{letter-spacing:.06em;text-transform:uppercase;margin:.9rem 0 .5rem;font-size:1.9rem}.about-lead{color:var(--muted-text);margin:0;font-size:1rem}.about-section-header{text-align:center;margin-bottom:1.5rem}.about-section-heading{letter-spacing:.04em;text-transform:uppercase;margin:0;font-size:1.05rem;font-weight:600}.about-section-subtitle{max-width:32rem;color:var(--muted-text);margin:.3rem auto 0;font-size:.9rem}.about-bio{grid-template-columns:minmax(0,1fr);gap:1.4rem;margin-bottom:2.8rem;display:grid}.about-bio-text,.about-bio-points{background:#fff;border:1px solid #e5e7eb;border-radius:1.2rem;padding:1.1rem 1.2rem 1.2rem;box-shadow:0 14px 32px #0f172a0f}.about-bio-text p,.about-bio-points p{color:var(--text-color);margin:0 0 .7rem;font-size:.92rem}.about-bio-points ul{color:#374151;margin:.2rem 0 0;padding-left:1.15rem;font-size:.9rem}.about-bio-points li+li{margin-top:.2rem}.about-expertise{margin-bottom:3rem}.about-grid{grid-template-columns:minmax(0,1fr);gap:1rem;display:grid}.about-card{background:#fff;border:1px solid #e5e7eb;border-radius:1.1rem;padding:1rem 1rem 1.1rem;transition:transform .15s,box-shadow .2s,border-color .18s;box-shadow:0 12px 28px #0f172a0d}.about-card:hover,.about-card:focus-within{border-color:var(--accent-soft);transform:translateY(-3px);box-shadow:0 18px 40px #0f172a1a}.about-card h3{margin:0 0 .4rem;font-size:.98rem;font-weight:600}.about-card ul{color:#4b5563;margin:0;padding-left:0;font-size:.88rem;list-style:none}.about-card li+li{margin-top:.18rem}.about-certifications{margin-bottom:3.1rem}.about-cert-grid{grid-template-columns:minmax(0,1fr);gap:1rem;display:grid}.cert-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:1.1rem;padding:.9rem 1rem 1rem}.cert-card h3{margin:0 0 .4rem;font-size:.95rem;font-weight:600}.cert-card ul{color:#4b5563;margin:0;padding-left:0;font-size:.88rem;list-style:none}.cert-card li+li{margin-top:.18rem}.about-cta{margin-top:.5rem}.about-cta-inner{background:radial-gradient(circle at 0 0,#eef2ff 0,#f9fafb 40%,#fff 100%);border:1px solid #e5e7eb;border-radius:1.4rem;flex-direction:column;gap:1rem;padding:1.4rem 1.25rem 1.6rem;display:flex}.about-cta-actions{flex-direction:column;gap:.6rem;display:flex}.about-cta-actions .btn{justify-content:center;width:100%}@media (min-width:640px){.about-page{padding-inline:1.75rem}.about-grid,.about-cert-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width:900px){.about-bio{grid-template-columns:repeat(2,minmax(0,1fr))}.about-cta-inner{flex-direction:row;justify-content:space-between;align-items:center}.about-cta-actions{flex-direction:row;gap:.75rem}.about-cta-actions .btn{width:auto}}@media (min-width:1024px){.about-page{padding-top:4rem;padding-bottom:5rem}}.projects-page{max-width:var(--header-max-width);background:radial-gradient(circle at 0 0,#eef2ff 0,#f9fafb 40%,#fff 100%);margin:0 auto;padding:3.75rem 1.5rem 4.75rem}.projects-page-header{text-align:center;max-width:44rem;margin:0 auto 2.25rem}.projects-page-label{color:#1d4ed8;letter-spacing:.09em;text-transform:uppercase;background:#e0ecff;border-radius:999px;align-items:center;gap:.4rem;padding:.2rem .65rem;font-size:.72rem;font-weight:500;display:inline-flex}.projects-page-label-dot{background:#1d4ed8;border-radius:999px;width:.4rem;height:.4rem}.projects-page-title{letter-spacing:.06em;text-transform:uppercase;margin:.9rem 0 .5rem;font-size:1.9rem}.projects-page-lead{color:var(--muted-text);margin:0;font-size:1rem}.projects-page-topics{margin:1.6rem auto 2.2rem}.projects-page-topic-list{flex-wrap:wrap;justify-content:center;gap:.6rem;margin:0;padding:0;list-style:none;display:flex}.projects-page-topic-chip{letter-spacing:.08em;text-transform:uppercase;color:#1e3a8a;background:#eef2ff;border:1px solid #c7d2fe;border-radius:999px;padding:.25rem .9rem;font-size:.78rem;font-weight:500}.projects-page-grid-section{position:relative}.projects-page-grid{grid-template-columns:minmax(0,1fr);gap:1.5rem;display:grid}.projects-page-card{border:1px solid var(--border-subtle,#e5e7eb);background:#fff;border-radius:1.25rem;flex-direction:column;gap:.45rem;padding:1.2rem 1.2rem 1.35rem;transition:transform .16s,box-shadow .22s,border-color .18s,background .18s;display:flex;position:relative;overflow:hidden;box-shadow:0 18px 40px #0f172a0f}.projects-page-card:before{content:"";opacity:0;pointer-events:none;background:radial-gradient(circle at 100% 0,#38bdf81f,#0000 55%);transition:opacity .22s;position:absolute;inset:-40%}.projects-page-card:hover,.projects-page-card:focus-within{border-color:var(--accent-soft);background:linear-gradient(135deg,#f9fafb,#fff);transform:translateY(-4px);box-shadow:0 22px 52px #0f172a24}.projects-page-card:hover:before,.projects-page-card:focus-within:before{opacity:1}.projects-page-card-header{margin-bottom:.1rem}.projects-page-card-meta{color:#6b7280;margin:0 0 .2rem;font-size:.78rem}.projects-page-card-tag{letter-spacing:.09em;text-transform:uppercase;background:#f3f4f6;border:1px solid #94a3b8b3;border-radius:999px;align-items:center;gap:.3rem;padding:.13rem .7rem;font-size:.72rem;display:inline-flex}.projects-page-card-tag:before{content:"";background:#22c55e;border-radius:999px;width:.4rem;height:.4rem}.projects-page-card-title{margin:0;font-size:1.02rem;font-weight:600}.projects-page-card-excerpt{color:var(--muted-text);margin:.25rem 0 .45rem;font-size:.9rem}.projects-page-card-tech{color:#4b5563;flex-wrap:wrap;gap:.3rem;margin:0 0 .55rem;font-size:.78rem;display:flex}.projects-page-card-tech span{background:#f9fafb;border:1px solid #d1d5dbe6;border-radius:999px;padding:.15rem .55rem}.projects-page-card-link{color:var(--accent);align-items:center;gap:.25rem;margin-top:auto;font-size:.86rem;font-weight:500;text-decoration:none;display:inline-flex}.projects-page-card-link:after{content:"↗";font-size:.8rem;transition:transform .16s}.projects-page-card-link:hover,.projects-page-card-link:focus-visible{text-decoration:underline}.projects-page-card-link:hover:after,.projects-page-card-link:focus-visible:after{transform:translate(2px)translateY(-1px)}.projects-page-card--featured{color:#e5e7eb;background:radial-gradient(circle at 0 0,#0f172a 0,#020617 55% 100%);border-width:1.5px;box-shadow:0 26px 60px #0f172ad9}.projects-page-card--featured .projects-page-card-meta{color:#9ca3af}.projects-page-card--featured .projects-page-card-excerpt{color:#d1d5db}.projects-page-card--featured .projects-page-card-tech span{color:#e5e7eb;background:#0f172ae6;border-color:#94a3b8e6}@media (min-width:640px){.projects-page{padding-inline:1.75rem}.projects-page-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:900px){.projects-page-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.projects-page-grid>.projects-page-card--featured{grid-column:span 2}}@media (min-width:1024px){.projects-page{padding-top:4rem;padding-bottom:5rem}}.case-study-detail{max-width:820px;margin:0 auto;padding:2.5rem 1.5rem 4rem}.case-study-back{margin-bottom:2rem}.case-study-back-link{color:#6b7280;align-items:center;gap:.35rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:color .2s;display:inline-flex}.case-study-back-link:hover{color:var(--accent)}.case-study-header{border-bottom:2px solid #e5e7eb;margin-bottom:3rem;padding-bottom:2.5rem}.case-study-cover{border-radius:12px;margin-bottom:3rem;overflow:hidden;box-shadow:0 4px 24px #0000001f}.case-study-cover-img{object-fit:cover;width:100%;height:auto;display:block}.case-study-meta{color:#6b7280;align-items:center;gap:.75rem;margin-bottom:1.25rem;font-size:.875rem;display:flex}.case-study-tag{color:#fff;text-transform:uppercase;letter-spacing:.05em;background:#10b981;border-radius:4px;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.case-study-title{color:#111827;margin-bottom:1rem;font-size:2.5rem;font-weight:800;line-height:1.2}.case-study-excerpt{color:#4b5563;margin-bottom:1.5rem;font-size:1.15rem;line-height:1.65}.case-study-tech-list{flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem;display:flex}.case-study-tech-pill{color:#374151;background:#f9fafb;border:1.5px solid #d1d5db;border-radius:999px;padding:.35rem .85rem;font-size:.8rem;font-weight:500;display:inline-block}.case-study-github-link{color:#111827;border:1.5px solid #d1d5db;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.case-study-github-link:hover{color:#fff;background:#111827;border-color:#111827}.case-study-content{color:#1f2937;font-size:1.05rem;line-height:1.75}.case-study-content h2{color:#111827;border-bottom:1px solid #e5e7eb;margin-top:2.5rem;margin-bottom:1rem;padding-bottom:.5rem;font-size:1.6rem;font-weight:700}.case-study-content h3{color:#111827;margin-top:2rem;margin-bottom:.75rem;font-size:1.25rem;font-weight:600}.case-study-content p{margin-bottom:1.25rem}.case-study-content ul,.case-study-content ol{margin-bottom:1.25rem;padding-left:1.5rem}.case-study-content li{margin-bottom:.5rem}.case-study-content strong{color:#111827;font-weight:600}.case-study-content a{color:var(--accent);text-underline-offset:2px;text-decoration:underline}.case-study-content a:hover{color:#1e40af}.case-study-content pre{color:#e2e8f0;background:#0f172a;border-radius:10px;margin:1.5rem 0;padding:1.25rem 1.5rem;font-size:.85rem;line-height:1.6;overflow-x:auto}.case-study-content code{font-family:JetBrains Mono,Fira Code,monospace;font-size:.88em}.case-study-content :not(pre)>code{color:#0f172a;background:#f1f5f9;border-radius:4px;padding:.15rem .4rem;font-size:.85em}.case-study-content blockquote{border-left:4px solid var(--accent);color:#374151;background:#f8fafc;border-radius:0 8px 8px 0;margin:1.5rem 0;padding:.75rem 1.25rem}.case-study-content img{border-radius:8px;max-width:100%;margin:1.5rem 0}.case-study-content table{border-collapse:separate;border-spacing:0;border:1px solid #e2e8f0;border-radius:10px;width:100%;margin:1.75rem 0;font-size:.92rem;overflow:hidden;box-shadow:0 1px 4px #0000000f}.case-study-content thead{background:linear-gradient(135deg,#0f172a 0%,#1e293b 100%)}.case-study-content thead th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:#e2e8f0;white-space:nowrap;border-bottom:2px solid #334155;padding:.85rem 1.1rem;font-size:.82rem;font-weight:600}.case-study-content thead th:not(:last-child){border-right:1px solid #334155}.case-study-content tbody tr{transition:background-color .15s}.case-study-content tbody tr:nth-child(2n){background-color:#f8fafc}.case-study-content tbody tr:hover{background-color:#eff6ff}.case-study-content tbody td{color:#334155;vertical-align:top;border-bottom:1px solid #e2e8f0;padding:.75rem 1.1rem;line-height:1.55}.case-study-content tbody td:not(:last-child){border-right:1px solid #f1f5f9}.case-study-content tbody tr:last-child td{border-bottom:none}.case-study-content tbody td strong{color:#0f172a;font-weight:600}.case-study-content tbody td code{color:#0f172a;background:#f1f5f9;border-radius:4px;padding:.15rem .4rem;font-size:.85em}@media (max-width:768px){.case-study-content table{-webkit-overflow-scrolling:touch;font-size:.85rem;display:block;overflow-x:auto}.case-study-content thead th,.case-study-content tbody td{padding:.6rem .8rem}}.case-study-footer{border-top:2px solid #e5e7eb;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-top:4rem;padding-top:2rem;display:flex}@media (max-width:768px){.case-study-detail{padding:1.5rem 1rem 3rem}.case-study-title{font-size:1.75rem}.case-study-excerpt,.case-study-content{font-size:1rem}.case-study-content h2{font-size:1.35rem}.case-study-footer{text-align:center;flex-direction:column;align-items:stretch}}.project-page{max-width:var(--header-max-width);background:radial-gradient(circle at 0 0,#eef2ff 0,#f9fafb 40%,#fff 100%);margin:0 auto;padding:3.75rem 1.5rem 4.75rem}.project-breadcrumb{color:#6b7280;margin-bottom:1.4rem;font-size:.78rem}.project-breadcrumb ol{flex-wrap:wrap;gap:.35rem;margin:0;padding:0;list-style:none;display:flex}.project-breadcrumb li:after{content:"›";color:#9ca3af;margin-left:.35rem}.project-breadcrumb li:last-child:after{content:"";margin:0}.project-breadcrumb a{color:#4b5563;text-decoration:none}.project-breadcrumb a:hover,.project-breadcrumb a:focus-visible{color:var(--accent);text-decoration:underline}.project-label{color:#1d4ed8;letter-spacing:.09em;text-transform:uppercase;background:#e0ecff;border-radius:999px;align-items:center;gap:.4rem;padding:.2rem .7rem;font-size:.72rem;font-weight:500;display:inline-flex}.project-label-dot{background:#1d4ed8;border-radius:999px;width:.4rem;height:.4rem}.project-title{letter-spacing:.02em;margin:.9rem 0 .6rem;font-size:1.95rem;line-height:1.3}.project-page .project-header{text-align:center;max-width:48rem;margin:0 auto 2.1rem}.project-page .project-meta{color:#6b7280;flex-wrap:wrap;justify-content:center;gap:1.1rem;font-size:.82rem;display:flex}.project-meta>div{flex-direction:column;gap:.1rem;display:flex}.project-meta dt{letter-spacing:.09em;text-transform:uppercase;color:#9ca3af;font-size:.75rem}.project-meta dd{color:#374151;margin:0;font-weight:500}.project-layout{flex-direction:column;gap:1.75rem;margin-top:1.1rem;display:flex}.project-aside{order:-1}.project-aside-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:1.15rem;margin-bottom:.8rem;padding:.95rem 1rem 1.05rem;box-shadow:0 12px 26px #0f172a0f}.project-aside-title{margin:0 0 .45rem;font-size:.9rem;font-weight:600}.project-aside-list{color:#4b5563;margin:0;padding-left:0;font-size:.85rem;list-style:none}.project-aside-list li+li{margin-top:.25rem}.admin-layout{background:#f9fafb;min-height:100vh;display:flex}.admin-sidebar{z-index:40;background:#fff;border-right:1px solid #e5e7eb;flex-direction:column;width:260px;transition:transform .3s;display:flex;position:fixed;top:0;bottom:0;left:0}.admin-sidebar-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:1.5rem 1.25rem;display:flex}.admin-sidebar-title{color:var(--accent);margin:0;font-size:1.25rem;font-weight:700}.admin-sidebar-close{cursor:pointer;color:#6b7280;background:0 0;border:none;padding:.25rem;font-size:1.5rem;display:none}.admin-sidebar-nav{flex:1;padding:1rem .75rem;overflow-y:auto}.admin-nav-list{flex-direction:column;gap:.25rem;margin:0;padding:0;list-style:none;display:flex}.admin-nav-link{color:#4b5563;border-radius:.5rem;align-items:center;gap:.75rem;padding:.75rem 1rem;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.admin-nav-link:hover{color:var(--accent);background:#f3f4f6}.admin-nav-link.active{color:var(--accent);background:#eff6ff;font-weight:600}.admin-nav-icon{text-align:center;width:1.5rem;font-size:1.25rem}.admin-nav-label{font-size:.95rem}.admin-sidebar-footer{border-top:1px solid #e5e7eb;padding:1rem}.admin-user-info{align-items:center;gap:.75rem;margin-bottom:.5rem;padding:.75rem;display:flex}.admin-user-avatar{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;font-size:1rem;font-weight:600;display:flex}.admin-user-details{flex:1;min-width:0}.admin-user-email{color:#374151;text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:.875rem;overflow:hidden}.admin-logout-btn{color:#374151;cursor:pointer;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:.5rem;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.625rem 1rem;font-weight:500;transition:all .2s;display:flex}.admin-logout-btn:hover{background:#e5e7eb;border-color:#d1d5db}.admin-main{flex-direction:column;flex:1;min-height:100vh;margin-left:260px;display:flex}.admin-header{z-index:10;background:#fff;border-bottom:1px solid #e5e7eb;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex;position:sticky;top:0}.admin-menu-btn{cursor:pointer;color:#374151;background:0 0;border:none;padding:.5rem;display:none}.admin-header-title h2{color:#111827;margin:0;font-size:1.5rem;font-weight:700}.admin-header-actions{margin-left:auto}.admin-view-site-btn{background:var(--accent);color:#fff;border-radius:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.admin-view-site-btn:hover{background:var(--accent-hover)}.admin-content{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:2rem 1.5rem}.admin-posts-page{max-width:1600px;margin:0 auto}.admin-loading{flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:100vh;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.admin-card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.admin-card-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.admin-card-title{color:#111827;margin:0;font-size:1.25rem;font-weight:600}.admin-card-actions{gap:.5rem;display:flex}.admin-btn{cursor:pointer;border:1px solid #0000;border-radius:.5rem;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.admin-btn-primary{background:var(--accent);color:#fff}.admin-btn-primary:hover{background:var(--accent-hover)}.admin-btn-secondary{color:#374151;background:#fff;border-color:#d1d5db}.admin-btn-secondary:hover{background:#f9fafb}.admin-btn-danger{color:#fff;background:#dc2626}.admin-btn-danger:hover{background:#b91c1c}@media (max-width:768px){.admin-sidebar{transform:translate(-100%)}.admin-sidebar.open{transform:translate(0)}.admin-sidebar-close{display:block}.admin-sidebar-overlay{z-index:30;background:#00000080;position:fixed;inset:0}.admin-main{margin-left:0}.admin-menu-btn{display:block}.admin-content{padding:1.5rem 1rem}}.admin-dashboard-header{margin-bottom:2rem}.admin-dashboard-title{color:#111827;margin:0 0 .5rem;font-size:2rem;font-weight:700}.admin-dashboard-subtitle{color:#6b7280;margin:0;font-size:1rem}.admin-stats-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2.5rem;display:grid}.admin-stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;align-items:center;gap:1rem;padding:1.5rem;display:flex;box-shadow:0 1px 3px #0000001a}.admin-stat-icon{background:#f3f4f6;border-radius:.75rem;justify-content:center;align-items:center;width:3.5rem;height:3.5rem;font-size:2.5rem;display:flex}.admin-stat-content{flex:1}.admin-stat-label{color:#6b7280;margin:0 0 .25rem;font-size:.875rem;font-weight:500}.admin-stat-value{color:#111827;margin:0;font-size:2rem;font-weight:700}.admin-section-title{color:#111827;margin:0 0 1.5rem;font-size:1.5rem;font-weight:600}.admin-action-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;display:grid}.admin-action-card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1.5rem;text-decoration:none;transition:all .2s;box-shadow:0 1px 3px #0000001a}.admin-action-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.admin-action-icon{margin-bottom:1rem;font-size:2rem;display:block}.admin-action-title{color:#111827;margin:0 0 .5rem;font-size:1.125rem;font-weight:600}.admin-action-description{color:#6b7280;margin:0;font-size:.875rem}.admin-page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem;display:flex}.admin-page-title{color:#111827;margin:0 0 .5rem;font-size:2rem;font-weight:700}.admin-page-subtitle{color:#6b7280;margin:0;font-size:1rem}.admin-filters{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;display:flex}.admin-filter-group{flex-direction:column;gap:.5rem;min-width:150px;display:flex}.admin-search-group{flex:1;min-width:250px}.admin-filter-label{color:#374151;font-size:.875rem;font-weight:500}.admin-filter-select,.admin-filter-input{color:#111827;background:#fff;border:1px solid #d1d5db;border-radius:.5rem;padding:.625rem .875rem;font-size:.875rem}.admin-filter-select:focus,.admin-filter-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #0c02591a}.admin-results-info{color:#6b7280;margin-bottom:1rem;font-size:.875rem}.admin-error-message{color:#991b1b;background:#fee2e2;border:1px solid #fecaca;border-radius:.5rem;margin-bottom:1rem;padding:1rem}.admin-empty-state{text-align:center;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:4rem 2rem}.admin-empty-icon{margin-bottom:1rem;font-size:4rem}.admin-empty-title{color:#111827;margin:0 0 .5rem;font-size:1.5rem;font-weight:600}.admin-empty-description{color:#6b7280;margin:0 0 1.5rem}.admin-table-container{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;margin-bottom:1.5rem;overflow:hidden}.admin-table{border-collapse:collapse;width:100%}.admin-table thead{background:#f9fafb;border-bottom:1px solid #e5e7eb}.admin-table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;padding:.875rem 1rem;font-size:.75rem;font-weight:600}.admin-table td{color:#374151;border-top:1px solid #e5e7eb;padding:1rem;font-size:.875rem}.admin-table tbody tr:hover{background:#f9fafb}.admin-post-title-cell{flex-direction:column;gap:.5rem;display:flex}.admin-post-title-link{color:#111827;font-weight:500;text-decoration:none}.admin-post-title-link:hover{color:var(--accent);text-decoration:underline}.admin-post-tags{flex-wrap:wrap;gap:.5rem;display:flex}.admin-post-tag{color:#6b7280;background:#f3f4f6;border-radius:.25rem;padding:.125rem .5rem;font-size:.75rem;display:inline-block}.admin-badge{border-radius:9999px;align-items:center;gap:.25rem;padding:.25rem .75rem;font-size:.75rem;font-weight:500;display:inline-flex}.admin-badge-whitepaper{color:#92400e;background:#fef3c7}.admin-badge-published{color:#065f46;background:#d1fae5}.admin-badge-draft{color:#6b7280;background:#f3f4f6}.admin-table-actions{gap:.5rem;display:flex}.admin-action-btn{cursor:pointer;opacity:.7;background:0 0;border:none;padding:.25rem;font-size:1.25rem;transition:opacity .2s}.admin-action-btn:hover{opacity:1}.admin-action-btn-delete:hover{filter:brightness(1.2)}.admin-pagination{justify-content:center;align-items:center;gap:1rem;padding:1rem;display:flex}.admin-pagination-btn{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.admin-pagination-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:#f9fafb}.admin-pagination-btn:disabled{opacity:.5;cursor:not-allowed}.admin-pagination-info{color:#6b7280;font-size:.875rem}.admin-form{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:2rem}.admin-form-group{margin-bottom:1.5rem}.admin-form-group:last-child{margin-bottom:0}.admin-form-help{color:#6b7280;margin-top:.25rem;font-size:.75rem}.admin-alert{border-radius:.5rem;padding:1rem;font-size:.875rem;line-height:1.5}.admin-alert-error{color:#991b1b;background:#fee2e2;border:1px solid #fecaca}.admin-alert-success{color:#065f46;background:#d1fae5;border:1px solid #a7f3d0}.admin-alert-warning{color:#92400e;background:#fef3c7;border:1px solid #fde68a}.admin-alert-info{color:#1e40af;background:#dbeafe;border:1px solid #bfdbfe}.admin-form-section{margin-bottom:2rem}.admin-form-section:last-child{margin-bottom:0}.admin-form-section-title{color:#111827;border-bottom:1px solid #e5e7eb;margin:0 0 1rem;padding-bottom:.75rem;font-size:1.125rem;font-weight:600}.admin-form-grid{grid-template-columns:1fr;gap:1.5rem;display:grid}.admin-form-grid-2{grid-template-columns:repeat(2,1fr)}.admin-form-field{flex-direction:column;gap:.5rem;display:flex}.admin-form-label{color:#374151;font-size:.875rem;font-weight:500}.admin-form-label-required:after{content:" *";color:#dc2626}.admin-form-input,.admin-form-textarea,.admin-form-select{color:#111827;background:#fff;border:1px solid #d1d5db;border-radius:.5rem;padding:.75rem 1rem;font-family:inherit;font-size:.875rem}.admin-form-input:focus,.admin-form-textarea:focus,.admin-form-select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #0c02591a}.admin-form-textarea{resize:vertical;min-height:120px}.admin-form-textarea-large{min-height:300px}.admin-form-hint{color:#6b7280;margin-top:.25rem;font-size:.75rem}.admin-form-error{color:#dc2626;margin-top:.25rem;font-size:.75rem}.admin-form-checkbox-wrapper{align-items:center;gap:.5rem;display:flex}.admin-form-checkbox{cursor:pointer;border:1px solid #d1d5db;border-radius:.25rem;width:1.125rem;height:1.125rem}.admin-form-actions{border-top:1px solid #e5e7eb;gap:1rem;padding-top:1.5rem;display:flex}.admin-form-field-with-button{align-items:flex-end;gap:.5rem;display:flex}.admin-form-field-with-button .admin-form-field{flex:1}.admin-auto-fill-btn{color:#374151;cursor:pointer;white-space:nowrap;background:#f3f4f6;border:1px solid #d1d5db;border-radius:.5rem;height:42px;padding:.625rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.admin-auto-fill-btn:hover{background:#e5e7eb;border-color:#9ca3af}.admin-auto-fill-btn:active{background:#d1d5db}.admin-auto-fill-btn:disabled{opacity:.5;cursor:not-allowed}.admin-auto-fill-btn.success{color:#065f46;background:#d1fae5;border-color:#6ee7b7}.admin-char-count{margin-top:.25rem;font-size:.75rem;font-weight:500}.admin-char-count-short{color:#f59e0b}.admin-char-count-good{color:#10b981}.admin-char-count-long{color:#ef4444}.rich-text-editor{background:#fff;border:1px solid #d1d5db;border-radius:8px;overflow:hidden}.rich-text-editor-toolbar{background:#f9fafb;border-bottom:1px solid #e5e7eb;flex-wrap:wrap;gap:.5rem;padding:.75rem;display:flex}.toolbar-group{border-right:1px solid #e5e7eb;gap:.25rem;padding-right:.5rem;display:flex}.toolbar-group:last-child{border-right:none}.rich-text-editor-toolbar button{color:#374151;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #d1d5db;border-radius:4px;padding:.5rem .75rem;font-size:14px;font-weight:500;transition:all .2s}.rich-text-editor-toolbar button:hover{background:#f3f4f6;border-color:#9ca3af}.rich-text-editor-toolbar button.is-active{color:#fff;background:#3b82f6;border-color:#3b82f6}.rich-text-editor-toolbar button:disabled{opacity:.5;cursor:not-allowed}.rich-text-editor-content{color:#1f2937;min-height:400px;max-height:600px;padding:1.5rem;font-size:16px;line-height:1.7;overflow-y:auto}.rich-text-editor-content:focus{outline:none}.rich-text-editor-content h2{color:#111827;margin-top:2rem;margin-bottom:1rem;font-size:1.875rem;font-weight:700}.rich-text-editor-content h3{color:#111827;margin-top:1.5rem;margin-bottom:.75rem;font-size:1.5rem;font-weight:600}.rich-text-editor-content h4{color:#111827;margin-top:1.25rem;margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.rich-text-editor-content p{margin-bottom:1rem}.rich-text-editor-content ul,.rich-text-editor-content ol{margin-bottom:1rem;margin-left:1.5rem}.rich-text-editor-content li{margin-bottom:.5rem}.rich-text-editor-content blockquote{color:#6b7280;border-left:4px solid #3b82f6;margin:1.5rem 0;padding-left:1rem;font-style:italic}.rich-text-editor-content code{color:#dc2626;background:#f3f4f6;border-radius:4px;padding:.2rem .4rem;font-family:Courier New,monospace;font-size:.9em}.rich-text-editor-content pre{color:#e2e8f0;background:#1e293b;border-radius:8px;margin:1.5rem 0;padding:1rem;overflow-x:auto}.rich-text-editor-content pre code{color:inherit;background:0 0;padding:0;font-size:14px}.rich-text-editor-content .editor-link{color:#3b82f6;text-decoration:underline}.rich-text-editor-content .editor-image{border-radius:8px;max-width:100%;height:auto;margin:1.5rem 0}.admin-loading{flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.admin-loading-spinner{border:3px solid #e5e7eb;border-top-color:var(--accent);border-radius:50%;width:3rem;height:3rem;animation:.8s linear infinite spin}.admin-loading p{color:#6b7280;font-size:.875rem}.blog-content{color:#1f2937;max-width:800px;margin:0 auto;font-size:18px;line-height:1.8}.blog-content-h1{color:#111827;margin-top:3rem;margin-bottom:1.5rem;font-size:2.5rem;font-weight:800;line-height:1.2}.blog-content-h2{color:#111827;border-bottom:2px solid #e5e7eb;margin-top:2.5rem;margin-bottom:1.25rem;padding-bottom:.5rem;font-size:2rem;font-weight:700;line-height:1.3}.blog-content-h3{color:#111827;margin-top:2rem;margin-bottom:1rem;font-size:1.5rem;font-weight:600;line-height:1.4}.blog-content-h4{color:#374151;margin-top:1.5rem;margin-bottom:.75rem;font-size:1.25rem;font-weight:600;line-height:1.4}.blog-content-h5{color:#374151;margin-top:1.25rem;margin-bottom:.5rem;font-size:1.125rem;font-weight:600}.blog-content-h6{color:#4b5563;margin-top:1rem;margin-bottom:.5rem;font-size:1rem;font-weight:600}.blog-content-p{color:#374151;margin-bottom:1.5rem}.blog-content-strong{color:#111827;font-weight:700}.blog-content-em{font-style:italic}.blog-content-link{color:#3b82f6;text-underline-offset:2px;text-decoration:underline;text-decoration-thickness:1px;transition:color .2s}.blog-content-link:hover{color:#2563eb}.blog-content-ul,.blog-content-ol{margin-bottom:1.5rem;margin-left:2rem}.blog-content-ul{list-style-type:disc}.blog-content-ol{list-style-type:decimal}.blog-content-li{margin-bottom:.75rem;padding-left:.5rem}.blog-content-li::marker{color:#3b82f6;font-weight:600}.blog-content-blockquote{color:#4b5563;background:#f9fafb;border-left:4px solid #3b82f6;border-radius:0 8px 8px 0;margin:2rem 0;padding:1.5rem;font-style:italic}.blog-content-blockquote p:last-child{margin-bottom:0}.blog-content-code-inline{color:#dc2626;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:4px;padding:.2rem .5rem;font-family:Courier New,Consolas,Monaco,monospace;font-size:.9em}.blog-content-code-block{border-radius:8px;margin:2rem 0;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a}.code-block-header{background:#1e293b;border-bottom:1px solid #334155;padding:.75rem 1rem}.code-block-language{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;font-size:.875rem;font-weight:600}.blog-content-figure{text-align:center;margin:2.5rem 0}.blog-content-img{border-radius:8px;max-width:100%;height:auto;box-shadow:0 4px 6px -1px #0000001a}.blog-content-figcaption{color:#6b7280;margin-top:.75rem;font-size:.875rem;font-style:italic}.blog-content-hr{border:none;border-top:2px solid #e5e7eb;margin:3rem 0}.blog-content-table-wrapper{border:1px solid #e5e7eb;border-radius:8px;margin:2rem 0;overflow-x:auto}.blog-content-table{border-collapse:collapse;width:100%;font-size:.95rem}.blog-content-thead{background:#f9fafb}.blog-content-th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;padding:.75rem 1rem;font-size:.75rem;font-weight:600}.blog-content-td{color:#374151;border-bottom:1px solid #e5e7eb;padding:.75rem 1rem;font-size:.875rem}.blog-content-tr:last-child .blog-content-td{border-bottom:none}.blog-content-tbody .blog-content-tr:hover{background:#f9fafb}@media (max-width:768px){.blog-content{font-size:16px}.blog-content-h1{font-size:2rem}.blog-content-h2{font-size:1.75rem}.blog-content-h3{font-size:1.375rem}.blog-content-h4{font-size:1.125rem}.blog-content-ul,.blog-content-ol{margin-left:1.5rem}.blog-content-code-block{border-radius:0;margin:1.5rem -1rem}}.blog-post-page{max-width:900px;margin:0 auto;padding:3rem 2rem}.blog-post-header{border-bottom:2px solid #e5e7eb;margin-bottom:3rem;padding-bottom:2rem}.blog-post-meta{color:#6b7280;align-items:center;gap:.75rem;margin-bottom:1.5rem;font-size:.875rem;display:flex}.blog-post-tag{color:#fff;text-transform:uppercase;letter-spacing:.05em;background:#3b82f6;border-radius:4px;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.blog-post-title{color:#111827;margin-bottom:1rem;font-size:3rem;font-weight:800;line-height:1.2}.blog-post-excerpt{color:#4b5563;margin-top:1rem;font-size:1.25rem;line-height:1.6}.blog-post-footer{border-top:2px solid #e5e7eb;margin-top:4rem;padding-top:2rem}.blog-post-tags{flex-wrap:wrap;gap:.5rem;display:flex}.blog-post-tag-item{color:#374151;background:#f3f4f6;border-radius:6px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:background .2s;display:inline-block}.blog-post-tag-item:hover{background:#e5e7eb}@media (max-width:768px){.blog-post-page{padding:2rem 1rem}.blog-post-title{font-size:2rem}.blog-post-excerpt{font-size:1.125rem}.blog-post-meta{flex-wrap:wrap}}@media (max-width:1024px){.admin-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.admin-stats-grid,.admin-form-grid-2{grid-template-columns:1fr}.admin-form{padding:1.5rem}.admin-table-container{overflow-x:auto}.admin-filters{flex-direction:column}.admin-filter-group{width:100%}}.admin-modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.admin-modal{background:#fff;border-radius:.75rem;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.admin-modal-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.admin-modal-title{color:#111827;margin:0;font-size:1.5rem;font-weight:600}.admin-modal-close{cursor:pointer;color:#6b7280;background:0 0;border:none;padding:.25rem;font-size:1.5rem;line-height:1;transition:color .2s}.admin-modal-close:hover{color:#111827}.admin-modal-body{padding:1.5rem}.admin-modal-footer{border-top:1px solid #e5e7eb;justify-content:flex-end;gap:.75rem;padding:1.5rem;display:flex}.admin-contact-detail-section{margin-bottom:2rem}.admin-contact-detail-section:last-child{margin-bottom:0}.admin-contact-detail-heading{color:#111827;margin:0 0 1rem;font-size:1.125rem;font-weight:600}.admin-contact-detail-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.admin-contact-detail-item{flex-direction:column;gap:.25rem;display:flex}.admin-contact-detail-item-full{grid-column:1/-1}.admin-contact-detail-label{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;font-size:.875rem;font-weight:600}.admin-contact-detail-value{color:#111827;margin:0;font-size:1rem}.admin-contact-message-box{color:#374151;white-space:pre-wrap;word-wrap:break-word;background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem;font-size:.95rem;line-height:1.6}.admin-email-link{color:#2563eb;text-decoration:none}.admin-email-link:hover{text-decoration:underline}.admin-message-preview{color:#6b7280;font-size:.875rem}.admin-date-text{color:#6b7280;white-space:nowrap;font-size:.875rem}.admin-text-muted{color:#9ca3af;font-style:italic}.admin-text-primary{color:#111827;font-weight:500}.admin-text-secondary{color:#6b7280;font-size:.875rem}.admin-badge{text-transform:capitalize;border-radius:9999px;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.admin-badge-info{color:#1e40af;background:#dbeafe}.admin-badge-success{color:#065f46;background:#d1fae5}.admin-badge-warning{color:#92400e;background:#fef3c7}.admin-badge-error{color:#991b1b;background:#fee2e2}.admin-badge-general{color:#1f2937;background:#f3f4f6}.admin-badge-books{color:#1e40af;background:#dbeafe}.admin-badge-blog{color:#92400e;background:#fef3c7}@media (max-width:640px){.admin-contact-detail-grid{grid-template-columns:1fr}.admin-modal{border-radius:0;max-height:100vh}.admin-modal-footer{flex-direction:column}.admin-modal-footer .admin-btn{width:100%}}.project-tags{color:#374151;flex-direction:column;gap:.2rem;margin:0;padding-left:0;font-size:.83rem;list-style:none;display:flex}.project-links{margin:0;padding-left:0;font-size:.85rem;list-style:none}.project-links li+li{margin-top:.2rem}.project-links a{color:var(--accent);text-decoration:none}.project-links a:hover,.project-links a:focus-visible{text-decoration:underline}.project-aside-note{color:#6b7280;margin:.5rem 0 0;font-size:.78rem}.project-content{color:var(--text-color);background:#fff;border:1px solid #e5e7eb;border-radius:1.6rem;padding:1.5rem 1.4rem 1.7rem;font-size:.95rem;position:relative;overflow:hidden;box-shadow:0 20px 48px #0f172a17}.project-content:before{content:"";opacity:.4;pointer-events:none;background:radial-gradient(circle at 100% 0,#38bdf82e,#0000 60%);position:absolute;inset:-40%}.project-section{margin-top:1.4rem}.project-section:first-of-type{margin-top:0}.project-section h2{margin:0 0 .5rem;font-size:1.05rem;font-weight:600}.project-section h3{margin:.8rem 0 .3rem;font-size:.96rem;font-weight:600}.project-section p{color:var(--text-color);margin:0 0 .75rem;line-height:1.7}.project-section ul,.project-section ol{margin:.1rem 0 .75rem;padding-left:1.15rem}.project-section li+li{margin-top:.2rem}.project-footer{border-top:1px solid #e5e7eb;flex-direction:column;gap:.6rem;margin-top:1.8rem;padding-top:1.1rem;display:flex}.project-footer-text{color:#4b5563;margin:0;font-size:.88rem}.project-footer-link{color:var(--accent);align-items:center;gap:.25rem;font-size:.86rem;font-weight:500;text-decoration:none;display:inline-flex}.project-footer-link:after{content:"←";font-size:.8rem;transform:translateY(.5px)}.project-footer-link:hover,.project-footer-link:focus-visible{text-decoration:underline}@media (min-width:640px){.project-page{padding-inline:1.75rem}.project-content{padding-inline:1.7rem}}@media (min-width:900px){.project-layout{flex-direction:row;align-items:flex-start;gap:2.3rem}.project-aside{flex:0 0 260px;order:0;align-self:flex-start;position:sticky;top:6.5rem}.project-content{flex:1}}@media (min-width:1024px){.project-page{padding-top:4.1rem;padding-bottom:5.1rem}.project-title{font-size:2.1rem}.project-content{padding-inline:1.95rem}}.login-page{background:var(--page-bg);min-height:100vh;display:flex}.login-cover{background:var(--code-bg);width:66.6667%;position:relative;overflow:hidden}.login-cover-image{object-fit:cover;object-position:center}.login-cover-overlay{background:linear-gradient(135deg,#0c0259d9 0%,#091b55bf 50%,#020617e6 100%);align-items:flex-end;padding:3rem 2.5rem;display:flex;position:absolute;inset:0}.login-cover-content{color:#fff;max-width:32rem}.login-cover-title{letter-spacing:-.01em;margin:0 0 .75rem;font-size:2.5rem;font-weight:700;line-height:1.2}.login-cover-subtitle{color:#e5e7eb;opacity:.95;margin:0;font-size:1.05rem;line-height:1.6}.login-form-container{background:#fff;justify-content:center;align-items:center;width:33.3333%;padding:2rem 1.5rem;display:flex}.login-form-wrapper{width:100%;max-width:26rem}.login-header{text-align:center;margin-bottom:2rem}.login-title{color:var(--text-color);letter-spacing:-.01em;margin:0 0 .5rem;font-size:1.75rem;font-weight:700}.login-subtitle{color:var(--muted-text);margin:0;font-size:.95rem}.login-error{border-radius:var(--radius-md);color:#991b1b;background:#fef2f2;border:1px solid #fecaca;align-items:flex-start;gap:.75rem;margin-bottom:1.5rem;padding:.875rem 1rem;font-size:.875rem;line-height:1.5;display:flex}.login-error-icon{flex-shrink:0;width:1.25rem;height:1.25rem;margin-top:.125rem}.login-form{flex-direction:column;gap:1.25rem;display:flex}.login-field{flex-direction:column;gap:.5rem;display:flex}.login-label{color:var(--text-color);font-size:.875rem;font-weight:500}.login-input{width:100%;color:var(--text-color);background:var(--page-bg);border:1px solid var(--border-subtle);border-radius:var(--radius-md);outline:none;padding:.75rem 1rem;font-family:inherit;font-size:.9375rem;transition:border-color .2s,box-shadow .2s,background .2s}.login-input::placeholder{color:#9ca3af}.login-input:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px #0c02591a}.login-input:disabled{opacity:.6;cursor:not-allowed}.login-options{justify-content:space-between;align-items:center;gap:1rem;display:flex}.login-checkbox-wrapper{align-items:center;gap:.5rem;display:flex}.login-checkbox{border:1px solid var(--border-subtle);cursor:pointer;width:1rem;height:1rem;accent-color:var(--accent);border-radius:.25rem}.login-checkbox:disabled{opacity:.6;cursor:not-allowed}.login-checkbox-label{color:var(--text-color);cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.875rem}.login-forgot-link{color:var(--accent);font-size:.875rem;font-weight:500;text-decoration:none;transition:color .2s}.login-forgot-link:hover{color:var(--accent-hover);text-decoration:underline}.login-submit-btn{color:#fff;background:var(--accent);border-radius:var(--radius-md);cursor:pointer;border:none;width:100%;padding:.875rem 1.5rem;font-family:inherit;font-size:.9375rem;font-weight:600;transition:background .2s,transform .15s,box-shadow .2s}.login-submit-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 8px 20px #0c025940}.login-submit-btn:active:not(:disabled){transform:translateY(0)}.login-submit-btn:disabled{opacity:.7;cursor:not-allowed}@media (max-width:1024px){.login-cover,.login-form-container{width:50%}.login-cover-title{font-size:2rem}.login-cover-subtitle{font-size:.95rem}}@media (max-width:768px){.login-page{flex-direction:column}.login-cover{width:100%;min-height:16rem;max-height:20rem}.login-cover-overlay{justify-content:center;align-items:center;padding:2rem 1.5rem}.login-cover-content{text-align:center}.login-cover-title{font-size:1.75rem}.login-cover-subtitle{font-size:.9rem}.login-form-container{width:100%;padding:2.5rem 1.5rem}.login-form-wrapper{max-width:28rem}}@media (max-width:480px){.login-cover{min-height:12rem;max-height:16rem}.login-cover-overlay{padding:1.5rem 1rem}.login-cover-title{font-size:1.5rem}.login-cover-subtitle{font-size:.85rem}.login-form-container{padding:2rem 1rem}.login-options{flex-direction:column;align-items:flex-start;gap:.75rem}}.error-page{background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.error-container{border-radius:var(--radius-lg);width:100%;max-width:600px;box-shadow:var(--shadow-soft);text-align:center;background:#fff;padding:3rem 2rem}.error-header{margin-bottom:2rem}.error-title{color:var(--text-color);margin:0 0 .5rem;font-size:2rem;font-weight:700;line-height:1.2}.error-subtitle{color:var(--muted-text);margin:0;font-size:1rem}.error-details{border-radius:var(--radius-md);text-align:left;background:#f9fafb;border-left:4px solid #ef4444;margin:2rem 0;padding:1.5rem}.error-message{color:var(--text-color);word-break:break-word;margin:0 0 .5rem;font-size:.95rem}.error-code{color:var(--muted-text);margin:0;font-size:.85rem}.error-code code{border-radius:var(--radius-sm);word-break:break-all;background:#e5e7eb;padding:.25rem .5rem;font-family:Courier New,monospace}.error-actions{flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:2rem;display:flex}.error-retry-btn,.error-home-btn{border-radius:var(--radius-md);cursor:pointer;border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;text-decoration:none;transition:all .3s;display:inline-block}.error-retry-btn{background:var(--accent);color:#fff}.error-retry-btn:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 4px 12px #0c025933}.error-home-btn{background:var(--border-subtle);color:var(--text-color)}.error-home-btn:hover{background:#d1d5db;transform:translateY(-2px)}.error-retry-btn:focus-visible,.error-home-btn:focus-visible{outline:var(--focus-ring);outline-offset:3px}@media (max-width:768px){.error-container{padding:2rem 1.5rem}.error-title{font-size:1.5rem}.error-subtitle{font-size:.95rem}.error-actions{flex-direction:column}.error-retry-btn,.error-home-btn{width:100%}}.not-found-page .not-found-code{color:var(--accent);opacity:.8;margin:0 0 1rem;font-size:5rem;font-weight:900}.login-field-error{color:#dc2626;margin-top:.25rem;font-size:.875rem;display:block}.login-input.has-error{background-color:#fef2f2;border-color:#dc2626}.login-input.has-error:focus{border-color:#dc2626;outline-color:#dc2626}.admin-table-wrapper{border:1px solid var(--border-subtle);border-radius:var(--radius-md);width:100%;overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:.95rem}.admin-table-header{text-align:left;border-bottom:2px solid var(--border-subtle);-webkit-user-select:none;user-select:none;background-color:#f3f4f6;padding:1rem;font-weight:600}.admin-table-header.sortable{cursor:pointer;transition:background-color .2s}.admin-table-header.sortable:hover{background-color:#e5e7eb}.admin-table-header-content{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.admin-table-sort-icon{opacity:.6;text-align:center;min-width:1rem;font-size:.75rem}.admin-table-row{border-bottom:1px solid var(--border-subtle);transition:background-color .15s}.admin-table-row:hover{background-color:#f9fafb}.admin-table-row[tabindex="0"]{cursor:pointer}.admin-table-row[tabindex="0"]:focus-visible{outline:var(--focus-ring);outline-offset:-2px}.admin-table-cell{border-bottom:1px solid var(--border-subtle);padding:1rem}.admin-table-cell:last-child{border-right:none}.admin-table-empty{text-align:center;color:var(--muted-text);border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:#f9fafb;padding:3rem 1rem}.admin-table-empty p{margin:0}.admin-table-loading{text-align:center;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:#f9fafb;flex-direction:column;align-items:center;gap:1rem;padding:3rem 1rem;display:flex}.admin-table-spinner{border:3px solid #e5e7eb;border-top-color:var(--accent);border-radius:50%;width:2rem;height:2rem;animation:.6s linear infinite spin}.admin-table-loading p{color:var(--muted-text);margin:0}.admin-table-error{border-radius:var(--radius-md);color:#991b1b;background:#fee2e2;border:1px solid #fca5a5;padding:1.5rem}.admin-table-error p{margin:0}.admin-table-pagination{border-top:1px solid var(--border-subtle);justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;display:flex}.admin-table-pagination-btn{border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-color);cursor:pointer;background:#fff;padding:.5rem 1rem;font-weight:500;transition:all .2s}.admin-table-pagination-btn:hover:not(:disabled){background:var(--accent);color:#fff;border-color:var(--accent)}.admin-table-pagination-btn:disabled{opacity:.5;cursor:not-allowed}.admin-table-pagination-info{color:var(--muted-text);font-size:.95rem}.skeleton{background:linear-gradient(90deg,var(--card-bg,#e2e8f0)25%,var(--card-hover-bg,#f1f5f9)50%,var(--card-bg,#e2e8f0)75%);background-size:200% 100%;border-radius:4px;animation:1.5s ease-in-out infinite skeleton-shimmer}.skeleton-text{border-radius:4px;height:1rem}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}[data-theme=dark] .skeleton,.dark .skeleton{background:linear-gradient(90deg,#1d283a 25%,#26344b 50%,#1d283a 75%) 0 0/200% 100%;animation:1.5s ease-in-out infinite skeleton-shimmer}
