:root{--color-bg:#fafaf8;--color-surface:#ffffff;--color-border:#e8e5e0;--color-text:#1a1a1a;--color-muted:#6b6b6b;--color-accent:#4a7c59;--color-accent-lt:#eaf2ec;--font-sans:'Segoe UI', system-ui, -apple-system, sans-serif;--font-serif:Georgia, 'Times New Roman', serif;--radius:8px;--max-width:860px;--spacing:1.5rem}*,*::before,*::after{box-sizing:border-box}html{scroll-behavior:smooth}body{background-color:var(--color-bg);color:var(--color-text);font-family:var(--font-sans);font-size:1rem;line-height:1.7;margin:0;padding:0}.site-wrapper{display:flex;flex-direction:column;min-height:100vh}.site-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:0 var(--spacing)}.header-inner{display:flex;align-items:center;justify-content:space-between;max-width:var(--max-width);margin:0 auto;padding:1.1rem 0;flex-wrap:wrap;gap:.75rem}.site-brand{display:flex;flex-direction:column;text-decoration:none}.site-brand .brand-name{font-size:1.35rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em}.site-brand .brand-tagline{font-size:.78rem;color:var(--color-muted);letter-spacing:.04em}.site-nav ul{display:flex;list-style:none;margin:0;padding:0;gap:.15rem;flex-wrap:wrap}.site-nav a{display:inline-block;padding:.35rem .75rem;border-radius:calc(var(--radius)/2);font-size:.9rem;font-weight:500;color:var(--color-muted);text-decoration:none;transition:color .2s,background .2s}.site-nav a:hover{color:var(--color-text);background:var(--color-accent-lt)}.site-nav a.active{color:var(--color-accent);background:var(--color-accent-lt)}main{flex:1;max-width:var(--max-width);margin:2.5rem auto;padding:0 var(--spacing);width:100%}.site-footer{background:var(--color-surface);border-top:1px solid var(--color-border);padding:1.25rem var(--spacing);text-align:center;font-size:.85rem;color:var(--color-muted)}.site-footer a{color:var(--color-accent)}h1,h2,h3,h4{font-weight:700;line-height:1.25;letter-spacing:-.02em;color:var(--color-text);margin-top:0}h1{font-size:2.25rem}h2{font-size:1.6rem}h3{font-size:1.25rem}p{margin-top:0}a{color:var(--color-accent);text-decoration:none}a:hover{text-decoration:underline}.hero{text-align:center;padding:4rem 1rem 3rem}.hero-avatar{width:110px;height:110px;border-radius:50%;background:var(--color-accent-lt);display:flex;align-items:center;justify-content:center;font-size:2.5rem;margin:0 auto 1.5rem;border:3px solid var(--color-accent);overflow:hidden}.hero-avatar img{width:100%;height:100%;object-fit:cover;display:block}.hero h1{font-size:2.75rem;margin-bottom:.5rem}.hero .hero-subtitle{font-size:1.15rem;color:var(--color-muted);margin-bottom:2rem}.hero .hero-links{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.btn{display:inline-block;padding:.6rem 1.4rem;border-radius:var(--radius);font-size:.95rem;font-weight:600;text-decoration:none;transition:opacity .2s,transform .1s}.btn:hover{opacity:.87;transform:translateY(-1px);text-decoration:none}.btn-primary{background:var(--color-accent);color:#fff}.btn-outline{border:2px solid var(--color-accent);color:var(--color-accent)}.sections-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1.25rem;margin-top:3rem}.section-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem;text-decoration:none;color:inherit;transition:box-shadow .2s,transform .15s;display:block}.section-card:hover{box-shadow:0 4px 18px rgba(0,0,0,7%);transform:translateY(-3px);text-decoration:none}.section-card .card-icon{font-size:1.8rem;margin-bottom:.6rem}.section-card h3{margin-bottom:.35rem;font-size:1.05rem}.section-card p{font-size:.88rem;color:var(--color-muted);margin:0}.page-header{margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.page-header h1{margin-bottom:.4rem}.page-header .subtitle{color:var(--color-muted);font-size:1.1rem;margin:0}.card-list{display:flex;flex-direction:column;gap:1.25rem}.post-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.4rem 1.6rem;transition:box-shadow .2s}.post-card:hover{box-shadow:0 4px 18px rgba(0,0,0,7%)}.post-card h2{font-size:1.2rem;margin-bottom:.3rem}.post-card h2 a{color:var(--color-text)}.post-card h2 a:hover{color:var(--color-accent);text-decoration:none}.post-card .post-meta{font-size:.8rem;color:var(--color-muted);margin-bottom:.6rem}.post-card .post-summary{font-size:.93rem;color:var(--color-muted);margin:0}.featured-apps,.other-projects{margin-bottom:2.5rem}.section-label{font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-muted);margin-bottom:1rem;border-bottom:1px solid var(--color-border);padding-bottom:.4rem}.project-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:2rem;transition:all .3s ease;overflow:hidden}.project-card:hover{box-shadow:0 8px 32px rgba(0,0,0,.12);transform:translateY(-4px);border-color:var(--color-accent)}.project-card--featured{border-color:var(--color-accent);border-width:2px;background:linear-gradient(135deg,#fff 85%,var(--color-accent-lt) 100%);box-shadow:0 4px 20px rgba(74,124,89,.15)}.project-card--featured:hover{box-shadow:0 12px 40px rgba(74,124,89,.25);transform:translateY(-4px)}.project-card__wrapper{display:flex;gap:2.5rem;align-items:flex-start}.project-thumbnail{flex-shrink:0;width:145px;height:300px;border-radius:10px;overflow:visible;background:linear-gradient(135deg,var(--color-accent-lt) 0%,#f0f8f4 100%);display:flex;align-items:center;justify-content:center;position:relative;border:1px solid rgba(74,124,89,.2);box-shadow:0 12px 32px rgba(0,0,0,.12),0 6px 12px rgba(0,0,0,8%);transition:all .3s ease;padding:0}.project-thumbnail::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,rgba(255,255,255,0) 50%,rgba(0,0,0,5%) 100%);pointer-events:none;border-radius:10px;z-index:1}.project-card:hover .project-thumbnail{box-shadow:0 20px 48px rgba(0,0,0,.18),0 8px 16px rgba(0,0,0,.1),0 0 20px rgba(74,124,89,.15);transform:translateY(-4px)}.project-thumbnail img{width:100%;height:100%;object-fit:contain;display:block;position:relative;z-index:0;border-radius:8px;transition:transform .3s ease;padding:0}.project-card:hover .project-thumbnail img{transform:scale(1.02)}.project-thumbnail--fan{width:205px;height:330px;background:linear-gradient(160deg,#0c1322 0%,#131d33 100%);overflow:visible;perspective:900px}.fan-deck{position:absolute;inset:0;z-index:2}.fan-card{--x:0px;--y:0px;--r:0deg;position:absolute;left:50%;top:50%;width:165px;aspect-ratio:1080/2106;border-radius:10px;overflow:hidden;background:#0e1726;box-shadow:0 6px 16px rgba(0,0,0,.35);transform:translate(calc(-50% + var(--x)),calc(-50% + var(--y)))rotate(var(--r));transition:transform 600ms cubic-bezier(.05,.43,.25,.95),box-shadow 400ms ease;will-change:transform}.fan-card img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.fan-card--back{background:linear-gradient(160deg,#16223c 0%,#0b1120 100%);border:1px solid rgba(120,200,220,.18)}.fan-card--back::after{content:"ROVI";position:absolute;inset:0;display:grid;place-items:center;font-family:courier new,monospace;font-size:.7rem;letter-spacing:.25em;color:rgba(120,200,220,.35)}.fan-card:nth-child(1){--r:-7deg}.fan-card:nth-child(2){--r:7deg}.fan-card:nth-child(3){--r:-3deg}.fan-card:nth-child(4){--r:3deg}.project-card:hover .fan-card:nth-child(1),.project-card:focus-within .fan-card:nth-child(1){--x:-92px;--y:14px;--r:-18deg}.project-card:hover .fan-card:nth-child(2),.project-card:focus-within .fan-card:nth-child(2){--x:92px;--y:14px;--r:18deg}.project-card:hover .fan-card:nth-child(3),.project-card:focus-within .fan-card:nth-child(3){--x:-52px;--y:-6px;--r:-8deg}.project-card:hover .fan-card:nth-child(4),.project-card:focus-within .fan-card:nth-child(4){--x:52px;--y:-6px;--r:8deg}.project-card:hover .fan-card,.project-card:focus-within .fan-card{box-shadow:0 14px 30px rgba(0,0,0,.45)}@media(hover:none){.fan-card:nth-child(1){--x:-70px;--y:10px;--r:-14deg}.fan-card:nth-child(2){--x:70px;--y:10px;--r:14deg}.fan-card:nth-child(3){--x:-34px;--y:-4px;--r:-6deg}.fan-card:nth-child(4){--x:34px;--y:-4px;--r:6deg}}@media(prefers-reduced-motion:reduce){.fan-card{transition:none}}.project-card__content{flex:1;min-width:0}.project-card__title-section{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}.project-card h2{font-size:1.6rem;font-weight:700;margin:0 0 .1rem;color:var(--color-text);letter-spacing:-.01em}.project-card--featured h2{color:var(--color-accent)}.project-year{font-size:.9rem;font-weight:600;color:var(--color-muted);margin:0}.project-share-btn{background:0 0;border:1px solid var(--color-border);cursor:pointer;color:var(--color-muted);padding:.5rem;border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0;width:36px;height:36px}.project-share-btn:hover{color:var(--color-accent);background:var(--color-accent-lt);border-color:var(--color-accent)}.project-chips{display:flex;gap:.6rem;margin-bottom:1.2rem;flex-wrap:wrap}.chip{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:var(--color-accent-lt);color:var(--color-accent);border-radius:4px;padding:.3rem .7rem;border:1px solid rgba(74,124,89,.2)}.project-card--featured .chip{background:rgba(74,124,89,.1);border-color:var(--color-accent)}.project-description-section{margin-bottom:1.5rem}.project-description-section h3{font-size:.75rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text);margin:0 0 .6rem;opacity:.7}.project-description-copy{display:grid;gap:.75rem}.project-description-copy p{font-size:.95rem;color:var(--color-muted);margin:0;line-height:1.7}.project-description-copy a{color:var(--color-accent);text-decoration-thickness:.08em;text-underline-offset:.12em}.project-additional-images{margin-bottom:1.5rem}.project-additional-images h3{font-size:.75rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text);margin:0 0 .75rem;opacity:.7}.project-additional-images__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.9rem}.project-additional-images__grid img{display:block;width:100%;max-width:100%;height:auto;border-radius:10px;border:1px solid rgba(74,124,89,.16);box-shadow:0 10px 24px rgba(0,0,0,8%)}.project-tech-section{margin-bottom:1.5rem}.project-tech-section h3{font-size:.75rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text);margin:0 0 .6rem;opacity:.7}.project-techs{display:flex;gap:.8rem;flex-wrap:wrap}.tech-tag{display:inline-block;font-size:.8rem;font-weight:500;background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);border-radius:6px;padding:.45rem .85rem;transition:all .2s}.tech-tag:hover{background:var(--color-accent-lt);border-color:var(--color-accent);color:var(--color-accent)}.project-actions{display:flex;gap:.85rem;flex-wrap:wrap;margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--color-border)}.btn-open-site,.btn-github{display:inline-flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;text-decoration:none;border-radius:6px;padding:.6rem 1.3rem;transition:all .2s ease;border:none;cursor:pointer;letter-spacing:.03em}.btn-open-site{background:var(--color-accent);color:#fff;box-shadow:0 4px 12px rgba(74,124,89,.3);min-width:140px}.btn-open-site:hover{background:#3a6347;box-shadow:0 6px 20px rgba(74,124,89,.4);transform:translateY(-2px);text-decoration:none}.btn-github{background:0 0;color:var(--color-accent);border:1.5px solid var(--color-accent)}.btn-github:hover{background:var(--color-accent);color:#fff;box-shadow:0 4px 12px rgba(74,124,89,.3);transform:translateY(-2px)}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}@media(max-width:600px){.contact-grid{grid-template-columns:1fr}}.contact-info h2{font-size:1.3rem}.contact-info p{color:var(--color-muted);font-size:.95rem}.contact-links{list-style:none;padding:0;margin:1.25rem 0 0}.contact-links li{margin-bottom:.6rem;font-size:.95rem}.contact-links a{color:var(--color-text);display:flex;align-items:center;gap:.5rem;text-decoration:none}.contact-links a:hover{color:var(--color-accent)}.contact-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.75rem}.form-group{margin-bottom:1.1rem}.form-group label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.35rem;color:var(--color-text)}.form-group input,.form-group textarea{width:100%;padding:.55rem .8rem;border:1px solid var(--color-border);border-radius:calc(var(--radius)/2);font-family:var(--font-sans);font-size:.95rem;background:var(--color-bg);color:var(--color-text);transition:border-color .2s;outline:none}.form-group input:focus,.form-group textarea:focus{border-color:var(--color-accent)}.form-group textarea{resize:vertical;min-height:120px}.prose h1{font-size:2rem;margin-bottom:1.5rem}.prose h2{font-size:1.4rem;margin-top:2rem;margin-bottom:.75rem}.prose h3{font-size:1.15rem;margin-top:1.5rem}.prose p{margin-bottom:1.25rem}.prose ul,.prose ol{margin-bottom:1.25rem;padding-left:1.5rem}.prose blockquote{border-left:4px solid var(--color-accent);background:var(--color-accent-lt);margin:1.5rem 0;padding:.75rem 1.25rem;border-radius:0 var(--radius)var(--radius)0;font-style:italic;color:var(--color-muted)}.about-hero{display:flex;align-items:flex-start;gap:2rem;margin-bottom:2.5rem;flex-wrap:wrap}.about-avatar{width:130px;height:130px;border-radius:50%;background:var(--color-accent-lt);display:flex;align-items:center;justify-content:center;font-size:3rem;border:3px solid var(--color-accent);flex-shrink:0}.about-intro h1{margin-bottom:.4rem}.about-intro .subtitle{color:var(--color-muted);font-size:1.05rem;margin-bottom:1rem}.skill-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem}.skill-tag{background:var(--color-accent-lt);color:var(--color-accent);border-radius:20px;padding:.25rem .8rem;font-size:.82rem;font-weight:600}.wellness-hero{background:linear-gradient(135deg,var(--color-accent-lt) 0%,#f0f7f2 100%);border-radius:var(--radius);padding:2.5rem;text-align:center;margin-bottom:2.5rem}.wellness-hero .emoji{font-size:3rem;margin-bottom:.75rem}.offerings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem;margin-top:2rem}.offering-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem}.offering-card .icon{font-size:1.6rem;margin-bottom:.6rem}.offering-card h3{margin-bottom:.4rem;font-size:1.05rem}.offering-card p{font-size:.88rem;color:var(--color-muted);margin:0}.fl-hero{text-align:center;padding:4rem 1rem 3.5rem;max-width:700px;margin:0 auto}.fl-tagline{font-size:.82rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-accent);margin-bottom:1rem}.fl-hero h1{font-size:2.8rem;margin-bottom:1rem;line-height:1.2}.fl-intro{font-size:1.1rem;color:var(--color-muted);margin-bottom:2rem;line-height:1.75}.btn-lg{padding:.8rem 2rem;font-size:1.05rem}.fl-section{margin:3.5rem 0}.fl-section-alt{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:2.5rem}.fl-section-title{text-align:center;margin-bottom:2rem;font-size:1.7rem}.fl-offers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem}.fl-offer-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.75rem;transition:box-shadow .2s,transform .15s}.fl-offer-card:hover{box-shadow:0 6px 24px rgba(0,0,0,8%);transform:translateY(-3px)}.fl-offer-icon{font-size:2rem;margin-bottom:.75rem}.fl-offer-card h3{font-size:1.2rem;margin-bottom:.4rem}.fl-offer-desc{font-size:.93rem;color:var(--color-muted);margin-bottom:1rem;line-height:1.6}.fl-offer-list{list-style:none;padding:0;margin:0}.fl-offer-list li{font-size:.88rem;color:var(--color-text);padding:.3rem 0;padding-left:1.2rem;position:relative}.fl-offer-list li::before{content:"✓";position:absolute;left:0;color:var(--color-accent);font-weight:700}.fl-two-col{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:start}@media(max-width:680px){.fl-two-col{grid-template-columns:1fr}}.fl-strength-list{list-style:none;padding:0;margin:1.25rem 0 0}.fl-strength-list li{padding:.4rem 0;padding-left:1.4rem;position:relative;font-size:.95rem;border-bottom:1px solid var(--color-border)}.fl-strength-list li:last-child{border-bottom:none}.fl-strength-list li::before{content:"→";position:absolute;left:0;color:var(--color-accent);font-weight:700}.fl-aside-card{background:var(--color-bg);border:2px solid var(--color-accent);border-radius:var(--radius);padding:1.75rem}.fl-aside-icon{font-size:1.75rem;margin-bottom:.6rem}.fl-aside-card h3{margin-bottom:.5rem;font-size:1.15rem}.fl-aside-card p{font-size:.92rem;color:var(--color-muted);margin-bottom:.75rem}.fl-aside-note{font-size:.82rem!important;font-style:italic;margin-bottom:1.25rem!important}.fl-process-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1.5rem;counter-reset:steps}.fl-process-step{text-align:center;padding:1.5rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.fl-step-number{font-size:2rem;font-weight:800;color:var(--color-accent);line-height:1;margin-bottom:.5rem;font-variant-numeric:tabular-nums}.fl-process-step h3{font-size:1rem;margin-bottom:.4rem}.fl-process-step p{font-size:.86rem;color:var(--color-muted);margin:0}.fl-cta-banner{background:linear-gradient(135deg,var(--color-accent) 0%,#3a6648 100%);border-radius:var(--radius);padding:3rem 2rem;text-align:center;margin:3.5rem 0 1rem;color:#fff}.fl-cta-banner h2{color:#fff;font-size:1.85rem;margin-bottom:.75rem}.fl-cta-banner p{color:rgba(255,255,255,.85);font-size:1rem;margin-bottom:1.75rem;max-width:540px;margin-left:auto;margin-right:auto}.fl-cta-banner .btn-primary{background:#fff;color:var(--color-accent)}.fl-cta-banner .btn-primary:hover{opacity:.92}@media(max-width:640px){h1{font-size:1.75rem}.hero h1{font-size:2rem}.hero{padding:2.5rem .5rem 2rem}.header-inner{padding:.75rem 0}.site-nav a{font-size:.82rem;padding:.3rem .6rem}.about-hero{flex-direction:column}.contact-grid{grid-template-columns:1fr}.project-card__wrapper{flex-direction:column;gap:1.5rem}.project-thumbnail{width:100%;height:400px}.project-card h2{font-size:1.4rem}.btn-open-site{min-width:auto;width:100%}}