:root{--accent: #e8ff47;--accent-dark: #b8cc00;--bg: #0d0d0d;--surface: #161616;--surface2: #1e1e1e;--text: #f0f0f0;--muted: #888;--border: #2a2a2a}.exp-list{display:flex;flex-direction:column;gap:.65rem}.exp-item{display:flex;flex-direction:column;gap:.75rem;padding:1.6rem 1.8rem;border:1px solid var(--border);border-radius:8px;background:var(--surface);position:relative;overflow:hidden;transition:border-color .25s ease,background .25s ease,transform .25s cubic-bezier(.16,1,.3,1)}.exp-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--border);border-radius:3px 0 0 3px;transition:background .25s ease}.exp-item:hover:before{background:var(--accent)}.exp-date{font-family:DM Mono,monospace;font-size:.68rem;color:var(--muted);background:#ffffff0a;border:1px solid var(--border);border-radius:3px;padding:.22rem .85rem .22rem .65rem;display:inline-flex;align-items:center;align-self:flex-start;width:max-content;letter-spacing:.06em;white-space:nowrap;transition:border-color .25s,color .25s}.exp-item:hover .exp-date{border-color:#e8ff4766;color:var(--accent)}.exp-content h3{font-size:1.05rem;font-weight:700;letter-spacing:-.01em;margin-bottom:.3rem;line-height:1.2}.exp-company{font-family:DM Mono,monospace;font-size:.75rem;color:var(--accent);margin-bottom:.65rem;letter-spacing:.02em}.exp-content p{font-family:DM Mono,monospace;font-size:.78rem;color:var(--muted);line-height:1.75}@media (max-width: 900px){.hamburger{display:flex}.nav-links{position:fixed;top:var(--nav-h, 64px);left:0;right:0;flex-direction:column;gap:0;background:#0d0d0dfa;border-bottom:1px solid var(--border);padding:1rem 1.5rem 1.5rem;transform:translateY(-110%);opacity:0;pointer-events:none;transition:transform .3s ease,opacity .3s ease;z-index:150}.nav-links.nav-open{transform:translateY(0)!important;opacity:1!important;pointer-events:all!important}.nav-links li{width:100%;padding:.65rem 0;border-bottom:1px solid #111}.nav-links li:last-child{border-bottom:none}.nav-links a{font-size:.95rem;color:var(--text);display:block}}@media (max-width: 640px){nav{padding:.9rem 1.25rem}}.reveal{opacity:0;transform:translateY(22px);transition:opacity .55s cubic-bezier(.16,1,.3,1),transform .55s cubic-bezier(.16,1,.3,1)}.hero-photo-frame{transition:transform .35s cubic-bezier(.16,1,.3,1)}.btn{transition:background .2s,color .2s,border-color .2s,transform .2s cubic-bezier(.16,1,.3,1),box-shadow .2s!important}.skill-item,.proj-card,.exp-item{transition:border-color .2s,background .2s,transform .25s cubic-bezier(.16,1,.3,1),box-shadow .25s}.skill-item:hover,.proj-card:hover,.exp-item:hover{transform:translate(6px);border-bottom-color:#e8ff478c!important;box-shadow:inset 3px 0 0 var(--accent),0 8px 32px #0006;background:#e8ff4706}.hero-tag{min-height:1.4em}.nav-open{transform:translateY(0)!important;opacity:1!important;pointer-events:all!important}.corner{position:fixed;width:28px;height:28px;border-color:#1e1e1e;border-style:solid;pointer-events:none;z-index:10}@media (max-width: 480px){.corner{display:none}}.scroll-top-btn{position:fixed;bottom:2rem;right:2rem;z-index:200;width:44px;height:44px;border-radius:50%;background:var(--surface);border:1px solid var(--border);color:var(--muted);font-size:1.1rem;font-family:var(--font-mono);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(12px) scale(.88);pointer-events:none;transition:opacity .25s ease,transform .25s cubic-bezier(.16,1,.3,1),border-color .2s,color .2s,background .2s}.scroll-top-btn--visible{opacity:1;transform:translateY(0) scale(1);pointer-events:all}.scroll-top-btn:hover{border-color:#e8ff4780;color:var(--accent);background:#e8ff470a;box-shadow:0 0 18px #e8ff4726}@media (max-width: 480px){.scroll-top-btn{bottom:1.2rem;right:1.2rem;width:40px;height:40px}}@media (max-width: 900px){nav{padding:1rem 1.5rem;overflow:visible;position:fixed}.hamburger{display:flex!important;position:relative;z-index:200}.nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:#0d0d0dfa;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);flex-direction:column;align-items:stretch;gap:0;z-index:150;border-top:1px solid var(--border);border-bottom:1px solid var(--border);box-shadow:0 12px 40px #000000b3;padding:.5rem 0 1rem}.nav-links.open{display:flex}.nav-links li{width:100%}.nav-links a,.nav-links a[href]{display:block;width:100%;font-size:1.1rem;color:var(--text);padding:1rem 2rem;text-align:left;border-bottom:1px solid var(--border);letter-spacing:.08em;transition:background .15s,color .15s;text-decoration:none}.nav-links li:last-child a{border-bottom:none}.nav-links a:hover,.nav-links a.active-link{background:var(--surface);color:var(--accent)}.nav-links a:after{display:none!important}.hero{grid-template-columns:1fr;padding:7rem 2rem 4rem;text-align:center}.hero-photo-wrap{order:-1}.hero-photo-frame{width:200px;height:240px}.hero-tag{justify-content:center}.hero-btns{justify-content:center;flex-wrap:wrap}.hero-desc{margin:0 auto 2.5rem;max-width:520px}.about-grid{grid-template-columns:1fr;gap:2rem}section,#portfolio-asignaturas{padding:4rem 2rem}}@media (max-width: 640px){nav{padding:.9rem 1.25rem}.hero{padding:6rem 1.25rem 3rem}.hero-photo-frame{width:160px;height:200px}.hero-btns{flex-direction:column;align-items:center;gap:.7rem}.hero-btns .btn{width:100%;max-width:280px;text-align:center;justify-content:center}section{padding:3.5rem 1.25rem}.exp-item{grid-template-columns:1fr;gap:.4rem}.contact-wrap{padding:2.5rem 1.25rem}.projects-grid{grid-template-columns:1fr!important}}#anim-loader{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg, #0d0d0d);z-index:9000;transform-origin:right;pointer-events:none;transition:transform .72s cubic-bezier(.77,0,.18,1),opacity .15s ease .68s}#anim-loader.anim-loader-out{transform:scaleX(0);opacity:0}@keyframes heroFadeUp{to{opacity:1;transform:translateY(0)}}@keyframes heroFadeRight{0%{opacity:0;transform:translate(44px)}to{opacity:1;transform:translate(0)}}.hero-glow{position:absolute;top:-120px;left:-80px;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(232,255,71,.055) 0%,transparent 62%);pointer-events:none;animation:blobDrift 14s ease-in-out infinite alternate;will-change:transform}.hero-glow:after{content:"";position:absolute;top:40%;right:-200px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(136,170,255,.04) 0%,transparent 65%);animation:blobDrift 18s ease-in-out infinite alternate-reverse}@keyframes blobDrift{0%{transform:translate(0) scale(1)}33%{transform:translate(30px,-20px) scale(1.04)}66%{transform:translate(-15px,25px) scale(.97)}to{transform:translate(20px,-10px) scale(1.02)}}.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);transition-delay:var(--anim-delay, 0s);will-change:opacity,transform}.reveal.visible{opacity:1;transform:translateY(0)}.reveal.from-left{transform:translate(-28px)}.reveal.from-right{transform:translate(28px)}.reveal.from-left.visible,.reveal.from-right.visible{transform:none}.reveal.scale-in{transform:translateY(16px) scale(.97)}.reveal.scale-in.visible{transform:translateY(0) scale(1)}.reveal-clip{opacity:0;clip-path:inset(0 0 100% 0);transition:opacity .01s linear,clip-path .75s cubic-bezier(.16,1,.3,1);transition-delay:var(--anim-delay, 0s);will-change:clip-path}.reveal-clip.visible{opacity:1;clip-path:inset(0 0 0% 0)}.reveal-clip.wipe-right{clip-path:inset(0 100% 0 0)}.reveal-clip.wipe-right.visible{clip-path:inset(0 0% 0 0)}.reveal:nth-child(1){--anim-delay: 0s}.reveal:nth-child(2){--anim-delay: .08s}.reveal:nth-child(3){--anim-delay: .16s}.reveal:nth-child(4){--anim-delay: .24s}.reveal:nth-child(5){--anim-delay: .32s}.reveal:nth-child(6){--anim-delay: .4s}.reveal:nth-child(7){--anim-delay: .48s}.reveal:nth-child(8){--anim-delay: .56s}.reveal:nth-child(9){--anim-delay: .64s}.reveal:nth-child(n+10){--anim-delay: .7s}.skills-grid .reveal:nth-child(n){--anim-delay: calc(var(--skill-i, 0) * 55ms)}.section-title{position:relative;display:inline-block}.section-title:after{content:"";position:absolute;bottom:-5px;left:0;width:0;height:2px;background:var(--accent, #e8ff47);box-shadow:0 0 10px #e8ff4766;transition:width .85s cubic-bezier(.16,1,.3,1) .2s}.section-title.title-line-drawn:after{width:100%}.parallax{transform:translateY(var(--parallax-y, 0px));will-change:transform;transition:transform .05s linear}.parallax-slow{--parallax-speed: .08}.parallax-med{--parallax-speed: .14}.parallax-fast{--parallax-speed: .22}.project-card,.card{transition:transform .32s cubic-bezier(.16,1,.3,1),border-color .32s ease,box-shadow .32s ease!important;position:relative;overflow:hidden}.project-card:after,.card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at var(--mouse-x, 50%) var(--mouse-y, 50%),rgba(232,255,71,.055) 0%,transparent 55%);opacity:0;transition:opacity .3s ease;pointer-events:none;border-radius:inherit}.project-card:hover:after,.card:hover:after{opacity:1}.project-card:hover,.card:hover{transform:translateY(-8px)!important;border-color:#e8ff4761!important;box-shadow:0 0 0 1px #e8ff4714,0 14px 48px #0009!important}.project-card:before,.card:before{background:var(--accent, #e8ff47)!important;box-shadow:0 0 10px #e8ff478c;height:2px!important;transition:transform .4s cubic-bezier(.16,1,.3,1)!important}.exp-item{transition:transform .28s cubic-bezier(.16,1,.3,1),border-color .28s ease,background .28s ease!important}.exp-item:hover{transform:translate(8px)!important;border-color:#e8ff4752!important;background:#e8ff4706!important}.skill-tag,.project-tag{transition:color .22s ease,border-color .22s ease,background .22s ease,transform .22s cubic-bezier(.16,1,.3,1)!important}.skill-tag:hover,.project-tag:hover{color:var(--accent, #e8ff47)!important;border-color:#e8ff4780!important;background:#e8ff4712!important;transform:translateY(-3px)!important}.cert-badge{transition:transform .28s cubic-bezier(.16,1,.3,1),box-shadow .28s ease,border-color .28s ease!important}.cert-badge:hover{transform:translateY(-4px)!important;border-color:#e8ff47a6!important;box-shadow:0 8px 24px #00000080,0 0 14px #e8ff4724!important}.btn{transition:transform .25s cubic-bezier(.16,1,.3,1),background .22s ease,color .22s ease,border-color .22s ease,box-shadow .22s ease!important;position:relative;overflow:hidden}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffff1a;border-radius:inherit;transform:scale(0);opacity:1;transition:transform .4s ease,opacity .4s ease;pointer-events:none}.btn.btn-clicked:after{transform:scale(2.5);opacity:0}.btn:hover{transform:translateY(-3px)!important}.btn:active{transform:translateY(0) scale(.97)!important;transition-duration:.08s!important}.btn-primary:hover{box-shadow:0 6px 24px #e8ff4752!important}.btn-outline:hover{box-shadow:0 4px 18px #00000073!important}.btn-accent-outline:hover{box-shadow:0 6px 22px #e8ff4747!important}.nav-links a{position:relative;transition:color .22s ease!important}.nav-links a:after{content:"";position:absolute;bottom:-3px;left:0;width:0;height:1.5px;background:var(--accent, #e8ff47);box-shadow:0 0 7px #e8ff478c;transition:width .3s cubic-bezier(.16,1,.3,1)}.nav-links a:hover:after,.nav-links a.active-link:after{width:100%}.project-link{transition:color .22s ease,transform .22s cubic-bezier(.16,1,.3,1)!important}.project-link:hover{color:var(--accent, #e8ff47)!important;transform:translate(4px)!important}.hero-photo-frame{transition:transform .4s cubic-bezier(.16,1,.3,1)!important;animation:photoGlow 3.5s ease-in-out infinite alternate}@keyframes photoGlow{0%{box-shadow:4px 4px 0 var(--accent, #e8ff47)}to{box-shadow:7px 7px 0 var(--accent, #e8ff47),0 0 38px #e8ff471a}}nav{transition:padding .35s ease,background-color .35s ease,box-shadow .35s ease!important}nav.nav-compact{padding-top:.5rem!important;padding-bottom:.5rem!important;background:#0d0d0df7!important;box-shadow:0 1px #ffffff0d!important}#anim-progress{position:fixed;top:0;left:0;height:2px;width:100%;background:var(--accent, #e8ff47);box-shadow:0 0 8px #e8ff4780;transform-origin:left;transform:scaleX(0);transition:transform .1s linear;pointer-events:none;z-index:9999}#anim-cursor-dot{position:fixed;top:0;left:0;width:8px;height:8px;border-radius:50%;background:var(--accent, #e8ff47);mix-blend-mode:difference;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .15s,height .15s;will-change:transform}#anim-cursor-ring{position:fixed;top:0;left:0;width:32px;height:32px;border-radius:50%;border:1px solid rgba(232,255,71,.35);pointer-events:none;z-index:9997;transform:translate(-50%,-50%);transition:width .3s ease,height .3s ease,border-color .3s ease,background .3s ease;will-change:transform}body.cursor-on-interactive #anim-cursor-dot{width:12px;height:12px}body.cursor-on-interactive #anim-cursor-ring{width:46px;height:46px;border-color:#e8ff47a6;background:#e8ff470a}@keyframes animBlink{0%,to{opacity:1}50%{opacity:0}}.anim-cursor{color:var(--accent, #e8ff47);animation:animBlink .75s step-end infinite;margin-left:1px}@media (prefers-reduced-motion: reduce){#anim-loader{display:none!important}.hero-tag,.hero-left h1,.hero-desc,.hero-btns,.hero-photo-wrap{opacity:1!important;transform:none!important;animation:none!important}.hero-glow{animation:none!important}.hero-glow:after{animation:none!important}.reveal,.reveal-clip{opacity:1!important;transform:none!important;clip-path:none!important;transition:none!important}.section-title:after{width:100%!important;transition:none!important}.hero-photo-frame{animation:none!important}.parallax{transform:none!important;will-change:auto!important}.project-card:hover,.card:hover,.skill-tag:hover,.project-tag:hover,.exp-item:hover,.cert-badge:hover,.btn:hover,.btn:active,.project-link:hover{transform:none!important}#anim-progress,#anim-cursor-dot,#anim-cursor-ring{display:none!important}}.skip-link{position:absolute;top:-100px;left:1rem;background:var(--accent);color:#0d0d0d;padding:.6rem 1.2rem;border-radius:0 0 4px 4px;font-family:DM Mono,monospace;font-size:.85rem;font-weight:500;z-index:9999;transition:top .2s}.skip-link:focus{top:0}a{text-decoration:none}body{background:var(--bg);color:var(--text);font-family:Syne,sans-serif;line-height:1.6;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:60px 60px;opacity:.15;pointer-events:none;z-index:-1}nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:1.2rem 4rem;background:#0d0d0deb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.nav-logo{font-family:DM Mono,monospace;font-size:.9rem;color:var(--accent);letter-spacing:.05em}.nav-links{display:flex;gap:2rem;list-style:none}.nav-links a{color:var(--muted);text-decoration:none;font-size:.85rem;font-family:DM Mono,monospace;letter-spacing:.05em;transition:color .2s}.nav-links a:hover,.nav-links a.active-link{color:var(--accent)}.portfolio-hero{min-height:38vh;display:flex;align-items:flex-end;padding:9rem 4rem 4rem;max-width:1200px;margin:0 auto;position:relative;overflow:hidden}.portfolio-hero-glow{position:absolute;top:-120px;left:-80px;width:500px;height:500px;background:radial-gradient(circle,rgba(232,255,71,.05) 0%,transparent 70%);pointer-events:none}.portfolio-hero-subtitle{font-family:DM Mono,monospace;font-size:.8rem;color:var(--accent);letter-spacing:.15em;text-transform:uppercase;margin-bottom:1rem;display:flex;align-items:center;gap:.6rem}.portfolio-hero-line{width:24px;height:1px;background:var(--accent);display:inline-block}.portfolio-hero-title{font-size:clamp(2.4rem,5vw,4rem);font-weight:800;line-height:1;letter-spacing:-.03em;margin-bottom:1.2rem}.portfolio-hero-title span{color:var(--accent)}.portfolio-hero-desc{font-family:DM Mono,monospace;font-size:.9rem;color:var(--muted);max-width:560px;line-height:1.8;margin-bottom:2rem}.portfolio-hero-btn{font-size:.82rem}.hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:4rem;padding:8rem 4rem 4rem;position:relative;overflow:hidden;max-width:1200px;margin:0 auto}.hero-glow{position:absolute;top:-100px;right:-100px;width:500px;height:500px;background:radial-gradient(circle,rgba(232,255,71,.07) 0%,transparent 70%);pointer-events:none}.hero-tag{font-family:DM Mono,monospace;font-size:.8rem;color:var(--accent);letter-spacing:.15em;text-transform:uppercase;margin-bottom:1.2rem;display:flex;align-items:center;gap:.6rem}.hero-tag:before{content:"";width:24px;height:1px;background:var(--accent)}.hero h1{font-size:clamp(2.8rem,6vw,5.5rem);font-weight:800;line-height:.95;letter-spacing:-.03em;margin-bottom:1.5rem}.hero h1 span{color:var(--accent)}.hero-surname{display:block;font-size:.42em;font-weight:700;letter-spacing:.01em;line-height:1.4;margin-top:.15em}.hero-desc{font-family:DM Mono,monospace;font-size:.95rem;color:var(--muted);max-width:480px;line-height:1.8;margin-bottom:2.5rem}.hero-btns{display:flex;gap:1rem;flex-wrap:wrap}.hero-photo-wrap{display:flex;justify-content:center;align-items:center;position:relative}.hero-photo-frame{position:relative;width:320px;height:380px}.hero-photo-frame:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border:1px solid var(--border);border-radius:12px}.hero-photo-frame:after{content:"";position:absolute;top:12px;left:12px;right:-12px;bottom:-12px;border:1px solid #222;border-radius:12px;z-index:-1}.hero-photo{width:100%;height:100%;object-fit:cover;object-position:center top;border-radius:10px;filter:grayscale(20%)}.hero-badge{position:absolute;bottom:-16px;left:50%;transform:translate(-50%);background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:.5rem 1.2rem;font-family:DM Mono,monospace;font-size:.72rem;color:var(--muted);white-space:nowrap;display:flex;align-items:center;gap:.5rem}.hero-badge-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:pulse 2s ease-in-out infinite;flex-shrink:0}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.8rem;border-radius:4px;font-family:DM Mono,monospace;font-size:.85rem;letter-spacing:.05em;cursor:pointer;text-decoration:none;transition:all .2s}.btn-primary{background:var(--accent);color:#0d0d0d;border:2px solid var(--accent);font-weight:500}.btn-primary:hover{background:var(--accent-dark);border-color:var(--accent-dark)}.btn-outline{background:transparent;color:var(--text);border:1px solid var(--border)}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.btn-accent-outline{background:transparent;color:var(--accent);border:1px solid var(--accent)}.btn-accent-outline:hover{background:var(--accent);color:#0d0d0d}section{padding:6rem 4rem;max-width:1100px;margin:0 auto}.section-label{font-family:DM Mono,monospace;font-size:.75rem;color:var(--accent);letter-spacing:.2em;text-transform:uppercase;margin-bottom:1rem;display:flex;align-items:center;gap:.8rem}.section-label:after{content:"";flex:1;height:1px;background:var(--border);max-width:80px}.section-title{font-size:clamp(2rem,4vw,3rem);font-weight:700;letter-spacing:-.02em;margin-bottom:3rem}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}.about-text p{font-family:DM Mono,monospace;font-size:.9rem;color:var(--muted);line-height:1.9;margin-bottom:1.2rem}.skills-grid{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem}.skill-tag{font-family:DM Mono,monospace;font-size:.75rem;padding:.4rem .9rem;border:1px solid var(--border);border-radius:2px;color:var(--muted);transition:all .2s}.skill-tag:hover{border-color:var(--accent);color:var(--accent)}.cert-badge{display:inline-flex;align-items:center;gap:.6rem;background:var(--surface);border:1px solid #3a3a1a;border-radius:4px;padding:.5rem 1rem;font-family:DM Mono,monospace;font-size:.75rem;color:var(--accent);margin-top:1.5rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:2rem;transition:border-color .25s,transform .25s;position:relative;overflow:hidden}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s}.project-card:hover{border-color:#333;transform:translateY(-4px)}.project-card:hover:before{transform:scaleX(1)}.project-num{font-family:DM Mono,monospace;font-size:.75rem;color:var(--accent);margin-bottom:1rem}.project-card h3{font-size:1.2rem;font-weight:700;margin-bottom:.8rem;letter-spacing:-.01em}.project-card p{font-family:DM Mono,monospace;font-size:.82rem;color:var(--muted);line-height:1.7;margin-bottom:1.5rem}.project-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.project-tag{font-family:DM Mono,monospace;font-size:.7rem;padding:.25rem .6rem;background:var(--surface2);border-radius:2px;color:var(--muted)}.project-links{display:flex;gap:1rem}.project-link{font-family:DM Mono,monospace;font-size:.78rem;color:var(--muted);text-decoration:none;display:flex;align-items:center;gap:.3rem;transition:color .2s}.project-link:hover{color:var(--accent)}.exp-list{display:flex;flex-direction:column}.exp-item{display:grid;grid-template-columns:160px 1fr;gap:2rem;padding:2rem 0;border-bottom:1px solid var(--border)}.exp-item:first-child{border-top:1px solid var(--border)}.exp-date{font-family:DM Mono,monospace;font-size:.78rem;color:var(--muted);padding-top:.2rem}.exp-content h3{font-size:1.05rem;font-weight:700;margin-bottom:.3rem}.exp-company{font-family:DM Mono,monospace;font-size:.82rem;color:var(--accent);margin-bottom:.8rem}.exp-content p{font-family:DM Mono,monospace;font-size:.82rem;color:var(--muted);line-height:1.7}.contact-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:4rem;text-align:center;position:relative;overflow:hidden}.contact-wrap:before{content:"";position:absolute;top:-100px;left:50%;transform:translate(-50%);width:400px;height:400px;background:radial-gradient(circle,rgba(232,255,71,.05) 0%,transparent 70%);pointer-events:none}.contact-wrap h2{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;letter-spacing:-.03em;margin-bottom:1rem;position:relative}.contact-wrap h2 span{color:var(--accent)}.contact-wrap p{font-family:DM Mono,monospace;font-size:.9rem;color:var(--muted);margin-bottom:2.5rem;position:relative}.contact-links{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.contact-form{display:flex;flex-direction:column;gap:1rem;margin-top:2rem;text-align:left;position:relative}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-family:DM Mono,monospace;font-size:.72rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}.form-group input,.form-group textarea{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:.75rem 1rem;color:var(--text);font-family:DM Mono,monospace;font-size:.85rem;transition:border-color .2s;outline:none;width:100%;resize:vertical}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent)}.form-group input::placeholder,.form-group textarea::placeholder{color:#444}.captcha-group{display:flex;justify-content:center;align-items:center}.form-honeypot{display:none!important}.form-submit-row{display:flex;justify-content:center;margin-top:.5rem}.btn-submit{min-width:200px;justify-content:center;position:relative}.btn-submit:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.form-feedback{font-family:DM Mono,monospace;font-size:.82rem;text-align:center;padding:.75rem 1rem;border-radius:4px;display:none;margin-top:.5rem}.form-feedback.success{display:block;background:#e8ff4714;border:1px solid var(--accent);color:var(--accent)}.form-feedback.error{display:block;background:#ff505014;border:1px solid #f55;color:#f88}.rate-info{font-family:DM Mono,monospace;font-size:.7rem;color:#444;text-align:center;margin-top:.5rem}@media (max-width: 600px){.form-row{grid-template-columns:1fr}}footer{border-top:1px solid var(--border);padding:2rem 4rem;display:flex;justify-content:space-between;align-items:center;font-family:DM Mono,monospace;font-size:.75rem;color:var(--muted)}.footer-links{display:flex;gap:1.5rem}.footer-links a{color:var(--muted);text-decoration:none;transition:color .2s}.footer-links a:hover{color:var(--accent)}#portfolio-asignaturas{padding:6rem 4rem;max-width:1100px;margin:0 auto}.portfolio-intro{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:2.5rem 3rem;margin-bottom:3rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}.portfolio-intro-text h3{font-size:1.3rem;font-weight:700;margin-bottom:.5rem}.portfolio-intro-text p{font-family:DM Mono,monospace;font-size:.85rem;color:var(--muted);line-height:1.7}.portfolio-stat-big{font-size:3.5rem;font-weight:800;color:var(--accent);line-height:1;text-align:center}.portfolio-stat-big span{display:block;font-family:DM Mono,monospace;font-size:.7rem;color:var(--muted);font-weight:400;letter-spacing:.15em;text-transform:uppercase;margin-top:.4rem}.module-nav{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:2rem}.mod-btn{display:flex;align-items:center;gap:.8rem;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:.8rem 1.2rem;cursor:pointer;transition:all .2s;text-align:left;color:var(--text);font-family:Syne,sans-serif}.mod-btn:hover{border-color:#444;background:var(--surface2)}.mod-btn.active{border-color:var(--accent);background:#e8ff470d}.mod-code{font-family:DM Mono,monospace;font-size:.68rem;letter-spacing:.12em;color:var(--accent);text-transform:uppercase}.mod-name{font-size:.78rem;color:var(--muted);font-weight:400;max-width:160px}.mod-btn.active .mod-name{color:var(--text)}.mod-section{display:none}.mod-section.active{display:block}.mod-section-header{display:flex;align-items:baseline;gap:1rem;margin-bottom:2.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.mod-section-number{font-family:DM Mono,monospace;font-size:.75rem;color:var(--accent);letter-spacing:.1em}.mod-section-title{font-size:1.4rem;font-weight:700;letter-spacing:-.02em}.trim-tabs{display:flex;gap:0;margin-bottom:2.5rem;border-bottom:1px solid var(--border)}.trim-tab{padding:.6rem 1.5rem;font-family:DM Mono,monospace;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;color:var(--muted);border:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s;background:none}.trim-tab:hover{color:var(--text)}.trim-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.trim-pane{display:none}.trim-pane.active{display:block}.ra-block{margin-bottom:3rem}.ra-label{display:inline-flex;align-items:center;gap:.6rem;background:#e8ff470d;border:1px solid rgba(232,255,71,.15);border-radius:3px;padding:.4rem .9rem;margin-bottom:1.5rem;font-family:DM Mono,monospace;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}.ra-dot{width:5px;height:5px;background:var(--accent);border-radius:50%;flex-shrink:0}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.2rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1.5rem;position:relative;overflow:hidden;transition:all .25s;cursor:pointer;text-decoration:none;display:block;color:inherit}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s}.card:hover{border-color:#383838;background:var(--surface2);transform:translateY(-2px)}.card:hover:before{transform:scaleX(1)}.card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;opacity:0;transition:opacity .3s;background:radial-gradient(800px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),rgba(232,255,71,.08),transparent 40%);pointer-events:none;z-index:0}.card.card-shine:after{opacity:1}.card>*{position:relative;z-index:1}.card-badges{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.7rem}.badge{display:inline-flex;align-items:center;gap:4px;border-radius:3px;padding:2px 7px;font-family:DM Mono,monospace;font-size:.62rem;letter-spacing:.08em;text-transform:uppercase}.badge-pdf{background:#c940401f;border:1px solid rgba(201,64,64,.25);color:#e87a7a}.badge-docx{background:#4a90d91f;border:1px solid rgba(74,144,217,.25);color:#7ab4e8}.badge-canva{background:#00c4cc1f;border:1px solid rgba(0,196,204,.25);color:#5ee6ea}.badge-grupo{background:#e8c5471f;border:1px solid rgba(232,197,71,.25);color:#e8c547}.badge-practica{background:#9664dc1f;border:1px solid rgba(150,100,220,.25);color:#c09cef}.badge-cont{background:#e8ff4714;border:1px solid rgba(232,255,71,.2);color:var(--accent)}.badge-genially{background:#ff64321f;border:1px solid rgba(255,100,50,.25);color:#ff8060}.badge-web{background:#50c8781f;border:1px solid rgba(80,200,120,.25);color:#6ed896}.badge .dot{width:4px;height:4px;border-radius:50%;background:currentColor}.card h3{font-size:1rem;font-weight:700;line-height:1.3;margin-bottom:.5rem;color:var(--text)}.card p{font-family:DM Mono,monospace;font-size:.78rem;line-height:1.6;color:var(--muted)}.card-footer{margin-top:1.2rem;padding-top:.9rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.card-file{font-family:DM Mono,monospace;font-size:.67rem;color:#555;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:220px}.card-arrow{color:var(--accent);font-size:1rem;transition:transform .2s}.card:hover .card-arrow{transform:translate(4px)}.stats-row{display:flex;gap:2rem;flex-wrap:wrap;margin-top:3rem;padding:2rem 2.5rem;background:var(--surface);border:1px solid var(--border);border-radius:8px}.stat{display:flex;flex-direction:column;gap:.2rem}.stat-num{font-size:2.5rem;font-weight:800;color:var(--accent);line-height:1}.stat-lbl{font-family:DM Mono,monospace;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:500;display:none;align-items:center;justify-content:center;padding:2rem}.modal-overlay.open{display:flex}.modal{background:var(--surface);border:1px solid #383838;border-radius:12px;padding:2.5rem;max-width:560px;width:100%;position:relative;animation:modalIn .2s ease}@keyframes modalIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:1rem;right:1.2rem;background:none;border:none;color:var(--muted);font-size:1.3rem;cursor:pointer;transition:color .2s;font-family:DM Mono,monospace}.modal-close:hover{color:var(--text)}.modal h2{font-size:1.3rem;font-weight:700;margin-bottom:1rem}.modal p{font-family:DM Mono,monospace;font-size:.85rem;color:var(--muted);line-height:1.8;margin-bottom:.7rem}.modal-file{margin-top:1.2rem;background:#e8ff470a;border:1px solid rgba(232,255,71,.15);border-radius:6px;padding:.8rem 1rem;font-family:DM Mono,monospace;font-size:.75rem;color:var(--accent);line-height:1.6}.modal-group{margin-top:.8rem;background:#e8c5470d;border:1px solid rgba(232,197,71,.2);border-radius:6px;padding:.8rem 1rem;font-family:DM Mono,monospace;font-size:.75rem;color:#e8c547;line-height:1.6}.modal-link{display:inline-flex;align-items:center;gap:.5rem;margin-top:1rem;background:#00c4cc12;border:1px solid rgba(0,196,204,.2);border-radius:6px;padding:.7rem 1rem;text-decoration:none;font-family:DM Mono,monospace;font-size:.75rem;color:#5ee6ea;transition:background .2s}.modal-link:hover{background:#00c4cc24}.modal-open-link{display:inline-flex;align-items:center;gap:.5rem;margin-top:1rem;background:var(--accent);color:#0d0d0d;border-radius:4px;padding:.7rem 1.2rem;text-decoration:none;font-family:DM Mono,monospace;font-size:.78rem;font-weight:500;transition:background .2s}.modal-open-link:hover{background:var(--accent-dark)}.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;z-index:200}.hamburger span{display:block;width:24px;height:2px;background:var(--text);border-radius:2px;transition:transform .3s,opacity .3s}.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}@media (max-width: 900px){nav{padding:1rem 1.5rem;overflow:visible}.hamburger{display:flex;position:relative;z-index:10}.nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:#0d0d0d;flex-direction:column;align-items:stretch;gap:0;z-index:10;border-top:1px solid var(--border);border-bottom:1px solid var(--border);box-shadow:0 12px 32px #0009;padding:.5rem 0 1rem}.nav-links.open{display:flex}.nav-links li{width:100%}.nav-links a{display:block;width:100%;font-size:1.15rem;color:var(--text);padding:1.1rem 1.5rem;text-align:center;border-bottom:1px solid var(--border);letter-spacing:.12em;transition:background .15s,color .15s}.nav-links a:last-child{border-bottom:none}.nav-links a:hover,.nav-links a.active-link{background:var(--surface);color:var(--accent)}.hero{grid-template-columns:1fr;padding:7rem 2rem 4rem;text-align:center}.hero-photo-wrap{order:-1}.hero-photo-frame{width:200px;height:240px}.hero-tag{justify-content:center}.hero-btns{justify-content:center;flex-wrap:wrap}.hero-desc{margin:0 auto 2.5rem;max-width:520px}.about-grid{grid-template-columns:1fr;gap:2rem}section,#portfolio-asignaturas{padding:4rem 2rem}}@media (max-width: 640px){nav{padding:1rem 1.25rem}.hero-photo-frame{width:160px;height:190px}h1{font-size:clamp(2rem,8vw,3.5rem)!important}.hero-btns{flex-direction:column;align-items:center;gap:.75rem}.hero-btns .btn{width:100%;max-width:280px;text-align:center;justify-content:center}section,#portfolio-asignaturas{padding:3.5rem 1.25rem}.section-title{font-size:clamp(1.5rem,6vw,2.2rem)!important}.exp-item{grid-template-columns:1fr;gap:.5rem}.contact-wrap{padding:2rem 1.25rem}footer{padding:1.5rem 1.25rem;flex-direction:column;gap:.5rem;text-align:center}.portfolio-intro{flex-direction:column;text-align:center}.skills-grid{grid-template-columns:1fr 1fr!important}.projects-grid,.asignaturas-grid{grid-template-columns:1fr!important}}:root{--priority-high: #ff5f57;--priority-med: #febc2e;--priority-low: #28c840}.db-loading{position:fixed;top:0;right:0;bottom:0;left:0;background:#0d0d0dd9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;z-index:9000;font-family:DM Mono,monospace;font-size:.8rem;color:#555;transition:opacity .3s}.db-loading.hidden{opacity:0;pointer-events:none}.db-spinner{width:28px;height:28px;border:2px solid #222;border-top-color:var(--accent);border-radius:50%;animation:db-spin .7s linear infinite}@keyframes db-spin{to{transform:rotate(360deg)}}.db-error{display:none;background:#ff5f5714;border:1px solid rgba(255,95,87,.25);border-radius:5px;padding:.75rem 1.1rem;font-family:DM Mono,monospace;font-size:.72rem;color:#ff7070;margin-bottom:1.5rem;align-items:center;gap:.6rem}.db-error.show{display:flex}.sync-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:#28c840;margin-left:.5rem;vertical-align:middle;transition:background .3s}.sync-dot.syncing{background:#febc2e;animation:pulse-sync .8s ease-in-out infinite}.sync-dot.error{background:#ff5f57;animation:none}@keyframes pulse-sync{0%,to{opacity:1}50%{opacity:.3}}.dash-wrap{max-width:900px;margin:0 auto;padding:8rem 2rem 5rem;min-height:calc(100vh - 140px)}.dash-top{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:2.5rem}.dash-eyebrow{font-family:DM Mono,monospace;font-size:.68rem;color:var(--muted);letter-spacing:.12em;margin-bottom:.4rem}.dash-h1{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;letter-spacing:-.03em;line-height:1}.dash-h1 span{color:var(--accent)}.dash-top-actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.btn-new-task{font-family:DM Mono,monospace;font-size:.78rem;font-weight:500;color:#0d0d0d;background:var(--accent);border:none;border-radius:4px;padding:.65rem 1.4rem;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:.4rem;white-space:nowrap}.btn-new-task:hover{background:#d4e83e}.btn-back{font-family:DM Mono,monospace;font-size:.62rem;letter-spacing:.08em;color:#b8f;background:#bb88ff14;border:1px solid rgba(187,136,255,.25);border-radius:3px;padding:.28rem .75rem;text-decoration:none;transition:background .15s,border-color .15s}.btn-back:hover{background:#bb88ff2e;border-color:#bb88ff80}.stats-bar{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:2rem}.stat-pill{font-family:DM Mono,monospace;font-size:.68rem;letter-spacing:.08em;padding:.35rem .9rem;border-radius:3px;border:1px solid var(--border);background:var(--surface);color:var(--muted);display:flex;align-items:center;gap:.45rem}.stat-pill b{color:var(--text);font-weight:500}.stat-pill.done b{color:var(--accent)}.stat-pill.doing b{color:#8af}.stat-pill.high b{color:var(--priority-high)}.task-form{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:1.5rem;margin-bottom:2rem;display:grid;gap:1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-row.three{grid-template-columns:1fr 1fr 1fr}.field{display:flex;flex-direction:column;gap:.35rem}.field label{font-family:DM Mono,monospace;font-size:.62rem;color:var(--muted);letter-spacing:.12em}.field input,.field select,.field textarea{background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text);font-family:DM Mono,monospace;font-size:.82rem;padding:.6rem .8rem;outline:none;transition:border-color .2s;width:100%}.field input:focus,.field select:focus,.field textarea:focus{border-color:#e8ff4780}.field textarea{resize:vertical;min-height:70px;line-height:1.6}.field select option{background:#111}.form-actions{display:flex;justify-content:flex-end;gap:.75rem}.btn-cancel{font-family:DM Mono,monospace;font-size:.78rem;color:var(--muted);background:none;border:1px solid var(--border);border-radius:4px;padding:.6rem 1.2rem;cursor:pointer;transition:color .2s,border-color .2s}.btn-cancel:hover{color:var(--text);border-color:#444}.btn-add-confirm{font-family:DM Mono,monospace;font-size:.78rem;font-weight:500;color:#0d0d0d;background:var(--accent);border:none;border-radius:4px;padding:.6rem 1.4rem;cursor:pointer;transition:background .2s}.btn-add-confirm:hover{background:#d4e83e}.view-bar{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.view-label{font-family:DM Mono,monospace;font-size:.62rem;color:var(--muted);letter-spacing:.1em}.view-btn{font-family:DM Mono,monospace;font-size:.68rem;letter-spacing:.06em;color:var(--muted);background:var(--surface);border:1px solid var(--border);border-radius:3px;padding:.3rem .8rem;cursor:pointer;transition:all .15s}.view-btn:hover{color:var(--text);border-color:#444}.view-btn.active{color:var(--accent);border-color:#e8ff4766;background:#e8ff470d}.filters-bar{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin-bottom:1.5rem}.filter-btn{font-family:DM Mono,monospace;font-size:.68rem;letter-spacing:.08em;color:var(--muted);background:var(--surface);border:1px solid var(--border);border-radius:3px;padding:.35rem .85rem;cursor:pointer;transition:all .15s}.filter-btn:hover{color:var(--text);border-color:#444}.filter-btn.active{color:var(--accent);border-color:#e8ff4766;background:#e8ff470d}.filter-sep{width:1px;height:18px;background:var(--border);margin:0 .2rem}.sort-select{font-family:DM Mono,monospace;font-size:.68rem;color:var(--muted);background:var(--surface);border:1px solid var(--border);border-radius:3px;padding:.35rem .7rem;cursor:pointer;outline:none;margin-left:auto}.tasks-list{display:flex;flex-direction:column;gap:.7rem}.task-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:1.1rem 1.3rem;display:grid;grid-template-columns:auto 1fr auto;gap:.9rem;align-items:start;transition:border-color .2s,opacity .2s;position:relative;overflow:hidden}.task-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px}.task-card[data-priority=alta]:before{background:var(--priority-high)}.task-card[data-priority=media]:before{background:var(--priority-med)}.task-card[data-priority=baja]:before{background:var(--priority-low)}.task-card.is-done{opacity:.5}.task-card.is-done .task-title{text-decoration:line-through;color:var(--muted)}.task-check{width:18px;height:18px;border:1.5px solid var(--border);border-radius:3px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.7rem;margin-top:2px;transition:border-color .15s,background .15s;background:var(--bg);-webkit-user-select:none;user-select:none}.task-check:hover{border-color:var(--accent)}.task-check.checked{background:var(--accent);border-color:var(--accent);color:#0d0d0d}.task-body{min-width:0}.task-header{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin-bottom:.3rem}.task-title{font-size:.92rem;font-weight:600;letter-spacing:-.01em;word-break:break-word}.task-badge{font-family:DM Mono,monospace;font-size:.58rem;letter-spacing:.1em;padding:.15rem .5rem;border-radius:2px;border:1px solid;flex-shrink:0}.badge-priority-alta{color:var(--priority-high);border-color:#ff5f574d}.badge-priority-media{color:var(--priority-med);border-color:#febc2e4d}.badge-priority-baja{color:var(--priority-low);border-color:#28c8404d}.badge-status-todo{color:var(--muted);border-color:var(--border)}.badge-status-doing{color:#8af;border-color:#88aaff4d}.badge-status-done{color:var(--accent);border-color:#e8ff474d}.task-desc{font-family:DM Mono,monospace;font-size:.72rem;color:var(--muted);line-height:1.65;margin-bottom:.5rem;word-break:break-word}.task-meta{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}.task-meta-item{font-family:DM Mono,monospace;font-size:.63rem;color:#444;display:flex;align-items:center;gap:.3rem}.task-meta-item.overdue{color:var(--priority-high)}.task-meta-item.soon{color:var(--priority-med)}.task-tags{display:flex;gap:.35rem;flex-wrap:wrap}.task-tag{font-family:DM Mono,monospace;font-size:.6rem;letter-spacing:.08em;padding:.15rem .5rem;border-radius:2px;background:#ffffff0a;border:1px solid var(--border);color:#666}.task-actions{display:flex;flex-direction:column;gap:.4rem;flex-shrink:0}.task-btn{background:none;border:none;color:#444;cursor:pointer;font-size:.85rem;padding:.25rem;border-radius:3px;transition:color .15s,background .15s;line-height:1;display:flex;align-items:center;justify-content:center;width:28px;height:28px}.task-btn:hover{color:var(--text);background:#ffffff0f}.task-btn.delete:hover{color:var(--priority-high)}.category-group{margin-bottom:1.2rem;border:1px solid var(--border);border-radius:6px;overflow:hidden}.category-header{display:flex;align-items:center;justify-content:space-between;padding:.8rem 1.1rem;background:var(--surface);cursor:pointer;-webkit-user-select:none;user-select:none;gap:.8rem;transition:background .15s}.category-header:hover{background:#161616}.category-header-left{display:flex;align-items:center;gap:.6rem}.category-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.category-name{font-size:.85rem;font-weight:700;letter-spacing:-.01em}.category-count{font-family:DM Mono,monospace;font-size:.62rem;color:var(--muted);background:#ffffff0d;border:1px solid var(--border);border-radius:2px;padding:.1rem .45rem}.category-mini-stats{display:flex;gap:.4rem;flex-wrap:wrap;flex:1;justify-content:flex-end}.cat-mini{font-family:DM Mono,monospace;font-size:.6rem;padding:.12rem .45rem;border-radius:2px;border:1px solid}.cat-mini.todo{color:var(--muted);border-color:var(--border)}.cat-mini.doing{color:#8af;border-color:#88aaff40}.cat-mini.done{color:var(--accent);border-color:#e8ff4740}.category-chevron{font-size:.6rem;color:var(--muted);transition:transform .2s;flex-shrink:0}.category-group.collapsed .category-chevron{transform:rotate(-90deg)}.category-group.collapsed .category-body{display:none}.category-body{display:flex;flex-direction:column;gap:.5rem;padding:.7rem;background:var(--bg)}.category-body .task-card{border-radius:4px}.empty-state{text-align:center;padding:4rem 2rem;border:1px dashed var(--border);border-radius:6px;display:none}.empty-state.visible{display:block}.empty-icon{font-size:2.5rem;margin-bottom:1rem;opacity:.4}.empty-title{font-size:1rem;font-weight:700;margin-bottom:.5rem;color:var(--muted)}.empty-desc{font-family:DM Mono,monospace;font-size:.72rem;color:#444}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:1.5rem;opacity:0;pointer-events:none;transition:opacity .2s}.modal-overlay.open{opacity:1;pointer-events:all}.modal{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:2rem;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;transform:translateY(8px);transition:transform .2s}.modal-overlay.open .modal{transform:translateY(0)}.modal-title{font-size:1.1rem;font-weight:700;letter-spacing:-.02em;margin-bottom:1.5rem}.modal-title span{color:var(--accent)}.modal-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.8rem;margin-bottom:1rem}.modal-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin-bottom:1rem}.modal .field{margin-bottom:0}.modal .form-actions{margin-top:.5rem}.toast{position:fixed;bottom:2rem;right:2rem;background:var(--surface);border:1px solid var(--border);border-radius:5px;padding:.75rem 1.2rem;font-family:DM Mono,monospace;font-size:.72rem;color:var(--text);z-index:200;transform:translateY(20px);opacity:0;transition:all .25s;pointer-events:none;max-width:280px;display:flex;align-items:center;gap:.6rem}.toast.show{transform:translateY(0);opacity:1}.toast-icon{font-size:.9rem}@media (max-width: 640px){.dash-wrap{padding:7rem 1rem 4rem}.dash-top{flex-direction:column;align-items:flex-start;gap:.75rem}.dash-top-actions{width:100%}.btn-new-task{flex:1;justify-content:center}.btn-back{flex:1;text-align:center}.stats-bar{gap:.5rem}.stat-pill{flex:1;min-width:calc(50% - .25rem);justify-content:center}.task-form{padding:1rem}.form-row,.form-row.three{grid-template-columns:1fr}.filters-bar{gap:.4rem}.filter-sep{display:none}.sort-select{margin-left:0;width:100%}.task-card{grid-template-columns:auto 1fr;grid-template-rows:auto auto}.task-actions{flex-direction:row;grid-column:1 / -1;border-top:1px solid var(--border);padding-top:.6rem;margin-top:.2rem;gap:.5rem}.task-btn{width:36px;height:36px;font-size:1rem}.task-header{gap:.4rem}.task-badge{font-size:.55rem}.modal-overlay{padding:.75rem;align-items:flex-end}.modal{max-height:92vh;border-radius:12px 12px 6px 6px;padding:1.5rem 1.1rem 1.8rem}.modal-grid-3,.modal-grid-2{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse;gap:.6rem}.btn-cancel,.btn-add-confirm{width:100%;text-align:center;justify-content:center}.view-bar{flex-wrap:wrap}.view-btn{flex:1;text-align:center}.toast{right:1rem;bottom:1rem;left:1rem;max-width:none}.category-mini-stats{display:none}}@media (max-width: 380px){.stat-pill{min-width:100%}}:root{--bg: #06060a;--s: #0e0e14;--b: #1c1c28;--t: #f0f0f0;--m: #555;--a: #e8ff47}html{scroll-behavior:smooth}body{font-family:Syne,sans-serif;background:var(--bg);color:var(--t);min-height:100vh;overflow-x:hidden}#app{display:block}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background-image:linear-gradient(rgba(255,255,255,.014) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.014) 1px,transparent 1px);background-size:48px 48px}nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:.85rem 2.5rem;background:#06060aeb;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--b)}.nav-logo{font-family:DM Mono,monospace;font-size:.75rem;color:var(--a);text-decoration:none;letter-spacing:.06em;display:flex;align-items:center;gap:.45rem}.nav-dot{width:5px;height:5px;border-radius:50%;background:var(--a);animation:blink 1.4s steps(1) infinite}.nav-search{display:flex;align-items:center;background:var(--s);border:1px solid var(--b);border-radius:5px;padding:.36rem .85rem;gap:.45rem}.nav-search input{background:none;border:none;outline:none;font-family:DM Mono,monospace;font-size:.7rem;color:var(--t);width:155px}.nav-search input::placeholder{color:#2e2e2e}.nav-right{display:flex;align-items:center;gap:1rem;font-family:DM Mono,monospace;font-size:.66rem;color:var(--m)}.nav-right b{color:var(--a)}.nav-logout{font-size:.6rem;color:#2e2e2e;background:none;border:1px solid #1a1a1a;border-radius:3px;padding:.22rem .6rem;cursor:pointer;font-family:DM Mono,monospace;letter-spacing:.06em;transition:color .15s,border-color .15s}.nav-logout:hover{color:#555;border-color:#333}.btn-apps-back{font-family:DM Mono,monospace;font-size:.62rem;letter-spacing:.08em;color:#b8f;background:#bb88ff14;border:1px solid rgba(187,136,255,.25);border-radius:3px;padding:.28rem .75rem;text-decoration:none;transition:background .15s,border-color .15s}.btn-apps-back:hover{background:#bb88ff2e;border-color:#bb88ff80}.hero{padding:7.5rem 2.5rem 2rem;max-width:1240px;margin:0 auto;position:relative;z-index:1}.eyebrow{font-family:DM Mono,monospace;font-size:.6rem;color:var(--m);letter-spacing:.22em;margin-bottom:.8rem}.hero-h1{font-size:clamp(3rem,8vw,6rem);font-weight:800;letter-spacing:-.05em;line-height:.9;margin-bottom:1.8rem}.hero-h1 em{color:var(--a);font-style:normal}.hero-h1 .ghost{-webkit-text-stroke:1px #1e1e1e;color:transparent}.cats{display:flex;gap:.4rem;flex-wrap:wrap}.cat{font-family:DM Mono,monospace;font-size:.6rem;letter-spacing:.1em;padding:.26rem .75rem;border-radius:2px;border:1px solid var(--b);background:none;color:#383838;cursor:pointer;transition:all .15s}.cat:hover{color:var(--t);border-color:#333}.cat.on{color:var(--a);border-color:#e8ff4761;background:#e8ff470a}.sec{max-width:1240px;margin:0 auto;padding:0 2.5rem 5rem;position:relative;z-index:1}.sec-bar{display:flex;align-items:center;gap:.6rem;margin-bottom:1.2rem;padding-bottom:.7rem;border-bottom:1px solid var(--b)}.sec-bar h2{font-size:.75rem;font-weight:700;letter-spacing:.12em;color:var(--m)}.sec-bar small{font-family:DM Mono,monospace;font-size:.58rem;color:#2a2a2a}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1rem}.card{background:var(--s);border:1px solid var(--b);border-radius:8px;overflow:hidden;cursor:pointer;position:relative;transition:transform .2s,border-color .2s,box-shadow .2s}.card:hover{transform:translateY(-5px);border-color:#ffffff1a;box-shadow:0 16px 50px #000000bf}.card:hover .overlay{opacity:1}.thumb{width:100%;aspect-ratio:16/9;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.thumb canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000085;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .18s;z-index:3}.play-btn{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#000;font-weight:700;box-shadow:0 0 24px currentColor}.game-logo{display:flex;align-items:center;justify-content:center;width:100%;height:58px;margin-bottom:.55rem;position:relative}.game-logo svg{width:auto;height:100%;max-width:100%;display:block}.info{padding:.6rem .95rem .85rem}.info-row{display:flex;align-items:center;justify-content:space-between}.tag{font-family:DM Mono,monospace;font-size:.55rem;letter-spacing:.1em;color:#383838}.stars{font-size:.58rem;color:#febc2e;letter-spacing:-1px}.rec{font-family:DM Mono,monospace;font-size:.55rem;margin-top:.3rem}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:#000000e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;flex-direction:column;align-items:center;padding:1rem;overflow-y:auto;opacity:0;pointer-events:none;transition:opacity .2s}.modal.on{opacity:1;pointer-events:all}.mbar{width:100%;max-width:700px;display:flex;align-items:center;justify-content:space-between;padding:.55rem 0}.mname{display:flex;align-items:center;gap:.55rem;font-size:1rem;font-weight:800;letter-spacing:-.02em}.mclose{font-family:DM Mono,monospace;font-size:.68rem;color:var(--m);background:var(--s);border:1px solid var(--b);border-radius:4px;padding:.36rem .8rem;cursor:pointer;transition:all .15s}.mclose:hover{color:var(--t);border-color:#333}.gwrap{width:100%;max-width:700px;border:1px solid transparent;border-radius:8px;overflow:hidden;background:#000;position:relative;box-shadow:0 0 0 1px #222,0 0 18px 2px var(--game-glow, #e8ff47),inset 0 0 12px #00000080;transition:box-shadow .3s}.gwrap canvas{display:block;width:100%}.ctrls{width:100%;max-width:700px;display:flex;gap:.35rem;flex-wrap:wrap;padding:.5rem 0}.ctrl{font-family:DM Mono,monospace;font-size:.56rem;color:#3a3a3a;background:var(--s);border:1px solid var(--b);border-radius:2px;padding:.16rem .5rem}.pause-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:100;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s;border-radius:8px}.pause-overlay.on{opacity:1;pointer-events:all}.pause-overlay h2{font-size:2.5rem;font-weight:800;color:var(--game-glow, #e8ff47);letter-spacing:-.02em;text-shadow:0 0 16px var(--game-glow, rgba(232, 255, 71, .5));margin-bottom:.5rem}.pause-overlay p{font-family:DM Mono,monospace;font-size:.8rem;color:#ccc;margin-bottom:1.5rem}.pause-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.25);color:#fff;padding:.5rem 1.2rem;border-radius:4px;font-family:DM Mono,monospace;font-size:.75rem;cursor:pointer;transition:all .2s}.pause-btn:hover{background:#ffffff40;border-color:#fff}@keyframes shake{0%,to{transform:translate(0) rotate(0)}10%,30%,50%,70%,90%{transform:translate(-3px,-2px) rotate(-1deg)}20%,40%,60%,80%{transform:translate(3px,2px) rotate(1deg)}}.shake{animation:shake .35s cubic-bezier(.36,.07,.19,.97) both}.dpad-overlay{display:none;width:100%;max-width:700px;padding:.6rem 0 .4rem;-webkit-user-select:none;user-select:none}@media (hover:none),(pointer:coarse){.dpad-overlay{display:block}}.dpad-row{display:flex;justify-content:center;gap:.4rem;margin:.2rem 0}.dpad-btn{width:52px;height:52px;border-radius:8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:var(--t);font-size:1.2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .1s,transform .08s;touch-action:manipulation}.dpad-btn:active,.dpad-btn.pressed{background:#ffffff2e;transform:scale(.93)}.dpad-btn.action{background:#e8ff471f;border-color:#e8ff4759;color:var(--a);font-size:.65rem;width:auto;padding:0 1rem;letter-spacing:.06em;font-family:DM Mono,monospace}.dpad-spacer{width:52px;height:52px}.dpad-actions{display:flex;justify-content:center;gap:.5rem;margin-top:.5rem}.toast{position:fixed;bottom:1.5rem;right:1.5rem;z-index:600;background:var(--s);border:1px solid var(--b);border-radius:5px;padding:.6rem 1rem;font-family:DM Mono,monospace;font-size:.68rem;display:flex;align-items:center;gap:.45rem;transform:translateY(16px);opacity:0;transition:all .25s;pointer-events:none}.toast.on{transform:none;opacity:1}.toast b{color:var(--a)}@media (max-width:640px){nav{padding:.8rem 1.1rem}.nav-search{display:none}.hero{padding:5.5rem 1.1rem 1.5rem}.sec{padding:0 1.1rem 3rem}.grid{grid-template-columns:1fr 1fr;gap:.65rem}}.apps-page{min-height:calc(100vh - 140px);padding:8rem 2rem 5rem;max-width:1100px;margin:0 auto}.dash-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;margin-bottom:2.5rem}.dash-meta{font-family:DM Mono,monospace;font-size:.7rem;color:var(--muted);letter-spacing:.08em;margin-bottom:.5rem}.dash-title{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;letter-spacing:-.03em;line-height:1.05}.dash-title span{color:var(--accent)}.btn-logout{font-family:DM Mono,monospace;font-size:.72rem;color:var(--muted);background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:.5rem 1rem;cursor:pointer;transition:border-color .2s,color .2s;white-space:nowrap;letter-spacing:.05em;flex-shrink:0;margin-top:.5rem}.btn-logout:hover{border-color:#ff5f57;color:#ff7070}.session-bar{background:var(--surface);border:1px solid var(--border);border-radius:5px;padding:.75rem 1.2rem;display:flex;align-items:center;gap:.75rem;font-family:DM Mono,monospace;font-size:.7rem;color:var(--muted);margin-bottom:2.5rem;flex-wrap:wrap}.session-dot{width:6px;height:6px;border-radius:50%;background:#28c840;flex-shrink:0;animation:pulse-dot 2.5s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;box-shadow:0 0 #28c84066}50%{opacity:.7;box-shadow:0 0 0 5px #28c84000}}.session-path{color:#8af}.session-expiry{color:var(--accent);margin-left:auto}.dash-stats{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2.5rem}.stat{background:var(--surface);border:1px solid var(--border);border-radius:5px;padding:1rem 1.5rem;flex:1;min-width:110px}.stat-value{font-size:1.8rem;font-weight:800;letter-spacing:-.04em;color:var(--accent);line-height:1;margin-bottom:.25rem}.stat-label{font-family:DM Mono,monospace;font-size:.65rem;color:var(--muted);letter-spacing:.1em}.section-row{display:flex;align-items:center;gap:.8rem;margin-bottom:1.2rem}.section-row span{font-family:DM Mono,monospace;font-size:.68rem;color:var(--muted);letter-spacing:.12em}.section-row:after{content:"";flex:1;height:1px;background:var(--border)}.apps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1rem;margin-bottom:3rem}.app-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:1.4rem;text-decoration:none;color:var(--text);display:flex;flex-direction:column;gap:.85rem;position:relative;overflow:hidden;transition:border-color .2s,transform .2s,background .2s}.app-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .25s ease}.app-card:hover{border-color:#333;background:#141414;transform:translateY(-2px)}.app-card:hover:before{transform:scaleX(1)}.app-card.coming-soon{opacity:.35;pointer-events:none}.app-icon{font-size:1.5rem;width:2.4rem;height:2.4rem;display:flex;align-items:center;justify-content:center;background:var(--surface2);border:1px solid var(--border);border-radius:6px;flex-shrink:0}.app-card-body{flex:1}.app-name{font-size:.95rem;font-weight:700;letter-spacing:-.01em;margin-bottom:.25rem}.app-desc{font-family:DM Mono,monospace;font-size:.7rem;color:var(--muted);line-height:1.65}.app-card-footer{display:flex;align-items:center;justify-content:space-between}.app-tag{font-family:DM Mono,monospace;font-size:.62rem;color:var(--muted);background:var(--bg);border:1px solid var(--border);border-radius:2px;padding:.18rem .5rem;letter-spacing:.1em}.app-tag.active{color:var(--accent);border-color:#e8ff474d}.app-tag.wip{color:#febc2e;border-color:#febc2e4d}.app-arrow{font-family:DM Mono,monospace;font-size:.8rem;color:var(--accent);opacity:0;transform:translate(-6px);transition:opacity .2s,transform .2s}.app-card:hover .app-arrow{opacity:1;transform:translate(0)}@media (max-width: 640px){.apps-page{padding:7rem 1.25rem 4rem}.session-expiry{display:none}}:root{--accent: #e8ff47;--accent-dark: #b8cc00;--bg: #0d0d0d;--surface: #111111;--surface2: #181818;--text: #f0f0f0;--muted: #666;--border: #222;--red: #ff5f57}body{background:var(--bg);color:var(--text);font-family:Syne,sans-serif;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(232,255,71,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(232,255,71,.03) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}.glow{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:700px;height:700px;background:radial-gradient(circle,rgba(232,255,71,.04) 0%,transparent 60%);pointer-events:none}.corner{position:fixed;width:28px;height:28px;border-color:#222;border-style:solid;pointer-events:none}.card{position:relative;z-index:1;width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:2.5rem 2rem 2rem;animation:slideUp .45s cubic-bezier(.16,1,.3,1) both}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.card:before{content:"";position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.5;border-radius:1px}.logo-link{display:inline-flex;align-items:center;gap:.4rem;font-family:DM Mono,monospace;font-size:.8rem;color:var(--muted);text-decoration:none;letter-spacing:.05em;margin-bottom:2rem;transition:color .2s}.logo-link:hover{color:var(--accent)}.card-badge{display:inline-flex;align-items:center;gap:.5rem;font-family:DM Mono,monospace;font-size:.65rem;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--border);border-radius:3px;padding:.25rem .7rem;margin-bottom:1.2rem}.badge-dot{width:5px;height:5px;border-radius:50%;background:var(--red);box-shadow:0 0 6px #ff5f5799}h1{font-size:1.75rem;font-weight:800;letter-spacing:-.03em;line-height:1.1;margin-bottom:.35rem}.subtitle{font-family:DM Mono,monospace;font-size:.72rem;color:var(--muted);margin-bottom:2rem}.field-label{font-family:DM Mono,monospace;font-size:.65rem;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin-bottom:.35rem;display:block}.input-wrap{position:relative;margin-bottom:1rem}input[type=password],input[type=text]{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:5px;color:var(--text);font-family:DM Mono,monospace;font-size:.92rem;padding:.8rem 3rem .8rem 1rem;outline:none;transition:border-color .2s,box-shadow .2s;letter-spacing:.12em}input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #e8ff4712}input.error{border-color:var(--red)!important;box-shadow:0 0 0 3px #ff5f5712!important;animation:shake .35s ease}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-7px)}40%{transform:translate(7px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.toggle-pw{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--muted);font-size:.95rem;padding:.2rem;transition:color .2s;line-height:1}.toggle-pw:hover{color:var(--accent)}.error-msg{font-family:DM Mono,monospace;font-size:.7rem;color:#ff7070;min-height:1.2em;margin-bottom:.8rem;transition:opacity .2s;display:flex;align-items:center;gap:.4rem}.error-msg:empty{opacity:0}.lockout-bar{display:none;align-items:center;gap:.6rem;background:#ff5f5712;border:1px solid rgba(255,95,87,.25);border-radius:4px;padding:.65rem .9rem;font-family:DM Mono,monospace;font-size:.7rem;color:#ff7070;margin-bottom:1rem}.lockout-bar.visible{display:flex}.btn-submit{width:100%;background:var(--accent);color:#0d0d0d;border:none;border-radius:5px;font-family:DM Mono,monospace;font-size:.85rem;font-weight:500;letter-spacing:.06em;padding:.9rem;cursor:pointer;transition:background .15s,opacity .15s,transform .1s;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-submit:hover:not(:disabled){background:#d4e83f}.btn-submit:active:not(:disabled){transform:scale(.99)}.btn-submit:disabled{opacity:.45;cursor:not-allowed}.attempts-hint{font-family:DM Mono,monospace;font-size:.65rem;color:#3a3a3a;text-align:center;margin-top:.7rem;min-height:1em;transition:color .3s}.attempts-hint.warn{color:#febc2e}.attempts-hint.danger{color:var(--red)}.spinner{display:none;width:14px;height:14px;border:2px solid rgba(0,0,0,.2);border-top-color:#0d0d0d;border-radius:50%;animation:spin .7s linear infinite}.btn-submit.loading .spinner{display:block}.btn-submit.loading .btn-label{opacity:.6}@keyframes spin{to{transform:rotate(360deg)}}.card-footer{display:flex;align-items:center;gap:.8rem;margin-top:1.8rem;padding-top:1.4rem;border-top:1px solid var(--border)}.back-link{flex:1;font-family:DM Mono,monospace;font-size:.7rem;color:var(--muted);text-decoration:none;transition:color .2s}.back-link:hover{color:var(--accent)}.footer-meta{font-family:DM Mono,monospace;font-size:.62rem;color:#2a2a2a;letter-spacing:.06em}@media (max-width: 480px){.card{padding:2rem 1.25rem 1.5rem}.corner{display:none}}:root{--accent: #e8ff47;--bg: #0d0d0d;--surface: #161616;--border: #2a2a2a;--text: #f0f0f0;--muted: #666}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Syne,sans-serif;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem 2rem 4rem;overflow-x:hidden;overflow-y:auto;position:relative}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:60px 60px;opacity:.4;pointer-events:none}body:after{content:"";position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:700px;height:700px;background:radial-gradient(circle,rgba(232,255,71,.06) 0%,transparent 65%);pointer-events:none}.container{position:relative;z-index:1;max-width:680px;width:100%;text-align:center}.badge{display:inline-flex;align-items:center;gap:.6rem;background:var(--surface);border:1px solid var(--border);border-radius:3px;padding:.5rem 1.1rem;font-family:DM Mono,monospace;font-size:.78rem;color:var(--muted);margin-bottom:1.5rem;letter-spacing:.08em}.dot{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:pulse 2s ease-in-out infinite;flex-shrink:0}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}h1{font-size:clamp(2.2rem,5vw,4rem);font-weight:800;line-height:1.05;letter-spacing:-.03em;margin-bottom:.5rem}h1 span{color:var(--accent)}.subtitle{font-family:DM Mono,monospace;font-size:clamp(.8rem,2vw,1rem);color:var(--muted);margin:1.2rem 0 2rem;line-height:1.8}.progress-wrap{background:var(--surface);border:1px solid var(--border);border-radius:3px;padding:1.5rem 2rem;margin-bottom:1.5rem;text-align:left}.progress-label{display:flex;justify-content:space-between;font-family:DM Mono,monospace;font-size:.72rem;color:var(--muted);margin-bottom:.8rem;letter-spacing:.06em}.progress-bar{height:3px;background:var(--border);border-radius:2px;overflow:hidden;margin-bottom:1.2rem}.progress-fill{height:100%;background:var(--accent);border-radius:2px;width:75%;transition:width .3s ease}.tasks{display:flex;flex-direction:column;gap:.5rem}.task{font-family:DM Mono,monospace;font-size:.72rem;color:var(--muted);display:flex;align-items:center;gap:.7rem}.task-icon{color:var(--accent);font-size:.65rem}.task-icon.pending{color:var(--border)}.task.done{color:#444;text-decoration:line-through}.social-links{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.social-link{font-family:DM Mono,monospace;font-size:.78rem;color:var(--muted);text-decoration:none;padding:.6rem 1.2rem;border:1px solid var(--border);border-radius:3px;transition:all .2s;letter-spacing:.05em}.social-link:hover{border-color:var(--accent);color:var(--accent)}.footer-text{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);font-family:DM Mono,monospace;font-size:.7rem;color:#333;letter-spacing:.1em;white-space:nowrap}.corner{position:fixed;width:30px;height:30px;border-color:#222;border-style:solid}@media (max-width: 480px){.progress-wrap{padding:1.2rem}.corner{display:none}}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,95,87,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,95,87,.018) 1px,transparent 1px);background-size:60px 60px;pointer-events:none;z-index:0}.badge-dot{width:6px;height:6px;border-radius:50%;background:#ff5f57;flex-shrink:0;box-shadow:0 0 8px #ff5f57b3}.error-code{font-family:Syne,sans-serif;font-size:clamp(7rem,22vw,14rem);font-weight:800;line-height:.95;letter-spacing:-.05em;color:#ff5f57;position:relative;display:inline-block;margin-bottom:.4rem;-webkit-user-select:none;user-select:none;animation:fadeUp 2s 1s ease both}.error-code:before,.error-code:after{content:"403";position:absolute;top:0;right:0;bottom:0;left:0;font-family:inherit;font-size:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;pointer-events:none;opacity:0}.error-code:before{color:#e8ff47a6;clip-path:polygon(0 0,100% 0,100% 38%,0 38%);animation:glitch-top 2s 1s infinite}.error-code:after{color:#febc2e8c;clip-path:polygon(0 62%,100% 62%,100% 100%,0 100%);animation:glitch-bot 2s 1s infinite}.t-prompt{color:#ff5f57;flex-shrink:0;font-weight:500}.t-cursor{display:inline-block;width:7px;height:.85em;background:#ff5f57;vertical-align:middle;margin-left:2px;animation:blink 1s step-end infinite}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(232,255,71,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(232,255,71,.022) 1px,transparent 1px);background-size:60px 60px;pointer-events:none;z-index:0}.error-inner{max-width:700px;width:100%;text-align:center;animation:fadeUp .55s ease both}.badge-dot{width:6px;height:6px;border-radius:50%;background:#ff5f57;flex-shrink:0;box-shadow:0 0 7px #ff5f578c}.error-code{font-family:Syne,sans-serif;font-size:clamp(7rem,22vw,14rem);font-weight:800;line-height:.95;letter-spacing:-.05em;color:var(--accent);position:relative;display:inline-block;margin-bottom:.4rem;-webkit-user-select:none;user-select:none;animation:fadeUp 2s 1s ease both}.error-code:before,.error-code:after{content:"404";position:absolute;top:0;right:0;bottom:0;left:0;font-family:inherit;font-size:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;pointer-events:none;opacity:0}.error-code:before{color:#47c8ffbf;clip-path:polygon(0 0,100% 0,100% 38%,0 38%);animation:glitch-top 2s 1s infinite}.error-code:after{color:#ff4747a6;clip-path:polygon(0 62%,100% 62%,100% 100%,0 100%);animation:glitch-bot 2s 1s infinite}@keyframes glitch-top{0%,87%,to{opacity:0;transform:translate(0)}89%{opacity:1;transform:translate(-5px,-2px)}91%{opacity:1;transform:translate(4px)}93%{opacity:0}}@keyframes glitch-bot{0%,87%,to{opacity:0;transform:translate(0)}90%{opacity:1;transform:translate(5px,2px)}92%{opacity:1;transform:translate(-3px)}94%{opacity:0}}.terminal{background:var(--surface);border:1px solid var(--border);border-radius:6px;margin:0 0 2rem;text-align:left;overflow:hidden;box-shadow:0 10px 40px #0000008c;animation:fadeUp .45s .25s ease both}.t-prompt{color:var(--accent);flex-shrink:0;font-weight:500}.t-cursor{display:inline-block;width:7px;height:.85em;background:var(--accent);vertical-align:middle;margin-left:2px;animation:blink 1s step-end infinite}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(254,188,46,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(254,188,46,.018) 1px,transparent 1px);background-size:60px 60px;pointer-events:none;z-index:0}.error-inner{max-width:700px;width:100%;text-align:center;animation:fadeUp 2s ease both}.badge-dot{width:6px;height:6px;border-radius:50%;background:#febc2e;flex-shrink:0;box-shadow:0 0 8px #febc2ea6}.error-code{font-family:Syne,sans-serif;font-size:clamp(7rem,22vw,14rem);font-weight:800;line-height:.95;letter-spacing:-.05em;color:#febc2e;position:relative;display:inline-block;margin-bottom:.4rem;-webkit-user-select:none;user-select:none;animation:fadeUp 2s 1s ease both}.error-code:before,.error-code:after{content:"500";position:absolute;top:0;right:0;bottom:0;left:0;font-family:inherit;font-size:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;pointer-events:none;opacity:0}.error-code:before{color:#ff5f57b3;clip-path:polygon(0 0,100% 0,100% 38%,0 38%);animation:glitch-top 5s 1.5s infinite}.error-code:after{color:#e8ff4780;clip-path:polygon(0 62%,100% 62%,100% 100%,0 100%);animation:glitch-bot 5s 1.5s infinite}@keyframes glitch-top{0%,85%,to{opacity:0;transform:translate(0)}87%{opacity:1;transform:translate(-6px,-2px)}89%{opacity:1;transform:translate(5px)}91%{opacity:0}}@keyframes glitch-bot{0%,85%,to{opacity:0;transform:translate(0)}88%{opacity:1;transform:translate(6px,3px)}90%{opacity:1;transform:translate(-4px)}92%{opacity:0}}.t-line:nth-child(6){animation:lineIn .25s 2.25s ease forwards}.t-prompt{color:#febc2e;flex-shrink:0;font-weight:500}.t-stack{color:#4a4a4a;font-size:.7rem}.t-cursor{display:inline-block;width:7px;height:.85em;background:#febc2e;vertical-align:middle;margin-left:2px;animation:blink 1s step-end infinite}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(136,170,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(136,170,255,.018) 1px,transparent 1px);background-size:60px 60px;pointer-events:none;z-index:0}.corner{position:fixed;width:28px;height:28px;border-color:#252525;border-style:solid;pointer-events:none;z-index:2}.corner-tl{top:1.5rem;left:1.5rem;border-width:1px 0 0 1px}.corner-tr{top:1.5rem;right:1.5rem;border-width:1px 1px 0 0}.corner-bl{bottom:1.5rem;left:1.5rem;border-width:0 0 1px 1px}.corner-br{bottom:1.5rem;right:1.5rem;border-width:0 1px 1px 0}.error-page{min-height:calc(100vh - 140px);display:flex;align-items:center;justify-content:center;padding:8rem 2rem 4rem;position:relative;z-index:1}.error-inner{max-width:700px;width:100%;text-align:center;animation:fadeUp 2s 1s ease both}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.error-badge{display:inline-flex;align-items:center;gap:.55rem;background:var(--surface);border:1px solid var(--border);border-radius:3px;padding:.4rem 1rem;font-family:DM Mono,monospace;font-size:.68rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.8rem;animation:fadeUp 2s 1s ease both}.badge-dot{width:6px;height:6px;border-radius:50%;background:#8af;flex-shrink:0;box-shadow:0 0 8px #8af9;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 8px #8af9}50%{box-shadow:0 0 16px #88aaffe6}}.error-code{font-family:Syne,sans-serif;font-size:clamp(7rem,22vw,14rem);font-weight:800;line-height:.95;letter-spacing:-.05em;color:#8af;position:relative;display:inline-block;margin-bottom:.4rem;-webkit-user-select:none;user-select:none;animation:fadeUp 2s 1s ease both}.error-code:before,.error-code:after{content:"503";position:absolute;top:0;right:0;bottom:0;left:0;font-family:inherit;font-size:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;pointer-events:none;opacity:0}.error-code:before{color:#88c8ffa6;clip-path:polygon(0 0,100% 0,100% 38%,0 38%);animation:glitch-top 2s 1s infinite}.error-code:after{color:#e8ff4773;clip-path:polygon(0 62%,100% 62%,100% 100%,0 100%);animation:glitch-bot 2s 1s infinite}@keyframes glitch-top{0%,88%,to{opacity:0;transform:translate(0)}90%{opacity:1;transform:translate(-4px,-2px)}92%{opacity:1;transform:translate(3px)}94%{opacity:0}}@keyframes glitch-bot{0%,88%,to{opacity:0;transform:translate(0)}91%{opacity:1;transform:translate(4px,2px)}93%{opacity:1;transform:translate(-2px)}95%{opacity:0}}.error-sub{font-family:DM Mono,monospace;font-size:.7rem;color:var(--muted);letter-spacing:.15em;text-transform:uppercase;margin-bottom:2rem;animation:fadeUp 2s 1s ease both}.terminal{background:var(--surface);border:1px solid var(--border);border-radius:6px;margin:0 0 2rem;text-align:left;overflow:hidden;box-shadow:0 10px 40px #0000008c;animation:fadeUp 2s 1s ease both}.terminal-bar{background:#181818;border-bottom:1px solid var(--border);padding:.55rem 1rem;display:flex;align-items:center;gap:.45rem}.t-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.t-dot-r{background:#ff5f57}.t-dot-y{background:#febc2e}.t-dot-g{background:#28c840}.t-title{font-family:DM Mono,monospace;font-size:.65rem;color:#383838;margin-left:.4rem;letter-spacing:.05em}.terminal-body{padding:1.4rem 1.6rem;font-family:DM Mono,monospace;font-size:.78rem;line-height:2}.t-line{display:flex;gap:.8rem;align-items:baseline;opacity:0}.t-line:nth-child(1){animation:lineIn .25s .75s ease forwards}.t-line:nth-child(2){animation:lineIn .25s 1.05s ease forwards}.t-line:nth-child(3){animation:lineIn .25s 1.35s ease forwards}.t-line:nth-child(4){animation:lineIn .25s 1.65s ease forwards}.t-line:nth-child(5){animation:lineIn .25s 1.95s ease forwards}@keyframes lineIn{0%{opacity:0;transform:translate(-5px)}to{opacity:1;transform:translate(0)}}.t-prompt{color:#8af;flex-shrink:0;font-weight:500}.t-cmd{color:var(--text)}.t-err{color:#ff7070}.t-warn{color:#febc2e}.t-ok{color:#28c840}.t-path{color:#8af}.t-spinner{display:inline-block;font-style:normal;animation:spin-chars 1s steps(4) infinite}@keyframes spin-chars{0%{content:"⠋"}25%{content:"⠙"}50%{content:"⠹"}75%{content:"⠸"}}.t-cursor{display:inline-block;width:7px;height:.85em;background:#8af;vertical-align:middle;margin-left:2px;animation:blink 1s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.error-title{font-family:Syne,sans-serif;font-size:clamp(1.4rem,3.5vw,2rem);font-weight:700;letter-spacing:-.02em;margin-bottom:.6rem;line-height:1.2;animation:fadeUp 2s 1s ease both}.error-desc{font-family:DM Mono,monospace;font-size:clamp(.76rem,2vw,.86rem);color:var(--muted);line-height:1.9;margin-bottom:2.2rem;animation:fadeUp 2s 1s ease both}.error-btns{display:flex;gap:.85rem;justify-content:center;flex-wrap:wrap;animation:fadeUp 2s 1s ease both}.error-meta{margin-top:3rem;font-family:DM Mono,monospace;font-size:.63rem;color:#272727;letter-spacing:.1em;display:flex;align-items:center;gap:1rem;animation:fadeUp 2s 1s ease both}.error-meta:before,.error-meta:after{content:"";flex:1;height:1px;background:#1c1c1c}@media (max-width: 640px){.error-page{padding:7rem 1.25rem 3rem}.terminal-body{padding:1rem 1.1rem;font-size:.72rem}.error-btns{flex-direction:column;align-items:center}.error-btns .btn{width:100%;max-width:280px;justify-content:center;text-align:center}.corner{display:none}body:before{background-size:40px 40px}}:root{--t-bg: #07091a;--t-card: #0e1229;--t-text: #ffffff;--t-soft: rgba(255, 255, 255, .72);--t-muted: rgba(255, 255, 255, .38);--t-border: rgba(255, 255, 255, .1);--t-border-strong: rgba(255, 255, 255, .18);--t-yellow: #facc15;--t-yellow-bg: rgba(250, 204, 21, .12);--t-green: #22c55e;--t-green-bg: rgba(34, 197, 94, .12);--t-blue-bg: rgba(99, 102, 241, .12);--t-orange-bg: rgba(249, 115, 22, .12);--t-danger: rgb(239, 68, 68);--t-radius: 18px;--t-radius-sm: 10px;--t-ease: .18s ease;--t-shadow: 0 10px 30px rgba(0, 0, 0, .25)}.tiro-page{font-family:Atkinson Hyperlegible,Georgia,serif;background:var(--t-bg);color:var(--t-text);min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:1.5rem 1rem 5rem;position:relative;overflow-x:hidden}.t-diana{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;-webkit-user-select:none;user-select:none;opacity:.45;z-index:0}.tiro-page{scrollbar-width:thin;scrollbar-color:rgba(250,204,21,.45) var(--t-bg)}.tiro-page::-webkit-scrollbar{width:8px}.tiro-page::-webkit-scrollbar-track{background:var(--t-bg)}.tiro-page::-webkit-scrollbar-thumb{background:#facc1566;border-radius:999px}.tiro-page::-webkit-scrollbar-thumb:hover{background:var(--t-yellow)}@keyframes t-fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.t-content{width:100%;max-width:920px;position:relative;z-index:2;animation:t-fadeUp .35s ease both}.t-card{background:var(--t-card);border:1px solid var(--t-border);border-radius:var(--t-radius);padding:2rem;box-shadow:var(--t-shadow);display:grid;grid-template-columns:1fr;row-gap:1.4rem}.t-top-bar{display:grid;grid-template-columns:auto auto;grid-template-rows:auto auto;justify-content:space-between;gap:.5rem 0;margin-bottom:1.6rem;padding-top:.3rem;width:100%}.t-top-bar .t-back-btn{grid-column:1;grid-row:1;justify-self:start}.t-top-bar .t-logout-btn{grid-column:2;grid-row:1;justify-self:end}.t-top-bar .t-user-pill{grid-column:1 / 3;grid-row:2;justify-self:center}.t-back-btn{background:#facc1514;border:1.5px solid rgba(250,204,21,.3);color:#facc15d9;font-family:inherit;font-size:.82rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;cursor:pointer;padding:.42rem 1rem;border-radius:999px;white-space:nowrap;transition:background var(--t-ease),border-color var(--t-ease),color var(--t-ease),transform .12s}.t-back-btn:hover{background:#facc152e;border-color:var(--t-yellow);color:var(--t-yellow);transform:translateY(-1px)}.t-back-btn:active{transform:translateY(0)}.t-back-btn:focus-visible{outline:3px solid var(--t-yellow);outline-offset:3px}.t-user-pill{display:inline-flex;align-items:center;gap:6px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:100px;padding:5px 12px 5px 8px;font-size:.82rem;font-weight:700;color:var(--t-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;max-width:280px}.t-udot{width:7px;height:7px;background:var(--t-green);border-radius:50%;box-shadow:0 0 6px #22c55eb3;flex-shrink:0}.t-logout-btn{background:none;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#fff6;cursor:pointer;font-family:inherit;font-size:.78rem;font-weight:700;padding:5px 10px;white-space:nowrap;transition:border-color .15s,color .15s;letter-spacing:.04em}.t-logout-btn:hover{border-color:#ef444480;color:#fca5a5}.t-page-header{display:grid;grid-template-columns:1fr;row-gap:.3rem}.t-eyebrow{display:block;font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--t-yellow)}.t-page-title{font-size:clamp(1.6rem,5vw,2.4rem);font-weight:700;line-height:1.1}.t-divider{height:1px;background:#ffffff0f}button{font-family:inherit}.t-btn-add{border:none;background:var(--t-yellow);color:var(--t-bg);font-weight:700;padding:.85rem 1.3rem;border-radius:var(--t-radius-sm);display:inline-flex;align-items:center;gap:8px;cursor:pointer;transition:transform var(--t-ease),box-shadow var(--t-ease),background var(--t-ease)}.t-btn-add:hover{background:#fde047;transform:translateY(-1px);box-shadow:0 8px 24px #facc1559}.t-btn-submit{flex:1;min-width:160px;border:none;background:var(--t-yellow);color:var(--t-bg);font-weight:700;padding:1rem 1.2rem;border-radius:var(--t-radius-sm);display:flex;justify-content:center;align-items:center;gap:10px;font-size:1rem;cursor:pointer;transition:transform var(--t-ease),box-shadow var(--t-ease),background var(--t-ease)}.t-btn-submit:hover:not(:disabled){background:#fde047;transform:translateY(-1px);box-shadow:0 8px 24px #facc1559}.t-btn-submit:disabled{opacity:.5;cursor:not-allowed}.t-btn-cancel,.t-btn-back-form,.t-btn-sort{border:1px solid var(--t-border-strong);background:transparent;color:var(--t-soft);padding:.75rem 1rem;border-radius:var(--t-radius-sm);display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;cursor:pointer;transition:background var(--t-ease),border-color var(--t-ease),color var(--t-ease)}.t-btn-cancel:hover,.t-btn-back-form:hover,.t-btn-sort:hover{border-color:#fff6;color:#fff}.t-btn-edit{width:40px;height:40px;border-radius:10px;border:1px solid var(--t-border-strong);background:transparent;color:var(--t-soft);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--t-ease),border-color var(--t-ease),color var(--t-ease)}.t-btn-edit:hover{border-color:#fff6;color:#fff}.t-form-actions{display:flex;gap:.8rem;flex-wrap:wrap}.t-toggle-group{display:flex;gap:4px;padding:4px;border-radius:12px;background:#ffffff0d;border:1px solid var(--t-border)}.t-tog{flex:1;border:none;border-radius:8px;padding:.8rem;background:transparent;color:#ffffff80;font-weight:700;font-family:inherit;cursor:pointer;transition:background var(--t-ease),color var(--t-ease);white-space:nowrap}.t-tog.active{background:var(--t-yellow);color:var(--t-bg)}.t-tabs{display:flex;background:#ffffff0d;border:1.5px solid rgba(255,255,255,.1);border-radius:12px;padding:4px;width:100%}.t-tab{flex:1;padding:.65rem 1rem;border:none;border-radius:8px;font-family:inherit;font-size:.95rem;font-weight:700;cursor:pointer;background:transparent;color:#ffffff73;transition:all .18s;text-align:center}.t-tab.active{background:var(--t-yellow);color:var(--t-bg)}.t-filters{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center}.t-flabel{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--t-muted);white-space:nowrap}.t-tg{display:flex;background:#ffffff0a;border:1.5px solid rgba(255,255,255,.1);border-radius:9px;padding:3px;gap:3px}.t-tg .t-tog{padding:.45rem .9rem;border-radius:6px;font-size:.85rem;flex:initial}.t-tg .t-tog.active{background:#facc1526;color:var(--t-yellow);border:1px solid rgba(250,204,21,.35)}.t-badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:.72rem;font-weight:700;text-transform:uppercase}.t-badge-pie{background:var(--t-green-bg);color:#86efac}.t-badge-tendido{background:var(--t-blue-bg);color:#a5b4fc}.t-badge-clas{background:var(--t-yellow-bg);color:#fde047}.t-badge-final{background:var(--t-orange-bg);color:#fdba74}.t-bmod{display:inline-flex;align-items:center;padding:3px 9px;border-radius:100px;font-size:.7rem;font-weight:700;white-space:nowrap}.t-bpie{background:#63b3ed24;color:#63b3ed}.t-btend{background:#9ae6b424;color:#9ae6b4}.t-bclas{background:#facc151a;color:var(--t-yellow)}.t-bfin{background:#f472b621;color:#f472b6}.t-lista-header{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;flex-wrap:wrap}.t-lista-actions{display:flex;gap:.8rem;flex-wrap:wrap}.t-table{width:100%;border-collapse:collapse}.t-table thead th{text-align:left;color:var(--t-muted);padding:0 .6rem .8rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em}.t-table tbody tr{border-top:1px solid rgba(255,255,255,.06);transition:background var(--t-ease)}.t-table tbody tr:hover{background:#ffffff08}.t-table td{padding:1rem .6rem;vertical-align:middle}.t-td-fecha{white-space:nowrap;color:var(--t-soft)}.t-td-total{color:var(--t-yellow);font-weight:700;font-size:1.1rem}.t-td-actions{text-align:right}.t-th-sort{cursor:pointer}.t-sort-arrow{display:inline-block;transition:transform .18s}.t-sort-arrow.asc{transform:rotate(180deg)}.t-empty{padding:2.5rem 1rem;text-align:center;color:var(--t-muted);display:flex;flex-direction:column;align-items:center;gap:1rem}.t-form-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.t-meta-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.t-field-group{display:flex;flex-direction:column;gap:.6rem}.t-field-label{font-weight:700;color:var(--t-soft)}.t-date-input{width:100%;border-radius:10px;border:1px solid rgba(255,255,255,.14);background:var(--t-bg);color:#fff;outline:none;padding:.9rem 1rem;font-family:inherit;transition:border-color var(--t-ease),box-shadow var(--t-ease)}.t-date-input:focus{border-color:var(--t-yellow);box-shadow:0 0 0 3px #facc1526}.t-section-block{display:flex;flex-direction:column;gap:0}.t-sec-label{display:block;font-size:.72rem;color:var(--t-muted);font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:.8rem}.t-series-block{display:flex;flex-direction:column;gap:1rem}.t-serie-row{background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:1rem}.t-serie-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.8rem;flex-wrap:wrap}.t-serie-name{font-size:.75rem;color:var(--t-muted);font-weight:700;letter-spacing:.12em;text-transform:uppercase}.t-serie-sub{color:#ffffff73;font-weight:700;font-size:.85rem}.t-serie-sub.active{color:var(--t-yellow)}.t-shots-grid{display:grid;gap:.5rem}.t-shots-10{grid-template-columns:repeat(10,1fr)}.t-shots-7{grid-template-columns:repeat(7,1fr)}.t-shots-5{grid-template-columns:repeat(5,1fr)}.t-cell{display:flex;flex-direction:column;gap:4px}.t-cell-lbl{font-size:.65rem;color:var(--t-muted);text-align:center;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.t-cell-inp{width:100%;border-radius:10px;border:1px solid rgba(255,255,255,.14);background:var(--t-bg);color:#fff;outline:none;text-align:center;padding:.75rem .4rem;font-weight:700;font-size:.9rem;font-family:inherit;transition:border-color var(--t-ease),box-shadow var(--t-ease),background var(--t-ease);-moz-appearance:textfield}.t-cell-inp::-webkit-inner-spin-button,.t-cell-inp::-webkit-outer-spin-button{-webkit-appearance:none}.t-cell-inp:focus{border-color:var(--t-yellow);box-shadow:0 0 0 3px #facc1526}.t-cell-inp.filled{border-color:#facc1573}.t-cell-inp.err{border-color:#ef4444cc!important;background:#ef44440f!important}.t-range-hint{margin-top:.6rem;text-align:right;font-size:.72rem;color:#ffffff40}.t-total-box{padding:1.2rem 1.4rem;border-radius:16px;background:#facc150f;border:1px solid rgba(250,204,21,.22);display:flex;justify-content:space-between;align-items:center;gap:1rem}.t-total-left{flex:1}.t-total-tag{color:var(--t-muted);font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.t-total-num{font-size:2.3rem;color:var(--t-yellow);font-weight:700}.t-total-of{color:#ffffff4d;font-size:1rem;margin-left:6px}.t-total-pct{font-size:1.8rem;color:#fff3;font-weight:700}.t-prog-wrap{width:100%;height:6px;margin-top:.7rem;border-radius:999px;overflow:hidden;background:#ffffff14}.t-prog-bar{height:100%;background:var(--t-yellow);border-radius:inherit;transition:width .25s ease}.t-msg{display:none;align-items:flex-start;gap:.6rem;padding:1rem;border-radius:12px;font-weight:700}.t-msg.show{display:flex}.t-msg-error{background:#ef44441a;border:1px solid rgba(239,68,68,.35);color:#fca5a5}.t-msg-success{background:#22c55e1a;border:1px solid rgba(34,197,94,.35);color:#86efac}.t-stats-row{display:grid;grid-template-columns:repeat(5,1fr);gap:.7rem}.t-scard{background:#ffffff0a;border:1.5px solid rgba(255,255,255,.08);border-radius:14px;padding:1rem}.t-slabel{font-size:.67rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--t-muted);display:block;margin-bottom:4px;line-height:1.3}.t-svalue{font-size:1.6rem;font-weight:700;color:var(--t-yellow);line-height:1;font-variant-numeric:tabular-nums;display:block}.t-ssub{font-size:.72rem;color:#ffffff47;display:block;margin-top:3px}.t-tbwrap{background:#ffffff05;border:1px solid rgba(255,255,255,.08);border-radius:14px;overflow:hidden}.t-thead{display:grid;padding:.75rem 1.1rem;border-bottom:1px solid rgba(255,255,255,.07);column-gap:.5rem}.t-thead span{font-size:.67rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--t-muted);overflow:hidden;white-space:nowrap;text-overflow:clip}.t-trow{display:grid;padding:.9rem 1.1rem;border-bottom:1px solid rgba(255,255,255,.05);align-items:center;transition:background .15s;column-gap:.5rem}.t-trow:last-child{border-bottom:none}.t-trow:hover{background:#ffffff08}.t-trow.me{background:#facc150f;border-left:3px solid var(--t-yellow)}.t-cols-rank{grid-template-columns:40px 1fr 90px 110px 80px 60px}.t-cols-mis{grid-template-columns:110px 80px 110px 80px 1fr}.t-pbadge{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;background:#ffffff12;color:#ffffff80}.t-p1{background:#facc1533;color:var(--t-yellow)}.t-p2{background:#c0c0c02e;color:silver}.t-p3{background:#cd7f322e;color:#cd7f32}.t-ncell{display:flex;flex-direction:column;min-width:0}.t-nmain{font-size:.95rem;font-weight:700;color:var(--t-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.t-tval{font-size:1.05rem;font-weight:700;color:var(--t-yellow);font-variant-numeric:tabular-nums}.t-metag{display:inline-flex;align-items:center;padding:2px 7px;background:#facc1526;border:1px solid rgba(250,204,21,.35);border-radius:100px;font-size:.65rem;font-weight:700;color:var(--t-yellow);letter-spacing:.06em}.t-mbwrap{width:100%;height:3px;background:#ffffff12;border-radius:3px;overflow:hidden;margin-top:5px}.t-mb{height:100%;background:var(--t-yellow);border-radius:3px}.t-posbanner{background:#facc1514;border:1.5px solid rgba(250,204,21,.25);border-radius:14px;padding:1rem 1.2rem;margin-bottom:.8rem;display:flex;align-items:center;gap:.9rem;flex-wrap:wrap}.t-posnum{font-size:2rem;font-weight:700;color:var(--t-yellow);line-height:1}.t-postxt{font-size:.85rem;color:var(--t-soft)}.t-poslbl{font-size:.95rem;font-weight:700;color:var(--t-text)}@keyframes t-spin{to{transform:rotate(360deg)}}.t-spinner{width:26px;height:26px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--t-yellow);border-radius:50%;animation:t-spin .7s linear infinite;display:inline-block}.t-spinner-sm{width:20px;height:20px;border:3px solid rgba(7,9,26,.2);border-top-color:var(--t-bg);border-radius:50%;animation:t-spin .7s linear infinite;display:inline-block}.t-loading-center{padding:2.5rem 1rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem;color:var(--t-soft)}.t-footer{text-align:center;font-size:.8rem;color:#fff3;letter-spacing:.04em;padding-top:.5rem}.t-index-content{width:100%;max-width:520px;position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;text-align:center;gap:0;animation:t-fadeUp .45s ease both;margin-top:10vh}.t-index-badge{display:inline-flex;align-items:center;gap:7px;padding:5px 14px;border-radius:100px;background:#facc151a;border:1.5px solid rgba(250,204,21,.3);font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--t-yellow);margin-bottom:1.5rem}.t-index-badge-dot{width:6px;height:6px;background:var(--t-yellow);border-radius:50%}.t-index-title{font-size:clamp(2.4rem,8vw,3.5rem);font-weight:700;line-height:1.05;margin-bottom:.6rem}.t-index-title span{display:block;color:var(--t-yellow)}.t-index-sep{width:48px;height:2px;background:#facc1566;border-radius:2px;margin:1.4rem auto}.t-index-desc{font-size:1rem;color:var(--t-soft);line-height:1.6;max-width:380px;margin-bottom:2rem}.t-index-nav{display:flex;flex-direction:column;gap:.8rem;width:100%;max-width:320px}.t-btn-primary{display:block;width:100%;padding:1rem 1.5rem;border:none;border-radius:12px;background:var(--t-yellow);color:var(--t-bg);font-family:inherit;font-size:1rem;font-weight:700;cursor:pointer;text-align:center;text-decoration:none;transition:background var(--t-ease),transform var(--t-ease),box-shadow var(--t-ease)}.t-btn-primary:hover{background:#fde047;transform:translateY(-2px);box-shadow:0 8px 24px #facc1559}.t-btn-secondary{display:block;width:100%;padding:1rem 1.5rem;border:1.5px solid rgba(255,255,255,.2);border-radius:12px;background:transparent;color:var(--t-soft);font-family:inherit;font-size:1rem;font-weight:700;cursor:pointer;text-align:center;text-decoration:none;transition:border-color var(--t-ease),color var(--t-ease),transform var(--t-ease)}.t-btn-secondary:hover{border-color:#ffffff80;color:#fff;transform:translateY(-1px)}.t-login-wrap{width:100%;max-width:420px;position:relative;z-index:2;animation:t-fadeUp .35s ease both;margin-top:8vh}.t-login-card{background:var(--t-card);border:1px solid var(--t-border);border-radius:var(--t-radius);padding:2.2rem 2rem;box-shadow:var(--t-shadow);display:flex;flex-direction:column;gap:1.4rem}.t-input{width:100%;border-radius:10px;border:1px solid rgba(255,255,255,.14);background:var(--t-bg);color:#fff;outline:none;padding:.9rem 1rem;font-family:inherit;font-size:1rem;transition:border-color var(--t-ease),box-shadow var(--t-ease)}.t-input:focus{border-color:var(--t-yellow);box-shadow:0 0 0 3px #facc1526}.t-input-group{display:flex;flex-direction:column;gap:.5rem}.t-input-label{font-size:.82rem;font-weight:700;color:var(--t-soft);letter-spacing:.06em}.t-back-link{display:inline-flex;align-items:center;gap:6px;color:#fff6;font-size:.82rem;font-weight:700;text-decoration:none;letter-spacing:.06em;text-transform:uppercase;transition:color .15s;align-self:flex-start}.t-back-link:hover{color:var(--t-yellow)}.t-hidden{display:none!important}@media (max-width: 768px){.t-stats-row{grid-template-columns:repeat(3,1fr)}.t-scard:first-child{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;flex-direction:row;gap:.5rem;padding:.8rem 1.2rem}.t-scard:first-child .t-slabel{margin-bottom:0}.t-scard:first-child .t-ssub{display:none}.t-scard:first-child .t-svalue{font-size:1.4rem}.t-cols-rank{grid-template-columns:36px 1fr 80px 75px}.t-col-fase,.t-col-me{display:none}.t-cols-mis{grid-template-columns:95px 75px 75px 1fr}.t-col-bar{display:none}.t-shots-10{grid-template-columns:repeat(5,1fr)}.t-shots-7{grid-template-columns:repeat(4,1fr)}}@media (max-width: 480px){.tiro-page{padding:1rem .75rem 4rem}.t-card{padding:1.4rem 1.1rem;row-gap:1.1rem}.t-stats-row{grid-template-columns:repeat(2,1fr);gap:.6rem}.t-scard:first-child{grid-column:1 / -1}.t-scard{padding:.85rem .9rem}.t-svalue{font-size:1.4rem}.t-slabel{font-size:.63rem}.t-tab{font-size:.88rem;padding:.6rem .5rem}.t-tg .t-tog{padding:.4rem .7rem;font-size:.8rem}.t-thead{padding:.65rem .85rem}.t-trow{padding:.8rem .85rem}.t-cols-rank{grid-template-columns:30px 1fr 65px 65px}.t-pbadge{width:26px;height:26px;font-size:.78rem}.t-nmain{font-size:.88rem}.t-tval{font-size:.95rem}.t-cols-mis{grid-template-columns:80px 65px 65px 1fr}.t-col-fase-m{display:none}.t-lista-header{flex-direction:column;align-items:stretch}.t-lista-actions{width:100%}.t-btn-add{width:100%;justify-content:center}.t-form-header{flex-direction:column;align-items:stretch}.t-meta-row{grid-template-columns:1fr}.t-form-actions{flex-direction:column}.t-btn-submit,.t-btn-cancel,.t-btn-back-form{width:100%;justify-content:center;min-width:0}.t-total-box{flex-direction:column;align-items:stretch}.t-total-pct{font-size:1.4rem}.t-shots-10{grid-template-columns:repeat(5,1fr);gap:.4rem}.t-shots-7{grid-template-columns:repeat(4,1fr);gap:.4rem}.t-shots-5{grid-template-columns:repeat(5,1fr);gap:.4rem}.t-cell-inp{padding:.6rem .2rem;font-size:.82rem}.t-cell-lbl{font-size:.6rem}.t-table,.t-table tbody,.t-table tr,.t-table td{display:block;width:100%}.t-table thead{display:none}.t-table tbody tr{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:.6rem;margin-bottom:1rem;border-top:none}.t-table td{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.7rem .5rem}.t-table td:before{font-size:.72rem;font-weight:700;text-transform:uppercase;color:var(--t-muted);white-space:nowrap;letter-spacing:.08em}.t-table td:nth-child(1):before{content:"Fecha"}.t-table td:nth-child(2):before{content:"Modalidad"}.t-table td:nth-child(3):before{content:"Fase"}.t-table td:nth-child(4):before{content:"Total"}.t-table td:nth-child(5):before{content:""}}@media (max-width: 420px){.t-card{padding:1.1rem .85rem}.t-shots-10,.t-shots-7{gap:.3rem}.t-shots-5{grid-template-columns:repeat(5,1fr);gap:.3rem}.t-cell-inp{padding:.5rem .1rem;font-size:.78rem}.t-cell-lbl{font-size:.55rem;letter-spacing:0}.t-total-num{font-size:2rem}.t-user-pill{max-width:200px}}@media (max-width: 360px){.tiro-page{padding:.85rem .6rem 4rem}.t-card{padding:1rem .75rem;row-gap:1rem}.t-shots-10,.t-shots-7{gap:.25rem}.t-serie-row{padding:.75rem .6rem}.t-stats-row{grid-template-columns:1fr 1fr}.t-top-bar{flex-wrap:wrap}.t-cols-rank{grid-template-columns:26px 1fr 58px 58px}.t-cols-mis{grid-template-columns:72px 58px 58px 1fr}}
