:root{
  --bg:#0d0d0d;
  --bg-2:#111111;
  --paper:#f7f5f0;
  --white:#ffffff;
  --text:#f5f5f5;
  --dark:#111111;
  --muted:#b7b7b7;
  --muted-dark:#666666;
  --orange:#ff6b00;
  --orange-2:#ff8b2a;
  --line:rgba(255,255,255,.14);
  --line-dark:rgba(17,17,17,.12);
  --radius:28px;
  --shadow:0 28px 90px rgba(0,0,0,.38);
  --container:min(100% - 42px,1180px);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;background:var(--bg);color:var(--text);line-height:1.55;overflow-x:hidden}
body::selection{background:var(--orange);color:#111}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,textarea{font:inherit}
.container{width:var(--container);margin-inline:auto}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link{position:fixed;left:16px;top:16px;z-index:999;padding:10px 14px;background:#fff;color:#111;border-radius:999px;transform:translateY(-130%);transition:.2s}.skip-link:focus{transform:none}.cursor{position:fixed;z-index:9999;pointer-events:none;width:18px;height:18px;border:1px solid var(--orange);border-radius:999px;transform:translate(-50%,-50%);mix-blend-mode:difference;opacity:0;transition:opacity .2s ease,width .2s ease,height .2s ease}.cursor.is-visible{opacity:1}.cursor.is-active{width:42px;height:42px}.site-header{position:fixed;top:0;left:0;right:0;z-index:100;padding-top:14px;transition:all .25s ease}.header-inner{height:72px;display:flex;align-items:center;justify-content:space-between;padding:0 18px;border:1px solid transparent;border-radius:999px;transition:all .25s ease}.site-header.is-scrolled .header-inner{background:rgba(13,13,13,.72);backdrop-filter:blur(20px);border-color:rgba(255,255,255,.1);box-shadow:0 20px 60px rgba(0,0,0,.22)}.brand{display:inline-flex;align-items:center;gap:12px;font-weight:900;letter-spacing:-.04em}.brand img{width:48px;height:48px;object-fit:contain}.brand span{font-size:18px}.site-nav{display:flex;align-items:center;gap:6px}.site-nav a{position:relative;padding:10px 14px;border-radius:999px;color:rgba(255,255,255,.76);font-size:14px;font-weight:800;transition:.22s ease}.site-nav a:hover,.site-nav a:focus-visible{color:#fff;background:rgba(255,255,255,.09)}.nav-toggle{display:none;border:0;background:transparent;padding:8px;cursor:pointer}.nav-toggle span:not(.sr-only){display:block;width:25px;height:2px;background:#fff;margin:5px 0;border-radius:999px}.hero{position:relative;min-height:100svh;display:grid;align-items:center;overflow:hidden;background:radial-gradient(circle at 72% 22%, rgba(255,107,0,.2), transparent 32%),linear-gradient(135deg,#050505 0%,#111 62%,#17110d 100%)}.hero-noise{position:absolute;inset:0;opacity:.23;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220' viewBox='0 0 220 220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='220' height='220' filter='url(%23n)' opacity='.28'/%3E%3C/svg%3E")}.hero-orb{position:absolute;border-radius:50%;filter:blur(10px);opacity:.55;animation:float 9s ease-in-out infinite}.hero-orb-a{width:470px;height:470px;right:-170px;top:18%;background:radial-gradient(circle,rgba(255,107,0,.42),transparent 70%)}.hero-orb-b{width:320px;height:320px;left:-160px;bottom:8%;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 70%);animation-delay:-3s}@keyframes float{0%,100%{transform:translate3d(0,0,0)}50%{transform:translate3d(-20px,24px,0)}}.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1.08fr) minmax(360px,.72fr);gap:70px;align-items:center;padding:140px 0 92px}.eyebrow{display:inline-flex;align-items:center;gap:10px;margin:0 0 18px;color:var(--orange-2);font-size:12px;line-height:1;text-transform:uppercase;letter-spacing:.22em;font-weight:950}.eyebrow::before{content:"";width:34px;height:2px;background:currentColor;border-radius:999px}.eyebrow.dark{color:var(--orange)}.hero h1{max-width:920px;margin:0;font-size:clamp(58px,9vw,126px);line-height:.88;letter-spacing:-.085em;font-weight:950}.hero-lead{max-width:690px;margin:28px 0 0;color:rgba(255,255,255,.76);font-size:clamp(19px,2vw,26px);font-weight:500}.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:52px;padding:0 22px;border-radius:999px;border:1px solid transparent;font-weight:950;letter-spacing:-.02em;cursor:pointer;transition:transform .22s ease, background .22s ease, color .22s ease, border-color .22s ease}.btn:hover{transform:translateY(-3px)}.btn-primary{background:var(--orange);color:#111}.btn-primary:hover{background:#fff}.btn-outline{border-color:rgba(255,255,255,.32);color:#fff;background:rgba(255,255,255,.03)}.btn-outline:hover{border-color:var(--orange);background:rgba(255,107,0,.12)}.btn-dark{background:#111;color:#fff}.btn-dark:hover{background:#fff;color:#111}.hero-showcase{position:relative;min-height:540px}.showcase-card{position:absolute;inset:52px 0 0 0;border:1px solid rgba(255,255,255,.14);border-radius:36px;background:linear-gradient(180deg,rgba(255,255,255,.1),rgba(255,255,255,.045));backdrop-filter:blur(22px);box-shadow:var(--shadow);overflow:hidden}.showcase-top{display:flex;gap:8px;padding:20px;border-bottom:1px solid rgba(255,255,255,.11)}.showcase-top span{width:11px;height:11px;border-radius:50%;background:rgba(255,255,255,.34)}.showcase-content{padding:34px}.showcase-content p{color:var(--orange-2);font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.18em;margin:0 0 14px}.showcase-content h2{margin:0 0 34px;font-size:clamp(34px,4vw,55px);line-height:.98;letter-spacing:-.06em}.stack-list{display:grid;grid-template-columns:1fr 1fr;gap:12px}.stack-list span{padding:14px 15px;border:1px solid rgba(255,255,255,.12);border-radius:18px;background:rgba(0,0,0,.18);color:rgba(255,255,255,.78);font-weight:800}.metric-card{position:absolute;z-index:2;width:180px;border-radius:26px;padding:20px;background:#fff;color:#111;box-shadow:0 20px 70px rgba(0,0,0,.35)}.metric-card strong{display:block;font-size:42px;line-height:1;letter-spacing:-.06em}.metric-card span{display:block;margin-top:8px;color:#555;font-size:14px;font-weight:800}.metric-a{right:-18px;top:8px}.metric-b{left:-24px;bottom:62px;background:var(--orange)}.scroll-indicator{position:absolute;z-index:3;left:50%;bottom:26px;transform:translateX(-50%);display:grid;place-items:center;gap:8px;color:rgba(255,255,255,.58);font-size:11px;text-transform:uppercase;letter-spacing:.22em}.scroll-indicator span{display:block;width:26px;height:42px;border:1px solid rgba(255,255,255,.32);border-radius:999px;position:relative}.scroll-indicator span::after{content:"";position:absolute;left:50%;top:9px;width:4px;height:4px;border-radius:50%;background:var(--orange);transform:translateX(-50%);animation:scrollDot 1.35s ease-in-out infinite}@keyframes scrollDot{0%{opacity:0;transform:translate(-50%,0)}35%{opacity:1}100%{opacity:0;transform:translate(-50%,17px)}}.section{padding:116px 0}.services,.about,.portfolio{background:var(--paper);color:#111}.section-heading{max-width:820px;margin:0 auto 56px;text-align:center}.section-heading h2,.pwa-copy h2,.about h2,.contact-section h2{margin:0;font-size:clamp(38px,5vw,72px);line-height:.96;letter-spacing:-.07em}.section-heading p:not(.eyebrow){max-width:690px;margin:18px auto 0;color:var(--muted-dark);font-size:18px}.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.service-card{min-height:330px;position:relative;padding:28px;border:1px solid var(--line-dark);border-radius:var(--radius);background:#fff;box-shadow:0 18px 50px rgba(17,17,17,.06);overflow:hidden;transition:transform .25s ease,border-color .25s ease,background .25s ease,color .25s ease}.service-card::after{content:"";position:absolute;right:-60px;bottom:-70px;width:180px;height:180px;border-radius:50%;background:var(--orange);opacity:.08;transition:.25s ease}.service-card:hover{transform:translateY(-8px);border-color:rgba(255,107,0,.55);background:#111;color:#fff}.service-card:hover::after{opacity:.28;transform:scale(1.15)}.service-icon{display:grid;place-items:center;width:54px;height:54px;border-radius:18px;background:#111;color:var(--orange);font-weight:950;margin-bottom:86px;transition:.25s ease}.service-card:hover .service-icon{background:var(--orange);color:#111}.service-card h3{margin:0 0 12px;font-size:24px;line-height:1.05;letter-spacing:-.05em}.service-card p{margin:0;color:#666}.service-card:hover p{color:rgba(255,255,255,.72)}.pwa-section{position:relative;background:#0f0f0f;color:#fff;overflow:hidden}.pwa-section::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 18% 20%,rgba(255,107,0,.22),transparent 34%),linear-gradient(180deg,rgba(255,255,255,.04),transparent);pointer-events:none}.pwa-grid{position:relative;display:grid;grid-template-columns:.95fr 1.05fr;gap:70px;align-items:center}.pwa-copy p:not(.eyebrow){font-size:20px;color:rgba(255,255,255,.72);margin:26px 0 0}.text-link{display:inline-flex;margin-top:28px;color:var(--orange-2);font-weight:950}.pwa-features{display:grid;grid-template-columns:1fr 1fr;gap:16px}.mini-feature{min-height:205px;border:1px solid rgba(255,255,255,.13);background:rgba(255,255,255,.06);backdrop-filter:blur(16px);border-radius:28px;padding:26px}.mini-feature strong{display:block;font-size:25px;letter-spacing:-.05em;margin-bottom:42px}.mini-feature span{color:rgba(255,255,255,.68)}.about-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:72px;align-items:start}.about-copy p{margin:0;color:#4e4e4e;font-size:22px}.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:38px}.stats div{border:1px solid var(--line-dark);border-radius:24px;background:#fff;padding:22px}.stats strong{display:block;font-size:42px;line-height:1;letter-spacing:-.06em}.stats span{display:block;margin-top:8px;color:#666;font-weight:800}.project-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.project-card{position:relative;min-height:330px;border-radius:30px;padding:24px;border:1px solid var(--line-dark);overflow:hidden;transition:.25s ease}.project-card-dark{background:#111;color:#fff;border-color:#111}.project-card::after{content:"";position:absolute;inset:auto -80px -90px auto;width:210px;height:210px;background:radial-gradient(circle,var(--orange),transparent 70%);opacity:.3}.project-card:hover{transform:translateY(-8px)}.project-logo{width:100%;height:112px;object-fit:contain;border-radius:22px;margin-bottom:26px;background:rgba(255,255,255,.04)}.project-card span{display:inline-flex;color:var(--orange-2);font-size:12px;text-transform:uppercase;letter-spacing:.12em;font-weight:950;margin-bottom:12px}.project-card h3{margin:0 0 10px;font-size:25px;line-height:1.08;letter-spacing:-.05em}.project-card p{margin:0;color:rgba(255,255,255,.67)}.portfolio-subheading{display:flex;align-items:end;justify-content:space-between;gap:24px;margin:72px 0 24px}.portfolio-subheading h3{margin:0;font-size:clamp(30px,3vw,46px);line-height:1;letter-spacing:-.06em}.web-card{position:relative;min-height:365px;display:block;border-radius:30px;overflow:hidden;background:#111;box-shadow:0 20px 60px rgba(17,17,17,.12);border:1px solid var(--line-dark);transition:.25s ease}.web-card:hover{transform:translateY(-8px)}.web-preview{width:100%;height:365px;object-fit:cover;opacity:.82;transition:.4s ease}.web-card:hover .web-preview{transform:scale(1.05);opacity:.58}.web-logo{position:absolute;z-index:2;top:18px;left:18px;width:190px;height:82px;object-fit:contain;border-radius:18px;box-shadow:0 12px 35px rgba(0,0,0,.18)}.web-card div{position:absolute;z-index:2;left:18px;right:18px;bottom:18px;border-radius:20px;padding:18px;background:rgba(255,255,255,.92);backdrop-filter:blur(18px);color:#111}.web-card strong{display:block;font-size:20px;line-height:1.1;letter-spacing:-.04em}.web-card span{display:block;margin-top:4px;color:#666;font-weight:700}.quote-section{background:var(--orange);color:#111;padding:92px 0}.quote-inner{max-width:980px;text-align:center}.quote-inner blockquote{margin:0;font-size:clamp(30px,5vw,64px);line-height:1;letter-spacing:-.07em;font-weight:950}.quote-inner cite{display:block;margin-top:18px;font-style:normal;font-weight:900;opacity:.7}.quote-inner .btn{margin-top:34px}.contact-section{background:#0d0d0d;color:#fff}.contact-section .section-heading p:not(.eyebrow){color:rgba(255,255,255,.64)}.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:72px}.team-card{position:relative;min-height:520px;border-radius:34px;overflow:hidden;background:#191919;box-shadow:var(--shadow)}.team-card img{width:100%;height:520px;object-fit:cover;filter:saturate(.18) contrast(1.08)}.team-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 42%,rgba(0,0,0,.9))}.team-info{position:absolute;z-index:2;left:24px;right:24px;bottom:24px}.team-info h3{margin:0;font-size:30px;line-height:1;letter-spacing:-.06em}.team-info p{margin:8px 0 12px;color:rgba(255,255,255,.65)}.team-info a{display:inline-flex;color:var(--orange-2);font-weight:950}.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:stretch}.contact-details,.contact-form{border:1px solid rgba(255,255,255,.12);border-radius:34px;background:rgba(255,255,255,.06);padding:30px}.contact-details img{width:74px;height:74px;object-fit:contain;margin-bottom:28px}.contact-details h3{margin:0;font-size:34px;letter-spacing:-.06em}.contact-details p{color:rgba(255,255,255,.64);margin:12px 0 20px}.email-link{display:inline-flex;color:var(--orange-2);font-weight:950;margin-bottom:30px}.quick-links{display:flex;flex-wrap:wrap;gap:10px}.quick-links a{padding:9px 12px;border:1px solid rgba(255,255,255,.12);border-radius:999px;color:rgba(255,255,255,.74);font-weight:800}.quick-links a:hover{border-color:var(--orange);color:#fff}.contact-form{display:grid;gap:14px}.contact-form label{display:grid;gap:8px;color:rgba(255,255,255,.76);font-weight:900}.contact-form input,.contact-form textarea{width:100%;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.22);color:#fff;border-radius:17px;padding:14px 16px;outline:0}.contact-form input:focus,.contact-form textarea:focus{border-color:var(--orange);box-shadow:0 0 0 4px rgba(255,107,0,.12)}.contact-form textarea{resize:vertical}.form-hint{margin:0;color:rgba(255,255,255,.45);font-size:13px}.site-footer{background:#050505;color:#fff;border-top:1px solid rgba(255,255,255,.08);padding:28px 0}.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:22px}.footer-inner p{margin:0;color:rgba(255,255,255,.6)}.footer-inner a{color:var(--orange-2);font-weight:900}.reveal{opacity:0;transform:translateY(28px);transition:opacity .72s ease,transform .72s ease}.reveal.is-visible{opacity:1;transform:none}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}.reveal{opacity:1;transform:none;transition:none}.hero-orb,.scroll-indicator span::after{animation:none}.btn,.service-card,.project-card,.web-card,.web-preview{transition:none}.cursor{display:none}}
@media (max-width:1060px){.hero-grid,.pwa-grid,.about-grid,.contact-grid{grid-template-columns:1fr}.hero-showcase{min-height:460px;order:-1}.showcase-card{inset:20px 0 0}.service-grid,.project-grid,.team-grid{grid-template-columns:repeat(2,1fr)}.latest-projects .project-card:first-child{grid-column:span 2}.team-grid .team-card:first-child{grid-column:span 2}.site-nav{position:fixed;left:20px;right:20px;top:94px;display:none;flex-direction:column;align-items:stretch;background:rgba(15,15,15,.96);border:1px solid rgba(255,255,255,.12);border-radius:26px;padding:12px;backdrop-filter:blur(20px)}.site-nav.is-open{display:flex}.site-nav a{padding:14px}.nav-toggle{display:block}}
@media (max-width:720px){:root{--container:min(100% - 28px,1180px);--radius:22px}.site-header{padding-top:10px}.header-inner{height:64px}.brand img{width:42px;height:42px}.brand span{font-size:16px}.hero-grid{padding:118px 0 90px;gap:28px}.hero h1{font-size:clamp(50px,16vw,72px)}.hero-lead{font-size:18px}.hero-showcase{display:none}.scroll-indicator{display:none}.section{padding:76px 0}.section-heading{text-align:left;margin-bottom:34px}.section-heading h2,.pwa-copy h2,.about h2,.contact-section h2{font-size:clamp(38px,12vw,52px)}.service-grid,.project-grid,.web-projects,.team-grid,.pwa-features,.stats{grid-template-columns:1fr}.latest-projects .project-card:first-child,.team-grid .team-card:first-child{grid-column:auto}.service-card{min-height:260px}.service-icon{margin-bottom:54px}.about-copy p{font-size:19px}.portfolio-subheading{display:block}.portfolio-subheading .text-link{margin-top:14px}.team-card,.team-card img{height:auto;min-height:430px}.team-card img{height:430px}.footer-inner{flex-direction:column;text-align:center}.cursor{display:none}}


/* v3 interactions and extended portfolio */
.scroll-progress{position:fixed;left:0;top:0;z-index:1000;height:3px;width:0;background:linear-gradient(90deg,var(--orange),#fff);box-shadow:0 0 22px rgba(255,107,0,.45);transition:width .08s linear}.back-to-top{position:fixed;z-index:140;right:22px;bottom:22px;width:52px;height:52px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:rgba(17,17,17,.72);color:#fff;backdrop-filter:blur(18px);font-size:22px;font-weight:950;cursor:pointer;opacity:0;transform:translateY(16px) scale(.96);pointer-events:none;transition:.22s ease}.back-to-top.is-visible{opacity:1;transform:none;pointer-events:auto}.back-to-top:hover{background:var(--orange);color:#111;transform:translateY(-3px)}.site-nav a.is-active{color:#111;background:var(--orange)}.site-nav .nav-cta{color:#111;background:#fff;margin-left:6px}.site-nav .nav-cta:hover{background:var(--orange);color:#111}.btn-ghost{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.12)}.btn-ghost:hover{background:#fff;color:#111}.dark-outline{color:#111;border-color:rgba(17,17,17,.22);background:#fff}.dark-outline:hover{background:#111;color:#fff;border-color:#111}.card-action{position:relative;z-index:2;display:inline-flex;margin-top:22px;color:var(--orange-2);font-weight:950}.portfolio-subheading p{margin:12px 0 0;color:#666;max-width:720px}.portfolio-toolbar{display:flex;flex-wrap:wrap;gap:9px;justify-content:flex-end}.filter-btn{border:1px solid var(--line-dark);background:#fff;color:#111;padding:10px 14px;border-radius:999px;font-weight:900;cursor:pointer;transition:.22s ease}.filter-btn:hover,.filter-btn.is-active{background:#111;color:#fff;border-color:#111}.portfolio-controls{display:flex;flex-wrap:wrap;gap:14px;margin:0 0 28px}.portfolio-all{overflow:hidden;transition:max-height .55s ease,opacity .35s ease}.portfolio-all.is-collapsed{max-height:0;opacity:0}.portfolio-all:not(.is-collapsed){max-height:22000px;opacity:1}.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.portfolio-item{border:1px solid var(--line-dark);border-radius:30px;overflow:hidden;background:#fff;color:#111;box-shadow:0 18px 60px rgba(17,17,17,.08);transition:.25s ease}.portfolio-item:hover{transform:translateY(-7px)}.portfolio-item.is-hidden{display:none}.portfolio-media{position:relative;display:block;height:235px;background:#111;overflow:hidden}.portfolio-screenshot{width:100%;height:100%;object-fit:cover;transition:.45s ease}.portfolio-overlay{position:absolute;inset:0;display:grid;place-items:center;background:rgba(0,0,0,.62);color:#fff;font-weight:950;opacity:0;transition:.25s ease}.portfolio-media:hover .portfolio-screenshot{transform:scale(1.06)}.portfolio-media:hover .portfolio-overlay{opacity:1}.portfolio-content{padding:22px}.portfolio-content img{width:100%;height:62px;object-fit:contain;border-radius:14px;background:#111;margin-bottom:16px}.portfolio-content span{display:inline-flex;color:var(--orange);font-size:11px;text-transform:uppercase;letter-spacing:.13em;font-weight:950;margin-bottom:8px}.portfolio-content h3{margin:0 0 8px;font-size:24px;line-height:1.05;letter-spacing:-.05em}.portfolio-content p{margin:0;color:#666}.portfolio-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.portfolio-actions a{padding:9px 12px;border-radius:999px;background:#111;color:#fff;font-size:13px;font-weight:900}.portfolio-actions a:first-child{background:var(--orange);color:#111}.team-grid{grid-template-columns:repeat(4,1fr)}.team-card{min-height:500px}.team-card img{height:500px}.site-footer .footer-inner{flex-wrap:wrap}.site-footer .footer-inner a{margin-left:10px}@media (max-width:1060px){.portfolio-grid{grid-template-columns:repeat(2,1fr)}.team-grid{grid-template-columns:repeat(2,1fr)}.team-grid .team-card:first-child{grid-column:auto}.site-nav .nav-cta{margin-left:0}}@media (max-width:720px){.portfolio-grid{grid-template-columns:1fr}.portfolio-media{height:230px}.portfolio-toolbar{justify-content:flex-start}.portfolio-controls{display:grid}.team-grid{grid-template-columns:1fr}.team-card,.team-card img{height:auto;min-height:430px}.team-card img{height:430px}.back-to-top{right:14px;bottom:14px;width:48px;height:48px}.site-nav a.is-active{background:rgba(255,107,0,.2);color:#fff}}


/* v4 portfolio enhancements */
.portfolio-search{display:inline-flex;align-items:center;min-width:min(320px,100%)}
.portfolio-search input{width:100%;border:1px solid var(--line-dark);border-radius:999px;padding:11px 16px;background:#fff;color:#111;font-weight:800;outline:none;transition:.2s ease}
.portfolio-search input:focus{border-color:var(--orange);box-shadow:0 0 0 4px rgba(255,107,0,.12)}
.project-count{display:inline-flex;align-items:center;padding:10px 14px;border-radius:999px;background:#111;color:#fff;font-size:13px;font-weight:900}
.portfolio-content>img{background:#fff;border:1px solid rgba(17,17,17,.08);padding:10px;object-fit:contain}
.portfolio-domain{margin-top:12px;color:#777;font-size:13px;font-weight:800;word-break:break-word}
.portfolio-empty{display:none;margin:20px 0;padding:22px;border-radius:20px;background:#fff3e8;color:#111;font-weight:900}
.portfolio-empty.is-visible{display:block}
@media (max-width:720px){.portfolio-toolbar{display:grid;grid-template-columns:1fr 1fr}.portfolio-search{grid-column:1 / -1}.project-count{justify-content:center}.filter-btn{width:100%}}


/* v5 refinements */
.site-nav a.home-btn{
  width:44px;
  height:44px;
  padding:0;
  border-radius:12px;
  display:grid;
  place-items:center;
  flex:0 0 44px;
  font-size:0;
  line-height:1;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.16);
}
.site-nav a.home-btn::before{
  content:"⌂";
  font-size:19px;
  font-weight:950;
  line-height:1;
}
.site-nav a.home-btn:hover,
.site-nav a.home-btn.is-active{
  background:var(--orange);
  color:#111;
  border-color:var(--orange);
}
.team-info p{
  text-transform:none;
}
.team-card img[alt="Filipe Moreira"]{
  object-position:center top;
}
.portfolio-item[data-project-domain] .portfolio-content img{
  max-width:180px;
  margin-left:auto;
  margin-right:auto;
}
.portfolio-live-note{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:14px;
  color:#777;
  font-size:12px;
  font-weight:800;
}
@media (max-width:720px){
  .site-nav a.home-btn{
    width:100%;
    flex:auto;
    height:44px;
    border-radius:14px;
    font-size:14px;
    display:flex;
    justify-content:center;
  }
  .site-nav a.home-btn::before{content:"Home";font-size:14px;}
}


/* v6 text/UX refinements */
.site-nav a.home-btn{
  width:44px !important;
  height:44px !important;
  min-width:44px;
  padding:0 !important;
  border-radius:10px !important;
  display:grid !important;
  place-items:center !important;
  flex:0 0 44px;
  font-size:0 !important;
  line-height:1;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.16);
}
.site-nav a.home-btn::before{
  content:"⌂";
  font-size:20px;
  font-weight:950;
  line-height:1;
}
.site-nav a.home-btn:hover,
.site-nav a.home-btn.is-active{
  background:var(--orange);
  color:#111;
  border-color:var(--orange);
}
.team-info p{ text-transform:none; }
.team-card img[alt="Filipe Moreira"]{
  object-position:center top;
}
@media (max-width:720px){
  .site-nav a.home-btn{
    width:100% !important;
    flex:auto;
    height:44px !important;
    border-radius:14px !important;
    font-size:14px !important;
    display:flex !important;
    justify-content:center;
  }
  .site-nav a.home-btn::before{content:"Home";font-size:14px;}
}


/* v8 fixes: square home button, cache-busted team portraits */
.site-nav .home-btn{
  width:44px !important;
  height:44px !important;
  min-width:44px !important;
  padding:0 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  border-radius:0 !important;
  aspect-ratio:1 / 1;
  font-size:18px;
  line-height:1;
}
.team-card img{
  object-fit:cover;
  object-position:center;
}
.team-card img[alt="Filipe Moreira"]{
  object-position:center 22%;
}
.team-card img[alt="Vitor Monteiro"]{
  object-position:center 18%;
}

/* v9 refinements */
.hero{
  min-height:100vh !important;
  height:100vh;
}
.hero-grid{
  min-height:100vh;
  padding-top:118px !important;
  padding-bottom:74px !important;
}
.site-nav a.is-active{
  background:var(--orange) !important;
  color:#111 !important;
  border-color:var(--orange) !important;
}
.site-nav a.home-btn{
  width:auto !important;
  min-width:58px !important;
  height:44px !important;
  padding:0 14px !important;
  border-radius:10px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  font-size:14px !important;
  font-weight:950 !important;
  line-height:1 !important;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.16);
}
.site-nav a.home-btn::before,
.site-nav a.home-btn::after{
  content:none !important;
}
.phone-note{
  margin:8px 0 0;
  color:rgba(255,255,255,.58);
  font-size:12px;
  line-height:1.4;
  font-weight:700;
}
@media (max-width:980px){
  .hero{height:auto;min-height:100vh !important;}
  .hero-grid{min-height:100vh;padding-top:130px !important;padding-bottom:96px !important;}
}
@media (max-width:720px){
  .site-nav a.home-btn{
    width:100% !important;
    min-width:0 !important;
    height:44px !important;
    border-radius:14px !important;
    font-size:14px !important;
  }
}


/* v11 — Ajustes PWA e contactos */
.pwa-features{
  align-self:start;
}
.mini-feature{
  min-height:0 !important;
  height:auto !important;
  padding:26px !important;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:34px;
}
.mini-feature strong{
  margin-bottom:0 !important;
}
.mini-feature span{
  max-width:28ch;
  line-height:1.45;
}
.contact-details .email-link{
  display:block;
  width:max-content;
  max-width:100%;
  margin-bottom:12px !important;
  line-height:1.2;
}
.contact-details .phone-link{
  margin-top:4px;
  margin-bottom:18px !important;
  font-size:20px;
  letter-spacing:.01em;
}
.contact-details .phone-note{
  margin:0 0 28px !important;
  color:rgba(255,255,255,.58);
  font-size:13px;
  line-height:1.4;
  font-weight:800;
}
@media (max-width:1060px){
  .pwa-grid{grid-template-columns:1fr;gap:34px;}
  .pwa-features{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:720px){
  .pwa-features{grid-template-columns:1fr;}
  .mini-feature{gap:22px;}
  .contact-details .email-link{width:100%;word-break:break-word;}
}
