.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}:root{--color-bg: #F9F8F6;--color-surface: #EFE9E3;--color-border: #D9CFC7;--color-accent: #C9B59C;--color-text: #2C2825;--color-text-muted: #6B635B;--space-1: .5rem;--space-2: 1rem;--space-3: 1.5rem;--space-4: 2rem;--space-6: 3rem;--space-8: 4rem;--space-12: 6rem;--radius-sm: .375rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-full: 9999px;--max-width-prose: 720px;--max-width-wide: 1120px}[data-theme=dark]{--color-bg: #1C1A17;--color-surface: #2A2622;--color-border: #3D3830;--color-accent: #D4C4A8;--color-text: #E8E4DF;--color-text-muted: #9E958A}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{height:100%;scroll-behavior:smooth}body{min-height:100%;background-color:var(--color-bg);color:var(--color-text);font-family:Georgia,Times New Roman,serif;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s ease,color .3s ease}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}[lang=en] [data-lang=ar],[lang=ar] [data-lang=en]{display:none}[dir=rtl]{text-align:right}[dir=ltr]{text-align:left}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}html{scroll-behavior:auto}}.theme-toggle{position:relative;width:56px;height:28px;border-radius:14px;border:none;cursor:pointer;padding:0;background:linear-gradient(135deg,#87ceeb,#b0e0e6);overflow:hidden;transition:background .3s ease;flex-shrink:0}.theme-toggle__notch{position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:gold;box-shadow:0 0 8px 3px #ffd70066,0 0 16px 6px #ffb40026;transition:transform .3s ease,background .3s ease,box-shadow .3s ease;animation:sunGlow 3s ease-in-out infinite}.theme-toggle__crater{position:absolute;border-radius:50%;background:#0000001f;opacity:0;transition:opacity .3s ease}.theme-toggle__crater--1{width:5px;height:5px;top:5px;left:11px}.theme-toggle__crater--2{width:4px;height:4px;top:13px;left:6px}.theme-toggle__star{position:absolute;border-radius:50%;background:#fff;opacity:0;transition:opacity .3s ease}.theme-toggle__star--1{width:3px;height:3px;top:6px;left:8px}.theme-toggle__star--2{width:2px;height:2px;top:18px;left:14px}.theme-toggle__star--3{width:2px;height:2px;top:14px;left:5px}.theme-toggle__cloud{position:absolute;width:18px;height:8px;background:#fffc;border-radius:8px;bottom:8px;right:10px;opacity:1;transition:opacity .3s ease;animation:cloudDrift 4s ease-in-out infinite}.theme-toggle__cloud:before{content:"";position:absolute;width:10px;height:10px;background:#fffc;border-radius:50%;top:-5px;left:2px}.theme-toggle__cloud:after{content:"";position:absolute;width:8px;height:8px;background:#fffc;border-radius:50%;top:-3px;left:8px}[data-theme=dark] .theme-toggle{background:linear-gradient(135deg,#1a1a2e,#4a2c6e)}[data-theme=dark] .theme-toggle .theme-toggle__notch{transform:translate(28px);background:#e8e4df;box-shadow:0 0 6px 1px #b4a0dc66;animation:none}[data-theme=dark] .theme-toggle .theme-toggle__crater{opacity:1}[data-theme=dark] .theme-toggle .theme-toggle__star{opacity:1;box-shadow:0 0 3px 1px #b4a0ff99}[data-theme=dark] .theme-toggle .theme-toggle__star--1{animation:starPulse 2s ease-in-out 0s infinite}[data-theme=dark] .theme-toggle .theme-toggle__star--2{animation:starPulse 2.5s ease-in-out .7s infinite}[data-theme=dark] .theme-toggle .theme-toggle__star--3{animation:starPulse 3s ease-in-out 1.4s infinite}[data-theme=dark] .theme-toggle .theme-toggle__cloud{opacity:0}@keyframes sunGlow{0%,to{box-shadow:0 0 8px 3px #ffd70066,0 0 16px 6px #ffb40026}50%{box-shadow:0 0 10px 4px #ffd70080,0 0 20px 8px #ffb40033}}@keyframes starPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.6);opacity:.6}}@keyframes cloudDrift{0%,to{transform:translate(0)}50%{transform:translate(3px)}}.theme-toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:14px}@media(prefers-reduced-motion:reduce){.theme-toggle,.theme-toggle__notch,.theme-toggle__crater,.theme-toggle__star,.theme-toggle__cloud{transition:none!important;animation:none!important}}.hero{background:linear-gradient(135deg,var(--color-surface),var(--color-border) 80%);padding:var(--space-8) var(--space-4);padding-top:calc(var(--space-12) + 60px)}.hero__inner{display:flex;align-items:center;gap:var(--space-8);max-width:var(--max-width-wide);margin-inline:auto}.hero__image-wrap{flex-shrink:0}.hero__image{width:clamp(140px,20vw,220px);height:clamp(140px,20vw,220px);border-radius:var(--radius-full);object-fit:cover;border:4px solid var(--color-accent);box-shadow:0 0 0 8px #c9b59c33}.hero__content{display:flex;flex-direction:column;gap:var(--space-2)}.hero__name{font-size:clamp(2rem,5vw,3rem);font-weight:400;color:var(--color-text);line-height:1.2}.hero__skills{font-size:clamp(.9rem,2vw,1.1rem);color:var(--color-text-muted)}.hero__bio{font-size:clamp(.9rem,1.8vw,1.05rem);color:var(--color-text-muted);max-width:520px;line-height:1.7}.hero__actions{display:flex;gap:var(--space-2);margin-top:var(--space-2);flex-wrap:wrap}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{opacity:0;animation:fadeIn .5s ease-out forwards}.delay-1{animation-delay:.15s}.delay-2{animation-delay:.3s}.delay-3{animation-delay:.45s}@media(prefers-reduced-motion:reduce){.fade-in{opacity:1;animation:none}}@media(max-width:639px){.hero{padding:var(--space-6) var(--space-3);padding-top:calc(var(--space-8) + 60px)}.hero__inner{flex-direction:column;text-align:center;align-items:center}.hero__actions{justify-content:center}.hero__bio{max-width:100%}}.btn{display:inline-flex;align-items:center;gap:.5em;padding:.625rem 1.5rem;border-radius:var(--radius-md);font-size:clamp(.85rem,1.5vw,.95rem);font-family:inherit;letter-spacing:.01em;transition:opacity .2s ease-out,transform .2s ease-out}.btn:hover{opacity:.85;transform:translateY(-1px)}.btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.btn--filled{background-color:var(--color-accent);color:var(--color-text)}[data-theme=dark] .btn--filled{color:#1c1a17}.btn--outlined{background:transparent;border:1.5px solid var(--color-accent);color:var(--color-text)}.about__heading{font-size:clamp(1.25rem,2.5vw,1.5rem);font-weight:400;color:var(--color-text);margin-bottom:var(--space-3)}.about__card{border-inline-start:3px solid var(--color-accent);padding:var(--space-3);background-color:var(--color-surface);border-radius:0 var(--radius-md) var(--radius-md) 0}.about__text{font-size:clamp(.9rem,1.5vw,1rem);color:var(--color-text-muted);line-height:1.8}.about__social{margin-top:var(--space-4)}.social{display:flex;gap:var(--space-3)}.social a{color:var(--color-accent);transition:opacity .2s ease-out}.social a:hover{opacity:.6}.social a:focus-visible{outline:2px solid var(--color-accent);outline-offset:4px;border-radius:2px}.projects__heading{font-size:clamp(1.25rem,2.5vw,1.5rem);font-weight:400;color:var(--color-text);margin-bottom:var(--space-3)}.projects__grid{display:flex;flex-wrap:wrap;gap:var(--space-3)}.projects__grid>article{flex:1 1 280px;max-width:100%}.card{display:flex;flex-direction:column;background-color:var(--color-bg);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border);transition:transform .2s ease-out,box-shadow .2s ease-out}.card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000000f}.card__thumb{width:100%;height:160px;object-fit:cover}.card__thumb--contain{object-fit:contain;background-color:#f0e8da;padding:var(--space-2)}[data-theme=dark] .card__thumb--contain{background-color:#2a2622}.card__thumb-placeholder{width:100%;height:160px;background:linear-gradient(135deg,var(--color-surface),var(--color-border))}.card__title{font-size:clamp(.95rem,1.5vw,1.05rem);font-weight:600;padding:var(--space-2) var(--space-2) 0;color:var(--color-text)}.card__type{font-size:.85rem;color:var(--color-text-muted);padding:.25rem var(--space-2) 0}.card__link{display:inline-block;margin:var(--space-2);padding:.5rem 1.25rem;border:1.5px solid var(--color-accent);border-radius:var(--radius-md);font-size:.85rem;color:var(--color-text);text-align:center;transition:opacity .2s ease-out}.card__link:hover{opacity:.7}.card__link:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.project-detail{display:flex;flex-direction:column;gap:var(--space-3)}.project-detail__back{display:inline-flex;align-items:center;gap:.25em;font-size:clamp(.85rem,1.5vw,.95rem);color:var(--color-accent);margin-bottom:var(--space-1);transition:opacity .2s ease-out}.project-detail__back:hover{opacity:.7}.project-detail__hero-img{width:100%;border-radius:var(--radius-lg);object-fit:cover;max-height:400px}.project-detail__title{font-size:clamp(1.5rem,4vw,2.25rem);font-weight:400;color:var(--color-text);line-height:1.2}.project-detail__type{display:inline-block;font-size:clamp(.8rem,1.5vw,.9rem);color:var(--color-text-muted);background:var(--color-surface);padding:.25rem .75rem;border-radius:var(--radius-full);align-self:flex-start}.project-detail__description{font-size:clamp(.9rem,1.8vw,1.05rem);color:var(--color-text-muted);line-height:1.8}.project-detail__features{list-style:none;display:flex;flex-direction:column;gap:var(--space-1);padding:0}.project-detail__features li{position:relative;padding-inline-start:1.25em;font-size:clamp(.85rem,1.5vw,.95rem);color:var(--color-text);line-height:1.6}.project-detail__features li:before{content:"";position:absolute;inset-inline-start:0;top:.55em;width:6px;height:6px;border-radius:50%;background:var(--color-accent)}.project-detail__cta{align-self:flex-start;margin-top:var(--space-2)}.project-carousel-wrapper{width:100%;margin-top:var(--space-2)}.project-carousel{position:relative;overflow:hidden;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);box-shadow:0 0 0 1px #0000000a,0 12px 40px #00000014,0 4px 12px #0000000a;aspect-ratio:16 / 9;cursor:grab;user-select:none}[data-theme=dark] .project-carousel{box-shadow:0 0 0 1px #ffffff0f,0 20px 60px #0006,0 4px 16px #00000040}.project-carousel:active{cursor:grabbing}.project-carousel__progress{position:absolute;bottom:0;left:0;height:2px;background:var(--color-accent);border-radius:0 2px 2px 0;pointer-events:none;z-index:5}.project-carousel__track{display:flex;height:100%;transition:transform .45s cubic-bezier(.25,.46,.45,.94)}.project-carousel__slide{flex:0 0 100%;height:100%;position:relative;overflow:hidden}.project-carousel__slide img{width:100%;height:100%;object-fit:cover;display:block;transition:filter .4s ease;filter:brightness(.88) saturate(.92)}.project-carousel__slide--active img{filter:brightness(1) saturate(1.05)}.project-carousel__overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.25) 0%,transparent 40%);pointer-events:none}.project-carousel__arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:40px;height:40px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:#ffffffd9;backdrop-filter:blur(10px);color:var(--color-text);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,border-color .2s ease,transform .2s ease,opacity .2s ease;opacity:0}[data-theme=dark] .project-carousel__arrow{background:#2a2622d9}.project-carousel:hover .project-carousel__arrow{opacity:1}.project-carousel__arrow:hover{background:var(--color-surface);border-color:var(--color-accent);transform:translateY(-50%) scale(1.05)}.project-carousel__arrow:active{transform:translateY(-50%) scale(.96)}.project-carousel__arrow--prev{left:14px}.project-carousel__arrow--next{right:14px}[dir=rtl] .project-carousel__arrow--prev{left:auto;right:14px}[dir=rtl] .project-carousel__arrow--next{right:auto;left:14px}@media(hover:none){.project-carousel__arrow{opacity:1}}.project-carousel__dots{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:var(--space-2)}.project-carousel__dot{width:6px;height:6px;border-radius:var(--radius-full);background:var(--color-border);cursor:pointer;padding:0;border:none;transition:background .3s ease,width .3s ease,transform .2s ease;flex-shrink:0}.project-carousel__dot--active{background:var(--color-accent);width:20px}.project-carousel__dot:hover:not(.project-carousel__dot--active){background:var(--color-text-muted);transform:scale(1.2)}@media(max-width:639px){.project-carousel__arrow{width:34px;height:34px}.project-carousel__arrow--prev{left:8px}.project-carousel__arrow--next{right:8px}[dir=rtl] .project-carousel__arrow--prev{left:auto;right:8px}[dir=rtl] .project-carousel__arrow--next{right:auto;left:8px}}@media(prefers-reduced-motion:reduce){.project-carousel__track{transition:none}.project-carousel__slide img{transition:none;filter:none}.project-carousel__progress{transition:none!important}.project-carousel__dot,.project-carousel__arrow{transition:none}}.project-detail__loading{display:flex;flex-direction:column;gap:var(--space-2)}.project-detail__skeleton{background:linear-gradient(90deg,var(--color-surface) 25%,var(--color-border) 50%,var(--color-surface) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media(prefers-reduced-motion:reduce){.project-detail__skeleton{animation:none}}.rich-text p{margin-bottom:.75em}.rich-text p:last-child{margin-bottom:0}.rich-text ul,.rich-text ol{padding-left:1.5em;margin-bottom:.75em}.rich-text li{margin-bottom:.25em}.rich-text h2,.rich-text h3{margin-top:1em;margin-bottom:.5em}.rich-text blockquote{border-left:3px solid var(--color-accent);padding-left:1em;margin:.75em 0;color:var(--color-text-muted)}.rich-text a{color:var(--color-accent);text-decoration:underline}.rich-text code{background:var(--color-surface);padding:.15em .35em;border-radius:3px;font-size:.9em}.rich-text hr{border:none;border-top:1px solid var(--color-border);margin:1em 0}.ProseMirror{outline:none;background:transparent;color:inherit;font-family:inherit;min-height:100px}.ProseMirror:focus{outline:none}.ProseMirror p{margin-bottom:.5em}.ProseMirror p:last-child{margin-bottom:0}
