@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&display=swap";:root{--bg: #f6f7fb;--surface: #ffffff;--text: #0f172a;--muted: #475569;--primary: #6366f1;--primary-600: #5457e3;--primary-700: #4f46e5;--border: rgba(2, 6, 23, .08);--ring: rgba(99, 102, 241, .35);--container: 1200px;--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--shadow-sm: 0 2px 8px rgba(2, 6, 23, .06);--shadow: 0 10px 25px rgba(2, 6, 23, .08);--shadow-lg: 0 25px 55px rgba(2, 6, 23, .12);--gradient: linear-gradient(135deg, #6366f1 0%, #8b5cf6 45%, #06b6d4 100%);--glass: rgba(255, 255, 255, .6);--backdrop: saturate(180%) blur(10px)}[data-theme=dark]{--bg: #060b12;--surface: #0b1220;--text: #e5e7eb;--muted: #94a3b8;--primary: #8b5cf6;--primary-600: #7c3aed;--primary-700: #6d28d9;--border: rgba(148, 163, 184, .16);--ring: rgba(139, 92, 246, .35);--glass: rgba(11, 18, 32, .6);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .35);--shadow: 0 10px 25px rgba(0, 0, 0, .4);--shadow-lg: 0 25px 55px rgba(0, 0, 0, .5)}html{scroll-behavior:smooth}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;color:var(--text);background:radial-gradient(1200px 600px at 10% -10%,rgba(99,102,241,.07),transparent 50%),radial-gradient(1200px 600px at 90% -10%,rgba(6,182,212,.07),transparent 50%),var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes fadeInScale{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes pulseGlow{0%{box-shadow:var(--shadow)}50%{box-shadow:0 12px 32px #6366f142}to{box-shadow:var(--shadow)}}@keyframes revealUp{0%{opacity:0;transform:translateY(14px) scale(.98)}60%{opacity:1;transform:translateY(0) scale(1.01)}to{opacity:1;transform:translateY(0) scale(1)}}.container{max-width:var(--container);padding-inline:clamp(1rem,3vw,2rem);margin-inline:auto}section{scroll-margin-top:80px}h1,h2,h3{color:var(--text);margin:0 0 var(--space-4)}h1{font-size:clamp(2rem,5vw,3rem);line-height:1.1}h2{font-size:clamp(1.5rem,3.5vw,2rem)}h3{font-size:1.25rem}p{color:var(--muted)}a{color:var(--primary);text-decoration:none}a:hover{color:var(--primary-700)}.gradient-text{background:var(--gradient);-webkit-background-clip:text;background-clip:text;color:transparent;background-size:200% 200%;animation:gradientShift 12s ease infinite}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.btn{display:inline-flex;align-items:center;justify-content:center;height:44px;padding:0 var(--space-5);border-radius:999px;font-weight:600;border:1px solid transparent;transition:transform .15s ease,box-shadow .2s ease,background .2s ease,color .2s ease;will-change:transform}.btn:disabled{cursor:not-allowed;opacity:.6;box-shadow:none;transform:none}.btn:active{transform:translateY(1px)}.btn--primary{color:#fff;background:var(--gradient);box-shadow:var(--shadow);animation:pulseGlow 8s ease-in-out infinite}.btn--primary:hover{box-shadow:var(--shadow-lg)}.btn--secondary{color:var(--text);background:var(--surface);border-color:var(--border)}.btn--secondary:hover{box-shadow:var(--shadow-sm)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.reveal{opacity:0;transform:translateY(12px)}.reveal.is-visible{opacity:1;transform:none;animation:revealUp .7s cubic-bezier(.2,.6,.3,1) forwards;animation-delay:var(--reveal-delay, 0s)}.fade-progressive>*{opacity:0;transform:translateY(8px);animation:revealUp .7s cubic-bezier(.2,.6,.3,1) forwards}.fade-progressive>*:nth-child(1){animation-delay:.05s}.fade-progressive>*:nth-child(2){animation-delay:.15s}.fade-progressive>*:nth-child(3){animation-delay:.25s}.fade-progressive>*:nth-child(4){animation-delay:.35s}.fade-progressive>*:nth-child(5){animation-delay:.45s}.fade-progressive>*:nth-child(6){animation-delay:.55s}.fade-progressive>*:nth-child(7){animation-delay:.65s}.fade-progressive>*:nth-child(8){animation-delay:.75s}.fade-progressive>*:nth-child(9){animation-delay:.85s}.fade-progressive>*:nth-child(10){animation-delay:.95s}:where(button,a,input,textarea):focus-visible{outline:2px solid var(--ring);outline-offset:2px}.header{position:sticky;top:0;z-index:20;background:var(--glass);backdrop-filter:var(--backdrop);-webkit-backdrop-filter:var(--backdrop);border-bottom:1px solid var(--border)}.header__container{display:flex;gap:var(--space-4);align-items:center;justify-content:space-between;padding-block:.85rem}.header__logo{display:inline-flex;align-items:center;justify-content:center;height:44px}.header__logo img{display:block;height:100%;width:auto}.header__nav ul{list-style:none;display:flex;gap:clamp(.75rem,2vw,1.25rem);margin:0;padding:0}.header__nav li{display:flex}.header__nav-link{position:relative;display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:18px;text-decoration:none;color:var(--text);transition:transform .25s ease}.header__nav-icon-wrapper{position:relative;width:100%;height:100%;display:inline-flex;align-items:center;justify-content:center;border-radius:inherit;background:linear-gradient(var(--surface),var(--surface)) padding-box,var(--gradient) border-box;border:1px solid transparent;box-shadow:var(--shadow-sm);transition:box-shadow .25s ease,transform .25s ease}.header__nav-icon{width:22px;height:22px}.header__nav-tooltip{position:absolute;top:calc(100% + .75rem);left:50%;transform:translate(-50%,-6px);background:var(--surface);color:var(--text);border-radius:var(--radius-sm);padding:.4rem .65rem;box-shadow:var(--shadow-sm);border:1px solid var(--border);font-size:.85rem;font-weight:600;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s ease,transform .2s ease;pointer-events:none;z-index:15}.header__nav-link:hover,.header__nav-link:focus-visible{transform:translateY(-4px)}.header__nav-link:hover .header__nav-icon-wrapper,.header__nav-link:focus-visible .header__nav-icon-wrapper{box-shadow:var(--shadow)}.header__nav-link:hover .header__nav-tooltip,.header__nav-link:focus-visible .header__nav-tooltip{opacity:1;visibility:visible;transform:translate(-50%)}.header__nav-link:focus-visible{outline:2px solid var(--ring);outline-offset:4px}.theme-toggle{height:36px;width:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px solid var(--border);background:var(--surface);cursor:pointer;color:var(--text);transition:box-shadow .2s ease,transform .2s ease}.theme-toggle:hover{box-shadow:var(--shadow-sm)}.theme-toggle:active{transform:translateY(1px)}.theme-toggle svg{transition:transform .35s ease}.theme-toggle:hover svg{transform:rotate(-8deg)}.hero{padding:clamp(3rem,6vw,5rem) 0;min-height:calc(100vh - 80px);display:flex;align-items:center;position:relative}.hero__container{display:grid;grid-template-columns:1.2fr 1fr;align-items:center;gap:clamp(1.5rem,4vw,3rem)}@media (max-width: 900px){.hero__container{grid-template-columns:1fr}}.hero__text h1{margin-top:.4rem}.hero__text h2{color:var(--muted);font-weight:600}.hero__text p{margin:var(--space-4) 0 var(--space-6)}.hero__typewriter{font-size:1.1rem;color:var(--muted)}.typewriter{display:inline-flex;align-items:center;gap:.25rem;min-height:1.6rem}.typewriter__text{display:inline-block}.typewriter__cursor{width:2px;height:1.2em;display:inline-block;background:var(--primary);animation:typewriterBlink 1.05s steps(2) infinite;border-radius:2px}@keyframes typewriterBlink{0%,49%{opacity:1}50%,to{opacity:0}}.hero__text>*{opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}.hero.is-visible .hero__text>*{opacity:1;transform:translateY(0)}.hero__text>*:nth-child(1){transition-delay:.1s}.hero__text>*:nth-child(2){transition-delay:.2s}.hero__text>*:nth-child(3){transition-delay:.32s}.hero__text>*:nth-child(4){transition-delay:.45s}.hero__buttons{display:flex;gap:var(--space-4);flex-wrap:wrap}.hero__buttons .btn:hover{transform:translateY(-2px)}.hero__image{text-align:center}.hero__image img{width:clamp(200px,28vw,280px);aspect-ratio:1 / 1;border-radius:50%;object-fit:cover;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);animation:float 9s ease-in-out infinite}.hero__scroll-hint{position:absolute;bottom:clamp(1.5rem,4vw,2.5rem);left:50%;transform:translate(-50%);display:inline-flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--muted);text-decoration:none;opacity:0;animation:scrollHintFade 1.6s ease forwards 1.2s}.hero__scroll-icon{position:relative;width:20px;height:32px;border:2px solid var(--muted);border-radius:999px;display:block;overflow:hidden}.hero__scroll-icon:after{content:"";position:absolute;top:6px;left:50%;width:6px;height:6px;border-radius:50%;background:var(--primary);transform:translate(-50%);animation:scrollHint 1.8s ease-in-out infinite}.hero__scroll-text{font-size:.9rem;letter-spacing:.08em;text-transform:uppercase}@keyframes scrollHint{0%,20%{transform:translate(-50%,-6px);opacity:0}30%{opacity:1}60%{transform:translate(-50%,10px);opacity:1}to{transform:translate(-50%,18px);opacity:0}}@keyframes scrollHintFade{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}@media (prefers-reduced-motion: reduce){.hero__text>*{opacity:1;transform:none;transition:none}.hero__image img,.typewriter__cursor{animation:none}.hero__scroll-icon:after{animation:none}.hero__scroll-hint{animation:none;opacity:1}}.about{padding:clamp(3rem,6vw,5rem) 0}.about__container{max-width:800px}.about__title{position:relative;margin:0 0 var(--space-6);padding-left:var(--space-4);font-size:clamp(1.5rem,3.5vw,2rem);opacity:0;transform:translateY(12px);transition:opacity .5s ease,transform .5s ease}.about__title:before{content:"";position:absolute;left:0;top:.2rem;bottom:.2rem;width:6px;border-radius:999px;background:var(--gradient);opacity:0;transform:scaleY(.4);transition:opacity .5s ease,transform .5s ease}.about.is-visible .about__title{opacity:1;transform:translateY(0)}.about.is-visible .about__title:before{opacity:1;transform:scaleY(1)}.about p{font-size:1.05rem;color:var(--muted);line-height:1.8;margin-bottom:var(--space-4);opacity:0;transform:translateY(14px);transition:opacity .45s ease,transform .45s ease}.about p:nth-of-type(1){transition-delay:.12s}.about p:nth-of-type(2){transition-delay:.22s}.about p:nth-of-type(3){transition-delay:.32s}.about.is-visible p{opacity:1;transform:translateY(0)}.about__timeline-heading{margin:var(--space-6) 0 var(--space-4);font-size:1.2rem;color:var(--text)}.about__timelines{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));column-gap:8rem;row-gap:6rem;align-items:start}.about__timeline{position:relative;margin-top:var(--space-3);padding-left:32px;display:grid;gap:var(--space-4)}.about__timeline:before{content:"";position:absolute;left:12px;top:0;bottom:0;width:2px;background:var(--border)}.about__timeline-item{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-3) var(--space-4) var(--space-3) var(--space-4);box-shadow:var(--shadow-sm);opacity:0;transform:translateY(12px);transition:opacity .45s ease,transform .45s ease;transition-delay:calc(var(--item-index, 0) * .08s + .2s)}.about.is-visible .about__timeline-item{opacity:1;transform:translateY(0)}.about__timeline-dot{position:absolute;left:-27px;top:18px;width:14px;height:14px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 4px #6366f12e;animation:pulseDot 2.4s ease-in-out infinite}.about__timeline-header{display:flex;align-items:baseline;gap:var(--space-3);flex-wrap:wrap}.about__timeline-year{font-weight:800;color:var(--primary-700)}.about__timeline-title{margin:0;font-size:1.05rem;color:var(--text)}.about__timeline-detail{margin:var(--space-2) 0 0;color:var(--muted)}@keyframes pulseDot{0%{box-shadow:0 0 0 4px #6366f12e;transform:scale(1)}50%{box-shadow:0 0 0 10px #6366f114;transform:scale(1.05)}to{box-shadow:0 0 0 4px #6366f12e;transform:scale(1)}}.project-card{overflow:hidden;border-radius:var(--radius);background:linear-gradient(var(--surface),var(--surface)) padding-box,linear-gradient(135deg,#6366f180,#06b6d480) border-box;border:1px solid transparent;box-shadow:var(--shadow-sm);opacity:0;transform:translateY(18px);transition:opacity .45s ease,transform .45s ease,box-shadow .25s ease;transition-delay:calc(var(--card-index, 0) * .08s + .12s)}.projects.is-visible .project-card{opacity:1;transform:translateY(0)}.project-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}.project-card__image-button{border:none;padding:0;margin:0;display:block;width:100%;background:none;cursor:zoom-in}.project-card__image-button img{width:100%;height:190px;object-fit:cover;display:block;transition:transform .4s ease}.project-card:hover .project-card__image-button img{transform:scale(1.05)}.project-card__content{padding:var(--space-5)}.project-card__badge{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border-radius:999px;font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--space-3);background:#6366f11f;color:var(--primary-700)}.project-card__badge--web{background:#6366f11f;color:var(--primary-700)}.project-card__badge--mobile{background:#0ea5e924;color:#0369a1}.project-card__badge--other{background:#60a5fa1f;color:#1d4ed8}[data-theme=dark] .project-card__badge{background:#818cf82e;color:#c7d2fe}[data-theme=dark] .project-card__badge--mobile{background:#38bdf829;color:#bae6fd}[data-theme=dark] .project-card__badge--other{background:#93c5fd29;color:#93c5fd}.project-card__content h3{margin:0 0 var(--space-2)}.project-card__content p{color:var(--muted);margin:0 0 var(--space-4)}.project-card__tech-list{display:flex;flex-wrap:wrap;gap:.4rem;margin:0 0 var(--space-4);padding:0;list-style:none}.project-card__tech-chip{padding:.35rem .65rem;border-radius:999px;background:#4f46e51f;color:var(--primary-700);font-size:.78rem;font-weight:600;letter-spacing:.02em}[data-theme=dark] .project-card__tech-chip{background:#818cf833;color:#c7d2fe}.project-card__content a{text-decoration:none;color:#fff;background:var(--gradient);padding:.55rem 1rem;border-radius:999px;display:inline-flex;font-weight:600;box-shadow:var(--shadow)}[data-theme=dark] .project-card__badge--web{background:#818cf82e;color:#c7d2fe}.projects{padding:clamp(3rem,6vw,5rem) 0}.projects__title{position:relative;margin:0 0 var(--space-8);padding-left:var(--space-4);font-size:clamp(1.5rem,3.5vw,2rem);opacity:0;transform:translateY(12px);transition:opacity .5s ease,transform .5s ease}.projects__title:before{content:"";position:absolute;left:0;top:.2rem;bottom:.2rem;width:6px;border-radius:999px;background:var(--gradient);opacity:0;transform:scaleY(.4);transition:opacity .5s ease,transform .5s ease}.projects.is-visible .projects__title{opacity:1;transform:translateY(0)}.projects.is-visible .projects__title:before{opacity:1;transform:scaleY(1)}.projects__filters{display:flex;justify-content:center;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-6)}.projects__filter-btn{border:1px solid var(--border);background:var(--surface);color:var(--muted);border-radius:999px;padding:.5rem 1.1rem;font-weight:600;font-size:.95rem;cursor:pointer;transition:color .2s ease,box-shadow .2s ease,border-color .2s ease,transform .2s ease}.projects__filter-btn:hover{color:var(--primary-700);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.projects__filter-btn--active{border-color:transparent;background:var(--gradient);color:#fff;box-shadow:var(--shadow)}[data-theme=dark] .projects__filter-btn{background:var(--surface);color:var(--muted)}.projects__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-6)}.projects-lightbox{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center}.projects-lightbox__backdrop{position:absolute;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.projects-lightbox__content{position:relative;max-width:min(90vw,980px);max-height:min(85vh,720px);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);animation:lightboxIn .35s ease;background:var(--surface)}.projects-lightbox__content img{display:block;max-width:100%;max-height:calc(85vh - 60px);object-fit:contain;background:var(--surface)}.projects-lightbox__close{position:absolute;top:12px;right:12px;width:36px;height:36px;border:none;border-radius:999px;background:#f87171eb;color:#fff;font-size:1.6rem;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .2s ease,transform .2s ease}.projects-lightbox__close:hover{background:#dc2626f2;transform:translateY(-2px)}.projects-lightbox__close:active{transform:translateY(0)}@keyframes lightboxIn{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.skills{padding:clamp(3rem,6vw,5rem) 0}.skills__title{position:relative;margin:0 0 var(--space-6);padding-left:var(--space-4);font-size:clamp(1.5rem,3.5vw,2rem);opacity:0;transform:translateY(12px);transition:opacity .5s ease,transform .5s ease}.skills__title:before{content:"";position:absolute;left:0;top:.2rem;bottom:.2rem;width:6px;border-radius:999px;background:var(--gradient);opacity:0;transform:scaleY(.4);transition:opacity .5s ease,transform .5s ease}.skills.is-visible .skills__title{opacity:1;transform:translateY(0)}.skills.is-visible .skills__title:before{opacity:1;transform:scaleY(1)}.skills__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-5)}.skills__group{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-5);box-shadow:var(--shadow-sm);opacity:0;transform:translateY(14px);transition:opacity .45s ease,transform .45s ease}.skills.is-visible .skills__group{opacity:1;transform:translateY(0)}.skills__group-title{margin:0 0 var(--space-4);font-size:1.1rem;font-weight:700;color:var(--text)}.skills__list{list-style:none;padding:0;margin:0;display:grid;gap:var(--space-3)}.skills__item{position:relative;overflow:hidden;background:#6366f112;border:1px solid rgba(99,102,241,.18);border-radius:var(--radius);padding:var(--space-3) var(--space-4);display:flex;align-items:center;gap:var(--space-3);font-size:1rem;color:var(--text);opacity:0;transform:translateY(12px);transition:opacity .35s ease,transform .35s ease,box-shadow .25s ease,border-color .25s ease;transition-delay:calc(var(--item-index, 0) * .08s + .12s)}.skills.is-visible .skills__item{opacity:1;transform:translateY(0)}.skills__item:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 0% 0%,rgba(99,102,241,.18),transparent 60%);opacity:0;transition:opacity .3s ease}.skills__item:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm);border-color:transparent}.skills__item:hover:after{opacity:1}.skills__item>*{position:relative;z-index:1}.skills__item-icon{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;flex-shrink:0;border-radius:var(--radius-sm);background:var(--surface);border:1px solid rgba(15,23,42,.08);box-shadow:var(--shadow-sm);overflow:hidden}.skills__item-icon i{font-size:22px;color:var(--primary-700)}.skills__name{font-weight:600}.skills__level{margin-left:auto;color:var(--muted);font-size:.92rem}.skills__item-icon img{width:100%;height:100%;object-fit:contain;padding:6px}.contact{padding:clamp(3rem,6vw,5rem) 0}.contact__container{max-width:720px}.contact__title{position:relative;margin:0 0 var(--space-6);padding-left:var(--space-4);font-size:clamp(1.5rem,3.5vw,2rem);opacity:0;transform:translateY(12px);transition:opacity .5s ease,transform .5s ease}.contact__title:before{content:"";position:absolute;left:0;top:.2rem;bottom:.2rem;width:6px;border-radius:999px;background:var(--gradient);opacity:0;transform:scaleY(.4);transition:opacity .5s ease,transform .5s ease}.contact.is-visible .contact__title{opacity:1;transform:translateY(0)}.contact.is-visible .contact__title:before{opacity:1;transform:scaleY(1)}.contact__form{display:flex;flex-direction:column;gap:var(--space-5)}.contact__form label{display:flex;flex-direction:column;font-weight:600;color:var(--text)}.contact__form input,.contact__form textarea{padding:.85rem .9rem;margin-top:.5rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.contact__form input:focus,.contact__form textarea:focus{border-color:transparent;outline:2px solid var(--ring);outline-offset:2px}.contact__form button[disabled]{cursor:not-allowed}.contact__status{display:inline-flex;align-items:center;gap:var(--space-3);font-weight:600;padding:var(--space-3) var(--space-4);border-radius:var(--radius);box-shadow:var(--shadow-sm);background:#6366f114;color:var(--primary-700);animation:fadeInScale .35s ease}.contact__status svg{color:currentColor}.contact__status--success{background:#10b9811f;color:#047857}.contact__status--error{background:#ef44441f;color:#b91c1c}[data-theme=dark] .contact__status--success{background:#10b9812e;color:#34d399}[data-theme=dark] .contact__status--error{background:#f8717129;color:#fca5a5}.footer{border-top:1px solid var(--border);padding:var(--space-6) 0;background:transparent}.footer__content{text-align:center;color:var(--muted)}.footer__links{margin-top:var(--space-2);display:flex;justify-content:center;gap:var(--space-4)}.footer__links a{position:relative;font-weight:600;color:var(--text);transition:color .2s ease}.footer__links a:after{content:"";position:absolute;left:0;bottom:-6px;width:100%;height:2px;border-radius:999px;background:var(--gradient);transform:scaleX(0);transform-origin:center;transition:transform .25s ease}.footer__links a:hover{color:var(--primary)}.footer__links a:hover:after{transform:scaleX(1)}.admin{min-height:100vh;background:var(--bg);color:var(--text)}.admin__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) clamp(1rem,3vw,2rem);border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:10;box-shadow:var(--shadow-sm)}.admin__brand{display:inline-flex;align-items:center;gap:var(--space-3);font-weight:700;letter-spacing:.01em}.admin__dot{width:12px;height:12px;border-radius:50%;background:var(--gradient);display:inline-block}.admin__title{font-size:1rem}.admin__badge{padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--muted);font-size:.9rem}.admin__logout{margin-left:var(--space-3)}.admin__content{padding:clamp(2rem,4vw,3rem) clamp(1rem,3vw,2rem)}.admin__lead{color:var(--muted);max-width:720px}.admin__nav{display:inline-flex;flex-wrap:wrap;gap:var(--space-3);margin:var(--space-3) 0 var(--space-4)}.admin__nav-link{display:inline-flex;align-items:center;gap:var(--space-2);padding:10px 14px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text);text-decoration:none;box-shadow:var(--shadow-sm);transition:transform .15s ease,box-shadow .2s ease}.admin__nav-link:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.admin__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-4);margin-top:var(--space-5)}.admin__form{margin-top:var(--space-5);display:grid;gap:var(--space-4)}.admin__card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-4);box-shadow:var(--shadow-sm)}.admin__card-header{display:flex;align-items:center;gap:var(--space-3);justify-content:space-between;flex-wrap:wrap}.admin__hint{color:var(--muted);font-size:.9rem}.admin__headers-grid{margin-top:var(--space-4);display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-3)}.admin__add-form{margin-top:var(--space-4);display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr)) auto;gap:var(--space-3);align-items:end}.admin__rows{display:grid;gap:var(--space-4);margin-top:var(--space-3)}.admin__row{border:1px dashed var(--border);border-radius:var(--radius);padding:var(--space-3)}.admin__row-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.admin__cells-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-3);margin-top:var(--space-3)}.admin__cell-toggle{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.admin__cell-toggle input{width:18px;height:18px;accent-color:var(--primary)}.admin__cell-toggle--active{border-color:#6366f199;box-shadow:0 0 0 3px #6366f12e;background:#6366f114}.admin__cell-label{font-weight:600;color:var(--text)}.admin__cell-header{display:inline-flex;align-items:center;gap:var(--space-2)}.admin__images-input{width:100%;min-height:68px;border-radius:var(--radius-sm);border:1px solid var(--border);padding:var(--space-2);font-size:.9rem;background:var(--surface);color:var(--text);resize:vertical}.admin__thumbs{display:none}.admin__error{color:#dc2626;font-weight:600}.admin__section-block{border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-3);background:var(--surface);box-shadow:var(--shadow-sm)}.admin__section-heading{font-weight:700;margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--border)}.admin__field{display:flex;flex-direction:column;gap:var(--space-2);font-size:.95rem}.admin__field span{color:var(--muted);font-weight:600}.admin__field input,.admin__field textarea{width:100%;border-radius:var(--radius-sm);border:1px solid var(--border);padding:var(--space-2) var(--space-3);font-size:.95rem;background:var(--surface);color:var(--text)}.admin__field textarea{min-height:60px;resize:vertical}.admin__field select{width:100%;border-radius:var(--radius-sm);border:1px solid var(--border);padding:var(--space-2) var(--space-3);background:var(--surface);color:var(--text)}.admin__field--inline input{width:clamp(180px,30vw,320px)}.admin__remove{border:none;background:#ef444414;color:#dc2626;border-radius:var(--radius-sm);padding:.4rem .6rem;cursor:pointer}.admin__add-row{height:36px;padding-inline:var(--space-4)}.admin__actions{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.admin__import-label{position:relative;overflow:hidden;cursor:pointer}.admin__import-label input{position:absolute;inset:0;opacity:0;cursor:pointer}.admin__status{color:var(--muted)}.admin__auth{position:fixed;inset:0;display:grid;place-items:center;background:#060c1699;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:30;padding:1rem}.admin__auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-lg);max-width:420px;width:100%}.admin__qr{display:block;margin:var(--space-3) auto;width:200px;height:200px;object-fit:contain}.admin__auth-input input{width:100%}.admin__auth-actions{margin-top:var(--space-3);display:flex;gap:var(--space-2);flex-wrap:wrap}.admin__modal-backdrop{position:fixed;inset:0;background:#0f172a73;display:grid;place-items:center;z-index:20;padding:1rem}.admin__modal{width:min(520px,100%);background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-lg);padding:var(--space-4)}.admin__modal-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-3)}.admin__modal-body{display:grid;gap:var(--space-3)}.admin__modal-actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-4)}.admin__modal-close{padding:.4rem .6rem}.admin__veille{margin-top:var(--space-4)}.admin__add-veille{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-2);align-items:center;width:100%}.admin__add-veille textarea{grid-column:1 / -2}.admin__add-veille .btn{justify-self:flex-end}.admin__veille-list{margin-top:var(--space-4);display:grid;gap:var(--space-3)}.admin__veille-item{border:1px dashed var(--border);border-radius:var(--radius);padding:var(--space-3);background:var(--surface)}.admin__veille-header{display:flex;align-items:center;gap:var(--space-2)}.admin__veille-header input{flex:1}.admin__veille-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-2);margin-top:var(--space-2)}.admin__veille-desc{width:100%;margin-top:var(--space-2);border-radius:var(--radius-sm);border:1px solid var(--border);padding:var(--space-2);font-size:.95rem;background:var(--surface);color:var(--text);resize:vertical}.admin__card h2{margin-top:0}.admin__card ul{margin:var(--space-3) 0 0;padding-left:var(--space-4);color:var(--muted)}.admin__card p{color:var(--muted);margin:var(--space-2) 0}@media (max-width: 600px){.admin__header{flex-direction:column;align-items:flex-start;gap:var(--space-2)}}
