:root{color-scheme:light;--ink:#181b22;--muted:#626b7a;--line:#dfe4ea;--panel:#f5f7fa;--white:#ffffff;--cobalt:#194fd8;--teal:#0b7d82;--mint:#d9f2e6;--amber:#f1b82d;--coral:#e45f4f;--shadow:0 20px 60px rgba(24,27,34,0.12);--radius:8px;--max:1180px;}:root[data-theme="dark"]{color-scheme:dark;--ink:#f6f8fb;--muted:#aab4c3;--line:#2d3542;--panel:#171d26;--white:#0f141c;--cobalt:#7aa2ff;--teal:#4fc3bd;--mint:#17382c;--amber:#f2c557;--coral:#ff8677;--shadow:0 20px 60px rgba(0,0,0,0.34);}*{box-sizing:border-box;}html{scroll-behavior:smooth;overflow-x:hidden;}body{margin:0;background:var(--white);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;line-height:1.5;overflow-x:hidden;}a{color:inherit;text-decoration:none;}*:focus-visible{outline:3px solid var(--teal);outline-offset:3px;}.skip-link{position:fixed;top:12px;left:12px;z-index:200;border-radius:999px;background:var(--ink);color:var(--white);font-size:0.92rem;font-weight:800;padding:10px 14px;transform:translateY(-140%);transition:transform 0.18s ease;}.skip-link:focus{transform:translateY(0);}p,h1,h2,h3{margin:0;}.site-header{position:fixed;top:16px;left:50%;z-index:20;display:flex;align-items:center;justify-content:space-between;width:min(calc(100% - 32px),var(--max));margin:0;padding:10px 12px;border:1px solid rgba(223,228,234,0.88);border-radius:var(--radius);background:rgba(255,255,255,0.86);box-shadow:0 12px 34px rgba(24,27,34,0.08);transform:translateX(-50%);backdrop-filter:blur(18px);}main{padding-top:92px;}:root[data-theme="dark"] .site-header{background:rgba(15,20,28,0.86);box-shadow:0 12px 34px rgba(0,0,0,0.24);}.brand{display:inline-flex;align-items:center;gap:10px;font-size:0.94rem;font-weight:700;}.brand-mark{display:inline-grid;width:34px;height:34px;place-items:center;border-radius:var(--radius);background:var(--ink);color:var(--white);font-size:0.78rem;letter-spacing:0;}.menu-toggle{display:none;width:40px;height:40px;flex:0 0 auto;place-items:center;border:1px solid var(--line);border-radius:6px;background:var(--white);color:var(--ink);cursor:pointer;padding:0;}.menu-toggle span{display:block;width:18px;height:2px;border-radius:999px;background:currentColor;transition:opacity 0.18s ease,transform 0.18s ease;}.menu-toggle span + span{margin-top:4px;}.site-header.is-menu-open .menu-toggle span:first-child{transform:translateY(6px) rotate(45deg);}.site-header.is-menu-open .menu-toggle span:nth-child(2){opacity:0;}.site-header.is-menu-open .menu-toggle span:last-child{transform:translateY(-6px) rotate(-45deg);}.site-nav{display:flex;gap:6px;min-width:0;}.site-nav a{border-radius:6px;color:var(--muted);font-size:0.9rem;min-width:0;padding:8px 10px;}.site-nav a:hover,.site-nav a:focus-visible{background:var(--panel);color:var(--ink);outline:3px solid var(--teal);outline-offset:3px;}.header-cta{display:inline-flex;min-height:38px;align-items:center;justify-content:center;border:1px solid var(--ink);border-radius:999px;background:var(--ink);color:var(--white);font-size:0.9rem;font-weight:800;padding:8px 16px;white-space:nowrap;}.header-cta:hover,.header-cta:focus-visible{outline:3px solid var(--teal);outline-offset:3px;transform:translateY(-1px);}:root[data-theme="dark"] .header-cta{background:#f6f8fb;border-color:#f6f8fb;color:#0f141c;}.site-header-actions{display:flex;align-items:center;gap:12px;min-width:0;}.utility-controls{display:flex;gap:6px;min-width:0;}.utility-toggle{display:inline-flex;min-height:36px;align-items:center;justify-content:center;gap:6px;border:1px solid var(--line);border-radius:6px;background:var(--white);color:var(--muted);cursor:pointer;font:inherit;font-size:0.82rem;font-weight:800;min-width:0;padding:7px 10px;white-space:nowrap;}.utility-toggle[aria-pressed="true"]{background:var(--ink);border-color:var(--ink);color:var(--white);}.utility-toggle:hover,.utility-toggle:focus-visible{color:var(--ink);outline:3px solid var(--teal);outline-offset:3px;}.utility-toggle[aria-pressed="true"]:hover,.utility-toggle[aria-pressed="true"]:focus-visible{color:var(--white);}.section{width:min(calc(100% - 32px),var(--max));margin:0 auto;padding:76px 0;}.section[id]{scroll-margin-top:116px;}.hero{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(300px,0.78fr);gap:38px;align-items:center;min-height:auto;padding-top:50px;padding-bottom:68px;}.eyebrow{color:var(--teal);font-size:0.72rem;font-weight:800;letter-spacing:0;margin-bottom:12px;text-transform:uppercase;}h1{max-width:760px;font-size:clamp(2.65rem,4.8vw,4.55rem);line-height:1;letter-spacing:0;}.hero h1{font-size:clamp(2rem,3.6vw,3.4rem);}h1 span,h2 span{display:block;}.headline-soft{font-weight:450;}h2{max-width:760px;font-size:clamp(2rem,4vw,4rem);font-weight:750;line-height:1.02;letter-spacing:0;}h3{font-size:1.18rem;line-height:1.2;}.hero-text{max-width:620px;color:var(--muted);font-size:clamp(1rem,1.35vw,1.18rem);margin-top:20px;}.hero-actions,.contact-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px;}.button{display:inline-flex;min-height:44px;align-items:center;justify-content:center;border:1px solid transparent;border-radius:6px;font-size:0.94rem;font-weight:750;padding:10px 16px;transition:transform 160ms ease,background-color 160ms ease,border-color 160ms ease;}.button:hover,.button:focus-visible{outline:3px solid var(--teal);outline-offset:3px;transform:translateY(-1px);}.button.primary{background:var(--ink);color:var(--white);}:root[data-theme="dark"] .button.primary,:root[data-theme="dark"] .utility-toggle[aria-pressed="true"]{background:#f6f8fb;border-color:#f6f8fb;color:#0f141c;}.button.secondary{border-color:var(--line);background:var(--white);color:var(--ink);}.hero-visual{display:grid;min-width:0;padding-bottom:38px;position:relative;}.portrait-card{position:relative;height:clamp(340px,46vh,460px);margin:0;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(135deg,rgba(24,27,34,0.08),rgba(11,125,130,0.16)),var(--panel);box-shadow:var(--shadow);overflow:hidden;}.portrait-card::before{content:"Portrait pending";position:absolute;inset:16px;display:grid;place-items:center;border:1px dashed rgba(24,27,34,0.24);border-radius:6px;color:var(--muted);font-weight:800;}.portrait-card img{position:relative;z-index:1;display:block;width:100%;height:100%;object-fit:cover;object-position:50% 50%;}.portrait-card img.is-missing{display:none;}.portrait-card figcaption{display:none;}.portrait-card figcaption strong{font-size:1rem;min-width:0;}.portrait-card figcaption span{color:rgba(255,255,255,0.78);font-size:0.9rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}.compact-preview{position:absolute;right:18px;bottom:0;z-index:3;width:min(260px,64%);box-shadow:0 18px 46px rgba(24,27,34,0.16);}.interface-shell{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);box-shadow:var(--shadow);overflow:hidden;}.window-bar{display:flex;gap:7px;padding:14px;border-bottom:1px solid var(--line);background:var(--white);}.window-bar span{width:9px;height:9px;border-radius:999px;background:var(--line);}.screen-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:12px;padding:16px;}.compact-preview .window-bar{padding:10px 12px;}.compact-preview .screen-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:10px;}.compact-preview .panel-line,.compact-preview .metric-strip{display:none;}.screen-panel,.metric-strip{min-height:150px;border-radius:var(--radius);padding:18px;}.compact-preview .screen-panel,.compact-preview .metric-strip{min-height:64px;padding:12px;}.screen-panel{display:flex;flex-direction:column;justify-content:flex-end;border:1px solid var(--line);background:var(--white);}.panel-large{min-height:260px;background:linear-gradient(135deg,rgba(25,79,216,0.9),rgba(11,125,130,0.82)),linear-gradient(90deg,var(--cobalt),var(--teal));color:#ffffff;}.compact-preview .panel-large{min-height:98px;}.panel-dark{background:var(--ink);color:var(--white);}:root[data-theme="dark"] .panel-dark{background:#0b1018;color:#ffffff;}.panel-line{background:linear-gradient(90deg,transparent 12px,rgba(25,79,216,0.12) 12px,rgba(25,79,216,0.12) 14px,transparent 14px),var(--white);}.panel-label{color:currentColor;font-size:0.72rem;font-weight:800;opacity:0.72;text-transform:uppercase;}.screen-panel strong{display:block;margin-top:8px;font-size:1.3rem;line-height:1.1;}.compact-preview .screen-panel strong{font-size:0.95rem;}.metric-strip{display:grid;grid-column:1 / -1;grid-template-columns:repeat(3,1fr);gap:10px;min-height:78px;background:var(--white);border:1px solid var(--line);}.compact-preview .metric-strip{min-height:48px;}.metric-strip span{display:grid;place-items:center;border-radius:6px;background:var(--panel);color:var(--muted);font-weight:800;}.intro{padding-top:22px;}.intro p{max-width:980px;color:var(--ink);font-size:clamp(1.35rem,2vw,1.8rem);line-height:1.24;}.highlight-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:34px;}.highlight-grid article{border-top:1px solid var(--line);padding-top:18px;}.highlight-grid strong{display:block;color:var(--ink);font-size:clamp(2rem,4vw,3.5rem);line-height:0.95;}.highlight-grid span{display:block;max-width:260px;color:var(--muted);font-size:0.94rem;margin-top:8px;}.split{display:grid;grid-template-columns:0.75fr 1.25fr;gap:42px;align-items:start;}.focus-grid,.contribution-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;}.focus-content{display:grid;gap:24px;}.capability-block{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);padding:22px;}.tag-list{display:flex;flex-wrap:wrap;gap:10px;}.tag-list span{display:inline-flex;min-height:38px;align-items:center;border:1px solid var(--line);border-radius:999px;background:var(--white);color:var(--ink);font-size:0.94rem;font-weight:750;padding:8px 13px;}.focus-grid article,.contribution-grid article,.timeline article{border:1px solid var(--line);border-radius:var(--radius);background:var(--white);padding:22px;}.focus-grid span,.contribution-grid span,.timeline span{display:block;color:var(--teal);font-size:0.78rem;font-weight:800;margin-bottom:22px;}.focus-grid h3,.contribution-grid h3,.timeline h3{margin-top:0;}.focus-grid p,.contribution-grid p,.timeline p,.project-content p,.copy-block p,.section-heading p,.component-board p,.next-project p{color:var(--muted);}.section-heading{display:grid;gap:12px;margin-bottom:28px;}.project-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;}.project-card{min-width:0;border:1px solid var(--line);border-radius:var(--radius);background:var(--white);overflow:hidden;}.project-card.featured{grid-column:span 2;}.project-card a{display:block;height:100%;}.project-card:hover{box-shadow:var(--shadow);}.project-visual{height:280px;border-bottom:1px solid var(--line);background:var(--panel);position:relative;overflow:hidden;}.project-visual img{display:block;width:100%;height:100%;object-fit:cover;object-position:top center;}.project-content{display:grid;gap:12px;padding:20px;}.project-meta{color:var(--teal);font-size:0.76rem;font-weight:800;text-transform:uppercase;}.text-link{color:var(--cobalt);font-weight:800;}.up-visual{background:#eef4ff;}.up-visual img{object-position:top center;}.sas-visual{background:#dff3f7;}.sas-visual img{object-position:top left;}.bluebox-visual{background:#365a86;}.bluebox-visual img{object-position:center center;}.bluebox-evidence-card{display:grid;grid-template-rows:minmax(0,1fr) auto;min-height:430px;}.bluebox-evidence-card img{height:100%;min-height:0;object-fit:contain;object-position:center center;padding:14px;}.soma-phone-grid{grid-template-columns:repeat(4,minmax(0,1fr));align-items:start;}.soma-phone-card{display:grid;grid-template-rows:minmax(0,1fr) auto;min-height:480px;}.soma-phone-card img{height:100%;min-height:0;object-fit:contain;object-position:top center;padding:14px;}.interbanking-visual{background:#f5f6fb;}.interbanking-visual img{object-position:center center;}.soma-visual{background:#0b0c10;}.soma-visual img{object-fit:contain;object-position:center center;padding:18px;}.browser-line{height:34px;background:var(--white);border-bottom:1px solid #cad8ef;}.hero-block{height:104px;margin:18px;border-radius:var(--radius);background:linear-gradient(118deg,#123f9c 0 48%,transparent 48%),linear-gradient(90deg,#2f6ec7,#f0c469);}.module-row{height:42px;margin:0 18px 16px;border-radius:6px;background:var(--white);}.content-mosaic{height:84px;margin:0 18px;border-radius:var(--radius);background:linear-gradient(90deg,#0d3fa2 0 28%,transparent 28%),linear-gradient(90deg,transparent 32%,#dfe9fb 32% 62%,transparent 62%),linear-gradient(90deg,transparent 66%,#f1b82d 66%);}.product-visual,.finance-visual{background:linear-gradient(90deg,transparent 14px,rgba(11,125,130,0.18) 14px 16px,transparent 16px),linear-gradient(180deg,#f9fbfc,#e7f4f2);}.system-visual{background:linear-gradient(90deg,#181b22 0 28%,transparent 28%),linear-gradient(180deg,#f7f9fb,#eef2f6);}.mobile-visual{background:radial-gradient(circle at 50% 22%,rgba(228,95,79,0.28),transparent 18%),linear-gradient(180deg,#f8faf9,#d9f2e6);}.commerce-visual{background:linear-gradient(135deg,rgba(241,184,45,0.62),transparent 38%),linear-gradient(180deg,#ffffff,#f7f3e3);}.molinos-visual{background:#08090b;}.molinos-visual img{object-fit:contain;object-position:center center;padding:12px;}.process{border-top:1px solid var(--line);border-bottom:1px solid var(--line);}.process-list{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;list-style:none;margin:0;padding:0;}.process-list li{border-radius:var(--radius);background:var(--panel);padding:20px;position:relative;}.process-list li:not(:last-child)::after{content:"→";position:absolute;top:20px;right:-16px;z-index:2;display:grid;width:32px;height:32px;place-items:center;border:1px solid var(--line);border-radius:999px;background:var(--white);color:var(--teal);font-size:1.1rem;font-weight:800;box-shadow:0 8px 24px rgba(24,27,34,0.08);}.process-list span{display:block;color:var(--ink);font-size:1.12rem;font-weight:800;margin-bottom:30px;}.process-list p{color:var(--muted);}.timeline{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;}.timeline article{background:var(--panel);}.languages{border-top:1px solid var(--line);padding-top:42px;padding-bottom:42px;}.languages .section-heading{margin-bottom:18px;}.languages h2{max-width:560px;font-size:clamp(1.25rem,2vw,1.8rem);line-height:1.12;}.language-grid{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-start;}.language-grid article{display:flex;align-items:baseline;justify-content:space-between;gap:16px;width:fit-content;min-width:220px;border:1px solid var(--line);border-radius:var(--radius);background:transparent;padding:14px 16px;}.language-grid span{display:block;color:var(--teal);font-size:0.78rem;font-weight:800;margin-bottom:0;text-transform:uppercase;}.language-grid strong{display:block;color:var(--ink);font-size:1rem;font-weight:650;line-height:1.1;text-align:right;}@media (max-width:520px){.language-grid{align-items:stretch;}.language-grid article{align-items:flex-start;flex-direction:column;gap:6px;min-width:min(100%,220px);}.language-grid strong{text-align:left;}}.contact{display:grid;grid-template-columns:0.82fr 1.18fr;gap:34px;align-items:start;border-radius:var(--radius);background:var(--ink);color:var(--white);margin-bottom:28px;padding:44px;}.contact .eyebrow,.contact h2{color:var(--white);}.contact .headline-soft{color:rgba(255,255,255,0.72);font-size:clamp(1.2rem,2vw,1.7rem);font-weight:200;line-height:1.16;margin-top:12px;}.availability-pill{display:inline-flex;min-height:38px;align-items:center;gap:10px;border:1px solid rgba(255,255,255,0.12);border-radius:999px;background:rgba(255,255,255,0.08);color:rgba(255,255,255,0.82);font-size:0.92rem;margin:0 0 24px;padding:8px 14px;}.availability-pill span{width:9px;height:9px;border-radius:999px;background:#7ee66b;box-shadow:0 0 0 5px rgba(126,230,107,0.14);}.availability-pill strong{font-weight:450;}:root[data-theme="dark"] .contact{background:#f6f8fb;color:#0f141c;}:root[data-theme="dark"] .contact .eyebrow,:root[data-theme="dark"] .contact h2{color:#0f141c;}:root[data-theme="dark"] .contact .headline-soft{color:rgba(15,20,28,0.66);}:root[data-theme="dark"] .availability-pill{border-color:rgba(15,20,28,0.12);background:rgba(15,20,28,0.06);color:rgba(15,20,28,0.76);}:root[data-theme="dark"] .contact .button.primary{background:#0f141c;border-color:#0f141c;color:#ffffff;}.contact .button.secondary{background:transparent;color:var(--white);}:root[data-theme="dark"] .contact .button.secondary{border-color:rgba(15,20,28,0.24);color:#0f141c;}.contact-panel{display:grid;gap:12px;}.contact-card{display:grid;grid-template-columns:auto minmax(0,1fr);gap:16px;align-items:end;border:1px solid rgba(255,255,255,0.18);border-radius:var(--radius);background:rgba(255,255,255,0.06);color:var(--white);padding:20px;}.contact-card-featured{position:relative;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:18px;min-height:150px;padding-right:72px;}.contact-card-split{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;}.contact-card-small{min-height:132px;}.contact-icon{display:inline-grid;width:62px;height:62px;place-items:center;border:1px solid rgba(255,255,255,0.16);border-radius:var(--radius);background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.78);}.contact-icon svg,.icon-button svg{width:30px;height:30px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2;}.icon-button svg{width:18px;height:18px;}.contact-card-body{display:grid;min-width:0;gap:8px;}.contact-card-body span{color:rgba(255,255,255,0.62);font-size:0.72rem;font-weight:800;letter-spacing:0.18em;text-transform:uppercase;}.contact-card-body strong{font-size:clamp(1.05rem,2vw,1.45rem);line-height:1.15;word-break:break-word;}.icon-button{display:inline-flex;position:absolute;top:50%;right:20px;width:38px;height:38px;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,0.22);border-radius:999px;background:transparent;color:var(--white);cursor:pointer;font:inherit;font-size:0.88rem;font-weight:800;padding:0;transform:translateY(-50%);}.icon-button:hover,.icon-button:focus-visible{border-color:rgba(255,255,255,0.52);outline:3px solid var(--teal);outline-offset:3px;}.contact-card:hover,.contact-card:focus-visible{border-color:rgba(255,255,255,0.42);outline:3px solid var(--teal);outline-offset:3px;}:root[data-theme="dark"] .contact-card{border-color:rgba(15,20,28,0.16);background:rgba(15,20,28,0.05);color:#0f141c;}:root[data-theme="dark"] .contact-card-body span{color:rgba(15,20,28,0.58);}:root[data-theme="dark"] .contact-icon{border-color:rgba(15,20,28,0.16);background:rgba(15,20,28,0.05);color:rgba(15,20,28,0.66);}:root[data-theme="dark"] .icon-button{border-color:rgba(15,20,28,0.18);color:#0f141c;}.site-footer{display:flex;justify-content:space-between;width:min(calc(100% - 32px),var(--max));margin:0 auto;padding:26px 0 42px;color:var(--muted);font-size:0.9rem;}.back-link{display:inline-flex;color:var(--muted);font-size:0.92rem;margin-bottom:28px;}.case-hero{display:grid;grid-template-columns:1fr minmax(320px,0.5fr);gap:44px;align-items:end;}.case-facts{display:grid;gap:10px;margin:0;}.case-facts div{border:1px solid var(--line);border-radius:var(--radius);padding:16px;}.case-facts dt{color:var(--teal);font-size:0.72rem;font-weight:800;margin-bottom:6px;text-transform:uppercase;}.case-facts dd{margin:0;}.case-preview{padding-top:0;}.case-image{margin:0;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);box-shadow:0 18px 48px rgba(24,27,34,0.1);overflow:hidden;}.case-image img{display:block;width:100%;height:100%;cursor:zoom-in;object-fit:cover;object-position:top center;}.case-image figcaption,.real-components figcaption{border-top:1px solid var(--line);background:var(--white);color:var(--muted);font-size:0.92rem;padding:14px 16px;}.hero-image{max-height:780px;}.hero-image img{height:auto;}.project-detail-hero{max-height:640px;}.project-detail-hero img{height:auto;}.project-detail-hero .contained-shot{height:560px;object-fit:contain;padding:28px;}.molinos-hero-image{background:#08090b;}.molinos-hero-image .contained-shot{height:560px;padding:34px;}.sas-overview{display:grid;grid-template-columns:minmax(0,0.86fr) minmax(320px,0.64fr);gap:34px;align-items:start;}.sas-overview-copy{display:grid;gap:20px;padding-top:14px;}.sas-overview-copy .copy-block{font-size:1.02rem;}.sas-overview-image{justify-self:end;width:min(100%,460px);max-height:none;}.sas-overview-image img{height:auto;object-fit:contain;}.placeholder-showcase{display:grid;min-height:520px;place-items:center;padding:36px;}.placeholder-device{width:min(720px,100%);aspect-ratio:16 / 10;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(135deg,rgba(241,184,45,0.58),transparent 40%),linear-gradient(90deg,rgba(255,255,255,0.92) 0 22%,transparent 22%),linear-gradient(180deg,#fffaf0,#f6f1df);box-shadow:var(--shadow);}.up-showcase{min-height:620px;border:1px solid #bed1ea;border-radius:var(--radius);background:#f0f5ff;overflow:hidden;}.up-nav{height:44px;background:#ffffff;border-bottom:1px solid #cbd8ea;}.up-hero-area{display:flex;min-height:250px;align-items:center;padding:38px;background:linear-gradient(116deg,#0c3d9d 0 48%,rgba(12,61,157,0) 48%),linear-gradient(90deg,#1a58c0,#eac171);color:var(--white);}.up-hero-area span,.up-hero-area em{display:block;font-style:normal;}.up-hero-area strong{display:block;max-width:360px;font-size:clamp(2.4rem,5vw,5.2rem);line-height:0.95;margin:10px 0 22px;}.up-actions{height:68px;background:#dfeaff;}.up-cards{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:18px;padding:38px;}.up-cards span{min-height:190px;border-radius:var(--radius);background:var(--white);}.case-section{padding-top:60px;padding-bottom:60px;}.image-grid{display:grid;gap:16px;}.image-grid-2{grid-template-columns:repeat(2,minmax(0,1fr));}.sas-bento-grid{grid-template-columns:repeat(6,minmax(0,1fr));align-items:start;}.sas-bento-card{display:grid;grid-template-rows:minmax(0,1fr) auto;grid-column:span 3;min-height:360px;}.sas-bento-card img{height:100%;min-height:0;object-fit:contain;object-position:top center;padding:16px;}.sas-bento-tall{grid-column:span 3;grid-row:span 2;min-height:620px;}.sas-bento-wide{grid-column:span 3;min-height:390px;}.sas-bento-tall img{min-height:560px;}.sas-bento-wide img{min-height:310px;}.molinos-desktop-grid{grid-template-columns:1.1fr 0.95fr 0.95fr;align-items:start;}.molinos-screen-card{display:grid;grid-template-rows:360px auto;min-height:0;}.molinos-screen-card img{height:100%;min-height:0;object-fit:cover;object-position:top center;}.molinos-screen-wide{min-height:0;}.molinos-responsive-grid{grid-template-columns:repeat(4,minmax(0,1fr));align-items:start;}.molinos-account-card{grid-column:span 2;min-height:0;}.molinos-phone-card{display:grid;grid-template-rows:360px auto;min-height:0;}.molinos-phone-card img{height:100%;min-height:0;object-fit:cover;object-position:top center;}.case-image.tall{height:720px;}.responsive-showcase{display:grid;grid-template-columns:0.42fr 0.72fr 1.25fr;gap:16px;align-items:start;}.phone-shot{height:700px;}.tablet-shot{height:700px;}.desktop-shot{height:700px;}.two-column{display:grid;grid-template-columns:0.78fr 1fr;gap:42px;}.copy-block{display:grid;gap:18px;font-size:1.08rem;}.template-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;}.template-card{display:flex;min-height:290px;flex-direction:column;justify-content:flex-end;border:1px solid var(--line);border-radius:var(--radius);padding:20px;overflow:hidden;}.template-card span{color:var(--teal);font-size:0.76rem;font-weight:800;margin-bottom:10px;text-transform:uppercase;}.template-card strong{font-size:1.15rem;line-height:1.22;}.home-template{background:linear-gradient(180deg,transparent 0 24%,rgba(25,79,216,0.85) 24% 47%,transparent 47%),#eef4ff;}.article-template{background:linear-gradient(90deg,transparent 0 68%,rgba(11,125,130,0.16) 68%),#fbfcfd;}.service-template{background:linear-gradient(180deg,rgba(241,184,45,0.3),transparent 46%),#ffffff;}.about-template{background:linear-gradient(135deg,rgba(228,95,79,0.22),transparent 42%),#f3f7f5;}.component-system{border-radius:var(--radius);background:var(--panel);padding-left:28px;padding-right:28px;}.component-board{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;}.component-board article,.component-board figure{margin:0;border:1px solid var(--line);border-radius:var(--radius);background:var(--white);padding:18px;}.component-board article>span,.component-board figure>span{display:block;color:var(--teal);font-size:0.76rem;font-weight:800;margin-bottom:14px;text-transform:uppercase;}.real-components figure{padding:0;overflow:hidden;}.real-components figure>span{padding:18px 18px 0;}.real-components img{display:block;width:calc(100% - 36px);height:330px;cursor:zoom-in;object-fit:contain;object-position:top center;margin:14px 18px 18px;}.lightbox{position:fixed;inset:0;z-index:100;display:none;grid-template-rows:auto minmax(0,1fr);gap:14px;background:rgba(14,17,22,0.9);padding:18px;}.lightbox.is-open{display:grid;}.lightbox-header{display:flex;align-items:center;justify-content:space-between;gap:16px;color:var(--white);}.lightbox-title{color:rgba(255,255,255,0.82);font-size:0.94rem;margin:0;}.lightbox-close{display:inline-grid;width:42px;height:42px;place-items:center;border:1px solid rgba(255,255,255,0.22);border-radius:6px;background:rgba(255,255,255,0.08);color:var(--white);cursor:pointer;font-size:1.4rem;line-height:1;}.lightbox-close:hover,.lightbox-close:focus-visible{background:rgba(255,255,255,0.16);outline:3px solid var(--teal);outline-offset:3px;}.lightbox-stage{display:grid;min-height:0;align-items:start;justify-items:center;overflow:auto;}.lightbox-image{display:block;max-width:100%;width:auto;max-height:none;height:auto;border-radius:6px;background:var(--white);box-shadow:0 24px 80px rgba(0,0,0,0.34);}@media (max-width:720px){.lightbox{padding:12px;}.lightbox-image{max-width:100%;}}.component-rows{min-height:190px;border-radius:6px;margin-bottom:14px;}.footer-module{background:linear-gradient(180deg,#3264c5 0 30%,#073796 30%),#073796;}.kpi-module{background:linear-gradient(90deg,#ffffff 0 28%,#f7c000 28% 42%,#3264c5 42% 72%,#b9cff9 72%),#ffffff;}.contact-module{background:linear-gradient(180deg,#f8fbff 0 42%,#fff1c7 42% 72%,#0d43a5 72%),#f8fbff;}.social-module{background:linear-gradient(90deg,rgba(255,255,255,0.7) 0 18%,transparent 18% 28%,rgba(255,255,255,0.9) 28% 48%,transparent 48% 62%,rgba(255,255,255,0.55) 62%),#275dbf;}.next-project{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;border-top:1px solid var(--line);}.next-card{display:grid;min-height:190px;align-content:end;gap:12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);padding:26px;position:relative;}.next-card::after{content:"→";position:absolute;right:24px;top:22px;color:var(--muted);font-size:1.6rem;}.next-card strong{color:var(--ink);font-size:clamp(1.6rem,3vw,2.6rem);line-height:1.05;}.next-card em{max-width:440px;color:var(--muted);font-style:normal;}.next-card:hover,.next-card:focus-visible{box-shadow:var(--shadow);outline:3px solid var(--teal);outline-offset:3px;}.contact-next{background:var(--ink);}.contact-next strong,.contact-next em,.contact-next .eyebrow{color:var(--white);}.contact-next em{color:rgba(255,255,255,0.72);}:root[data-theme="dark"] .contact-next{background:#f6f8fb;}:root[data-theme="dark"] .contact-next strong,:root[data-theme="dark"] .contact-next .eyebrow{color:#0f141c;}:root[data-theme="dark"] .contact-next em{color:rgba(15,20,28,0.66);}@media (max-width:980px){.hero,.split,.case-hero,.sas-overview,.two-column,.contact{grid-template-columns:1fr;}.hero{min-height:auto;padding-top:46px;}.hero-copy{max-width:760px;}.hero-visual{max-width:620px;padding-bottom:0;}.sas-overview-image{justify-self:start;width:min(100%,540px);}.sas-bento-grid{grid-template-columns:repeat(2,minmax(0,1fr));}.soma-phone-grid{grid-template-columns:repeat(2,minmax(0,1fr));}.molinos-desktop-grid,.molinos-responsive-grid{grid-template-columns:repeat(2,minmax(0,1fr));}.molinos-account-card{grid-column:auto;}.sas-bento-card,.sas-bento-tall,.sas-bento-wide{grid-column:auto;grid-row:auto;}.compact-preview{position:static;width:100%;margin-top:14px;}.project-grid,.timeline,.template-grid,.next-project{grid-template-columns:repeat(2,minmax(0,1fr));}.process-list{grid-template-columns:repeat(2,minmax(0,1fr));}.process-list li::after{display:none;}.contact-actions{margin-top:0;}}@media (max-width:720px){.site-header{align-items:stretch;flex-direction:column;gap:10px;top:16px;left:12px;margin:0;transform:none;width:min(calc(100vw - 24px),366px);}main{padding-top:214px;}.site-header-actions{align-items:stretch;flex-direction:column;gap:8px;width:100%;}.site-nav{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:4px;width:100%;}.site-nav a{font-size:0.82rem;padding:8px 4px;text-align:center;}.utility-controls{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;width:100%;}.utility-toggle{width:100%;padding-left:8px;padding-right:8px;}.header-cta{min-height:40px;width:100%;}.section{margin-left:12px;margin-right:auto;width:min(calc(100vw - 24px),366px);padding:48px 0;}.section[id]{scroll-margin-top:230px;}h1{font-size:clamp(2.45rem,12vw,3.55rem);line-height:1;}.hero h1{font-size:clamp(1.85rem,9vw,2.65rem);}.hero{gap:28px;padding-top:34px;}.hero-text{margin-top:18px;}.screen-grid,.focus-grid,.contribution-grid,.project-grid,.timeline,.template-grid,.component-board,.image-grid-2,.responsive-showcase,.sas-bento-grid,.soma-phone-grid,.molinos-desktop-grid,.molinos-responsive-grid,.process-list,.up-cards,.highlight-grid,.next-project{grid-template-columns:1fr;}.highlight-grid{gap:18px;}.contact-card-split{grid-template-columns:1fr;}.contact-card-small{min-height:auto;}.process-list li:not(:last-child)::after{content:"↓";top:auto;right:20px;bottom:-16px;display:grid;}.contact-card,.next-card{padding:20px;}.project-card.featured{grid-column:auto;}.project-visual{height:230px;}.portrait-card,.portrait-card img{height:360px;}.contact{padding:26px;}.site-footer{flex-direction:column;gap:8px;margin-left:12px;margin-right:auto;width:min(calc(100vw - 24px),366px);}.case-hero{padding-top:42px;}.up-showcase{min-height:520px;}.case-image.tall,.sas-bento-card,.sas-bento-tall,.sas-bento-wide,.soma-phone-card,.phone-shot,.tablet-shot,.desktop-shot{height:560px;}.molinos-screen-card,.molinos-screen-wide,.molinos-phone-card,.molinos-account-card{height:auto;grid-template-rows:320px auto;}.sas-bento-card img,.sas-bento-tall img,.sas-bento-wide img,.soma-phone-card img,.molinos-screen-card img,.molinos-phone-card img{min-height:0;}.real-components img{height:260px;}.up-hero-area{min-height:210px;padding:24px;}}@media (max-width:900px){.site-header{align-items:center;flex-direction:row;flex-wrap:nowrap;gap:10px;top:12px;left:12px;width:calc(100vw - 24px);max-width:none;padding-right:58px;transform:none;}main{padding-top:92px;}.brand{flex:1 1 auto;min-width:0;}.brand span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}.menu-toggle{position:absolute;top:10px;right:10px;display:inline-grid !important;}.site-header-actions{position:absolute;top:calc(100% + 8px);right:0;left:0;display:none;align-items:stretch;flex-direction:column;gap:10px;width:100%;padding:12px;border:1px solid rgba(223,228,234,0.92);border-radius:var(--radius);background:rgba(255,255,255,0.96);box-shadow:0 18px 44px rgba(24,27,34,0.12);backdrop-filter:blur(18px);}:root[data-theme="dark"] .site-header-actions{background:rgba(15,20,28,0.96);box-shadow:0 18px 44px rgba(0,0,0,0.28);}.site-header.is-menu-open .site-header-actions{display:flex;}.site-nav{display:grid;grid-template-columns:1fr;gap:4px;width:100%;}.site-nav a{font-size:0.92rem;padding:10px 12px;text-align:left;}.header-cta{width:100%;}.utility-controls{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;width:100%;}.utility-toggle{width:100%;}.section[id]{scroll-margin-top:116px;}}