:root{--sidebar-width: 260px;--sidebar-collapsed: 0;--gap: 18px;--bg: #f8fafc;--sidebar-bg: #0f172a;--accent: #06b6d4;--text: #0f172a;--muted: #64748b}*{box-sizing:border-box}html,body,#svelte{height:100%;margin:0;padding:0}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;background:var(--bg);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;font-size:16px;line-height:1.5;display:flex;flex-direction:column;min-height:100vh}.app{display:flex;position:relative;flex:1}aside{width:var(--sidebar-width);background:linear-gradient(180deg,var(--sidebar-bg),rgba(15,23,42,.95));color:#fff;padding:24px 16px;transition:transform .25s ease,width .25s ease;transform:translate(0);position:fixed;left:0;top:0;height:100vh;overflow-y:auto;overflow-x:hidden;box-shadow:2px 0 8px #0206171f;z-index:100}aside nav h2{color:#ffffffe6;font-size:1.1rem;font-weight:600;margin:0 0 1rem;padding:0 12px;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:.75rem}aside:not(.open){transform:translate(calc(0px - var(--sidebar-width)));opacity:1;pointer-events:none}main:not(.shifted){margin-left:0;width:100%}main{flex:1;padding:24px;margin-left:var(--sidebar-width);transition:margin-left .25s ease,filter .15s ease;min-width:0;width:calc(100% - var(--sidebar-width))}main.shifted{margin-left:var(--sidebar-width)}.sidebar-toggle{position:fixed;top:12px;left:12px;z-index:999;background:var(--accent);border:0;color:#fff;font-size:18px;width:44px;height:44px;border-radius:8px;cursor:pointer;box-shadow:0 6px 14px #06b6d424;touch-action:manipulation;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.sidebar-toggle:hover{background:#0891b2;transform:scale(1.05)}.sidebar-toggle:active{transform:scale(.95)}aside nav ul{list-style:none;padding:0;margin:8px 0 0}aside nav li{margin:6px 0}aside nav a{display:block;color:#fffffff2;text-decoration:none;padding:12px;border-radius:6px;transition:background .12s ease,color .12s ease;font-weight:500;font-size:.95rem;min-height:44px;display:flex;align-items:center;gap:.5rem}aside nav a:hover,aside nav a:focus{background:#ffffff14;outline:none;color:#fff}aside nav a[aria-current=page]{background:#06b6d433;color:var(--accent)}.backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:90;touch-action:none;opacity:0;animation:fadeIn .25s ease forwards}@keyframes fadeIn{to{opacity:1}}footer{background:var(--sidebar-bg);color:#ffffffe6;padding:24px;text-align:center;border-top:1px solid rgba(255,255,255,.1);font-size:.9rem;width:100%;margin:0}footer p{margin:0}@media (max-width: 1024px){main{padding:20px}:root{--sidebar-width: 240px}aside nav a{font-size:.9rem;padding:10px 12px}}@media (max-width: 768px){main{padding:16px 12px}.sidebar-toggle{top:8px;left:8px;width:40px;height:40px;font-size:16px}aside nav h2{font-size:1rem}}@media (max-width: 900px){aside{position:fixed;left:0;top:0;transform:translate(-100%);width:min(280px,85vw);opacity:1;pointer-events:auto;height:100vh;height:100dvh;z-index:95;transition:transform .3s ease}aside:not(.open){transform:translate(-100%);width:min(280px,85vw);opacity:1;padding:24px 16px;pointer-events:none}aside.open{transform:translate(0);pointer-events:auto}main{padding:16px;width:100%;margin-left:0}main.shifted{margin-left:0}.sidebar-toggle{top:10px;left:10px}footer{padding:16px;font-size:.85rem}}@media (max-width: 480px){main{padding:12px 8px}.sidebar-toggle{top:8px;left:8px;width:36px;height:36px;font-size:14px}aside{width:min(260px,90vw);padding:20px 12px}aside nav a{padding:12px 10px;font-size:.9rem;min-height:48px}aside nav h2{font-size:.95rem}footer{padding:12px;font-size:.8rem}}@media (max-width: 320px){main{padding:8px 6px}aside{width:95vw;padding:16px 10px}aside nav a{font-size:.85rem;padding:10px 8px}.sidebar-toggle{width:32px;height:32px;font-size:12px}}@media (hover: none) and (pointer: coarse){.sidebar-toggle:hover{transform:none;background:var(--accent)}.sidebar-toggle:active{background:#0891b2;transform:scale(.95)}aside nav a:hover{background:#ffffff0d}aside nav a:active{background:#ffffff1f}}:root{--bg: #F5F7FA;--card: #FFFFFF;--accent: #0066FF;--muted: #6B7280;--text: #0F172A;--border: rgba(15,23,42,.08);--radius: 12px;--gap: 1.5rem;--shadow: 0 2px 8px rgba(15,23,42,.04);--shadow-hover: 0 8px 24px rgba(15,23,42,.12);--container-pad: 2rem;--max-width: 1000px;--transition-fast: .18s;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem}@media (max-width: 768px){:root{--font-size-xs: .75rem;--font-size-sm: .8125rem;--font-size-base: .9375rem;--font-size-lg: 1rem;--font-size-xl: 1.125rem;--font-size-2xl: 1.375rem;--font-size-3xl: 1.625rem;--font-size-4xl: 1.875rem;--font-size-5xl: 2.25rem}}@media (max-width: 480px){:root{--font-size-xs: .6875rem;--font-size-sm: .75rem;--font-size-base: .875rem;--font-size-lg: .9375rem;--font-size-xl: 1rem;--font-size-2xl: 1.25rem;--font-size-3xl: 1.5rem;--font-size-4xl: 1.75rem;--font-size-5xl: 2rem}}body{background-color:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6;margin:0;padding:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}h1,h2,h3,h4,h5,h6{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;text-align:center;line-height:1.2;margin:0;font-weight:600}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}.projects{display:flex;flex-direction:column;gap:var(--gap);padding:var(--container-pad);margin:0 auto;max-width:var(--max-width);box-sizing:border-box}.projects h1{font-size:var(--font-size-4xl);font-weight:700;color:var(--text);margin:0 0 2rem;letter-spacing:-.02em}.project-filters,.project-filter{display:flex;gap:.75rem;align-items:center;justify-content:center;flex-wrap:wrap;margin:0 0 1rem;width:100%;box-sizing:border-box}.project-filters input[type=text],.project-filters select,.project-filter input[type=text],.project-filter select{background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:.6rem .85rem;font-size:.95rem;line-height:1;box-shadow:0 2px 6px #0f172a08;transition:all var(--transition-fast) ease;min-width:0}.project-filters input::placeholder,.project-filter input::placeholder{color:var(--muted)}.project-filters select,.project-filter select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:2.25rem;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 10px) calc(1em + 2px),calc(100% - 5px) calc(1em + 2px);background-size:6px 6px,6px 6px;background-repeat:no-repeat;cursor:pointer}.project-filters input[type=text]:hover,.project-filters select:hover,.project-filter input[type=text]:hover,.project-filter select:hover{transform:translateY(-1px);box-shadow:0 6px 18px #0066ff0f;border-color:#0066ff14}.project-filters input[type=text]:focus,.project-filters select:focus,.project-filter input[type=text]:focus,.project-filter select:focus{outline:none;border-color:#0066ff2e;box-shadow:0 8px 24px #0066ff14}.project-filters>*:not(:first-child),.project-filter>*:not(:first-child){flex:0 0 auto}.project-filters input[type=text],.project-filter input[type=text]{flex:1 1 320px;min-width:160px;max-width:70%}@media (max-width: 480px){.project-filters,.project-filter{flex-direction:column;gap:.5rem;margin-bottom:.75rem}.project-filters input[type=text],.project-filter input[type=text],.project-filters select,.project-filter select{width:100%;flex:1 1 auto}}@media (max-width: 768px){.project-filters,.project-filter{gap:.6rem}}.contact-form{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);box-sizing:border-box;max-width:820px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:center;text-align:center;transition:all var(--transition-fast) ease}.contact-form .full{grid-column:1 / -1}.contact-form .field{display:flex;flex-direction:column;gap:.35rem}.contact-form label{font-size:var(--font-size-sm);font-weight:600;color:var(--text)}.contact-form label .required{color:var(--accent);margin-left:.25rem;font-weight:700}.contact-form input[type=text],.contact-form input[type=email],.contact-form input[type=tel],.contact-form select,.contact-form textarea{background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:.6rem .85rem;font-size:var(--font-size-sm);line-height:1.2;box-shadow:0 2px 6px #0f172a08;transition:all var(--transition-fast) ease;min-width:0;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none;touch-action:manipulation}@media (max-width: 768px){.contact-form input[type=text],.contact-form input[type=email],.contact-form input[type=tel],.contact-form select,.contact-form textarea{padding:.75rem .85rem;font-size:var(--font-size-base);min-height:44px}}.contact-form textarea{min-height:140px;resize:vertical;padding-top:.8rem}.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--muted)}.contact-form input:hover,.contact-form select:hover,.contact-form textarea:hover{transform:translateY(-1px);box-shadow:0 6px 18px #0066ff0f;border-color:#0066ff14}.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:none;border-color:#0066ff2e;box-shadow:0 8px 24px #0066ff14}.contact-form .hint{font-size:.85rem;color:var(--muted)}.contact-form .error{color:#c02424;font-size:.85rem}.contact-form .actions{display:flex;gap:.75rem;justify-content:flex-end;align-items:center;margin-top:.25rem}.contact-form .button{padding:.65rem 1.25rem;border-radius:8px;box-shadow:0 4px 12px #0066ff2e}.contact-form .button-secondary{padding:.55rem 1rem}.contact-form .full .button{width:100%}.contact-form .success{background:linear-gradient(135deg,#e6fffa,#f0fff4);color:#064e3b;padding:.65rem .85rem;border-radius:8px;border:1px solid rgba(6,78,59,.06);font-size:.95rem}@media (max-width: 768px){.contact-form{grid-template-columns:1fr;padding:1.25rem}.contact-form .actions{justify-content:stretch;flex-direction:column-reverse}.contact-form .actions .button{width:100%}}@media (prefers-reduced-motion: reduce){.contact-form,.contact-form input,.contact-form textarea,.contact-form .button{transition:none;transform:none!important}}.project-item{background-color:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow);transition:all var(--transition-fast) ease;display:flex;flex-direction:column;gap:1rem;width:100%;box-sizing:border-box}.project-item:hover,.project-item:focus-within{transform:translateY(-2px);box-shadow:var(--shadow-hover);border-color:#0066ff1f}.project-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.project-item h2,.project-item h3{margin:0;font-size:var(--font-size-2xl);line-height:1.3;color:var(--text);font-weight:600;letter-spacing:-.01em}.project-item p{margin:0;color:var(--muted);font-size:var(--font-size-base);line-height:1.6}.project-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin:.5rem 0}.tag{background:linear-gradient(135deg,#e3f2fd,#bbdefb);color:#1565c0;padding:.35rem .85rem;border-radius:20px;font-size:.875rem;font-weight:500;border:1px solid rgba(21,101,192,.1)}.project-meta{display:flex;gap:1rem;align-items:center;justify-content:space-between;flex-wrap:wrap;padding-top:1rem;border-top:1px solid var(--border);margin-top:auto}.project-date{color:var(--muted);font-size:.9rem;display:flex;align-items:center;gap:.5rem}.project-date:before{content:"📅"}.project-actions{display:flex;gap:.75rem;flex-wrap:wrap}.button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background:linear-gradient(135deg,var(--accent),#0052d6);color:#fff;border:none;padding:.65rem 1.25rem;border-radius:8px;cursor:pointer;font-weight:600;font-size:var(--font-size-sm);text-decoration:none;box-shadow:0 4px 12px #06f3;transition:all var(--transition-fast) ease;white-space:nowrap;touch-action:manipulation;-webkit-tap-highlight-color:transparent;min-height:44px}.button-secondary{background:var(--card);color:var(--text);border:1.5px solid var(--border);box-shadow:0 2px 6px #0f172a0f}.button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0066ff4d}.button-secondary:hover{background:var(--bg);border-color:var(--accent);box-shadow:0 4px 12px #0f172a1a}.button:active{transform:translateY(0)}.button:focus-visible{outline:3px solid rgba(0,102,255,.3);outline-offset:2px}.button:before{font-size:1.1em}.button-download:before{content:"⬇️"}.button-view:before{content:"👁️"}.button-github:before{content:"🔗"}.back-button{background:transparent;color:var(--accent);border:none;padding:.5rem 0;margin-bottom:1.5rem;cursor:pointer;font-size:1rem;font-weight:500;display:inline-flex;align-items:center;gap:.5rem;transition:all var(--transition-fast) ease}.back-button:before{content:"←";font-size:1.2em}.back-button:hover{color:#0052d6;transform:translate(-4px)}@media (prefers-reduced-motion: reduce){.project-item,.button,.back-button{transition:none;transform:none!important}}@media (max-width: 768px){:root{--container-pad: 1.5rem;--gap: 1.25rem}.projects h1{font-size:var(--font-size-3xl);margin-bottom:1.5rem}.project-item{padding:1.5rem}.project-item h2,.project-item h3{font-size:var(--font-size-xl)}.project-meta{flex-direction:column;align-items:flex-start}body{font-size:var(--font-size-base)}}@media (max-width: 480px){:root{--container-pad: 1rem;--gap: 1rem}.projects h1{font-size:var(--font-size-3xl);margin-bottom:1.25rem}.project-item{padding:1.25rem;border-radius:10px}.project-item h2,.project-item h3{font-size:var(--font-size-xl)}.button{padding:.55rem 1rem;font-size:var(--font-size-sm);width:100%;justify-content:center;min-height:48px}.project-actions{width:100%}.project-actions .button{flex:1;min-width:0}.contact-form{margin:0 .5rem;padding:1rem}.contact-form .button{min-height:48px;font-size:var(--font-size-base)}.contact-form label{font-size:var(--font-size-sm)}}@media (max-width: 360px){:root{--container-pad: .75rem;--gap: .75rem}.projects{padding:var(--container-pad) .5rem}.projects h1{font-size:var(--font-size-2xl);margin-bottom:1rem}.contact-form{margin:0 .25rem;padding:.75rem;border-radius:8px}.contact-form .field{gap:.25rem}.contact-form label{font-size:var(--font-size-xs)}.contact-form input,.contact-form textarea,.contact-form select{font-size:var(--font-size-sm);padding:.65rem .75rem}.project-item{padding:1rem;margin:0 .25rem}.project-item h2,.project-item h3{font-size:var(--font-size-lg)}.project-item p{font-size:var(--font-size-sm)}.button{font-size:var(--font-size-sm);padding:.6rem .9rem}}@media (hover: none) and (pointer: coarse){.button:hover,.project-item:hover,.contact-form input:hover,.contact-form textarea:hover,.contact-form select:hover{transform:none}.button:focus,.project-item:focus-within,.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{transform:none;box-shadow:0 0 0 3px #06f3}.button:active{transform:scale(.98)}}.projects-container{display:flex;gap:var(--gap);margin-top:1rem;align-items:flex-start}.project-section{flex:1;min-width:0}.project-section h2{font-size:var(--font-size-2xl);margin-bottom:1rem;color:var(--text);font-weight:600;text-align:center}.projects-grid{display:flex;flex-direction:column;gap:var(--gap)}.project-view-btn{width:60%;align-self:center;margin-top:.5rem}@media (max-width: 1024px){.projects-container{gap:1rem}.project-view-btn{width:70%}}@media (max-width: 768px){.projects-container{flex-direction:column;gap:2rem}.project-section{width:100%}.project-view-btn{width:80%}.project-section h2{font-size:var(--font-size-xl);margin-bottom:.75rem}}@media (max-width: 480px){.projects-container{gap:1.5rem}.project-view-btn{width:100%;margin-top:.75rem}.project-section h2{font-size:var(--font-size-lg);margin-bottom:.5rem}}@media (min-width: 1200px){.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--gap)}.project-item{height:fit-content}}
