@import"https://fonts.googleapis.com/css2?family=Permanent+Marker&family=Sora:wght@300;400;500;600;700&display=swap";:root{--bg: #f3efe7;--surface: #fcfaf7;--text: #1d1b18;--muted: #5b554d;--line: #d9d2c9;--accent: #0f5f4d;--accent-strong: #0a493b;--shadow: 0 20px 55px rgba(15, 95, 77, .14)}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:Sora,sans-serif;color:var(--text);background:radial-gradient(circle at 12% 8%,rgba(15,95,77,.18),transparent 34%),radial-gradient(circle at 88% 82%,rgba(217,164,95,.2),transparent 36%),var(--bg)}.page-shell{position:relative;max-width:980px;margin:0 auto;padding:3.5rem 1.2rem 2.5rem}.ambient{position:absolute;border-radius:999px;filter:blur(20px);z-index:-1;opacity:.45}.ambient-one{width:220px;height:220px;top:2rem;right:10%;background:#94aac459;animation:drift 8s ease-in-out infinite}.ambient-two{width:200px;height:200px;left:12%;bottom:2rem;background:#44a34966;animation:drift 9s ease-in-out infinite reverse}.hero,.contact{background:color-mix(in srgb,var(--surface) 85%,white 15%);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:2rem;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:rise .68s ease-out both}.contact{margin-top:1.4rem;animation-delay:.18s}.top-logo-wrap{display:flex;justify-content:center;margin:0 0 1.1rem;animation:rise .54s ease-out both}.hero-logo{display:block;width:min(340px,72vw);height:auto;margin:0}.eyebrow{margin:0 0 .6rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-size:.74rem}h1{margin:0;font-size:clamp(2rem,5vw,3.4rem);line-height:1.05;max-width:14ch}#site-title{font-family:Permanent Marker,Sora,sans-serif;font-size:clamp(2.2rem,5.6vw,3.9rem);line-height:1;letter-spacing:.01em;max-width:none;color:#111}.hero-copy{margin:1rem 0 1.5rem;max-width:58ch;color:var(--muted);line-height:1.6}.primary-cta{display:inline-block;text-decoration:none;background:var(--accent);color:#fff;padding:.8rem 1.2rem;border-radius:999px;font-weight:600;transition:transform .15s ease,background-color .15s ease}.primary-cta:hover{background:var(--accent-strong);transform:translateY(-2px)}h2{margin:0;font-size:clamp(1.45rem,3vw,2rem)}.contact p{color:var(--muted);line-height:1.6}.link-grid{list-style:none;margin:1.2rem 0 0;padding:0;display:grid;gap:.8rem}.link-grid a{display:grid;gap:.32rem;border:1px solid var(--line);border-radius:12px;text-decoration:none;color:inherit;padding:.9rem 1rem;background:#fff;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease,background-color .15s ease}.link-grid a:hover{border-color:var(--accent);background:color-mix(in srgb,#fff 88%,var(--accent) 12%);box-shadow:0 12px 28px #0f5f4d1f;transform:translate(4px)}.link-grid a:focus-visible{outline:3px solid color-mix(in srgb,var(--accent) 50%,white 50%);outline-offset:3px;border-color:var(--accent);background:color-mix(in srgb,#fff 88%,var(--accent) 12%);box-shadow:0 12px 28px #0f5f4d1f}.link-heading{display:inline-flex;align-items:center;gap:.7rem}.link-icon{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:999px;background:color-mix(in srgb,var(--accent) 14%,white 86%);color:var(--accent);transition:transform .15s ease,background-color .15s ease}.link-icon svg{width:1.1rem;height:1.1rem}.link-title{font-weight:600}.link-grid small{color:var(--muted);font-size:.83rem}.link-action{display:inline-flex;align-items:center;gap:.45rem;margin-top:.2rem;color:var(--accent);font-size:.84rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase}.link-grid a:hover .link-action span,.link-grid a:focus-visible .link-action span{transform:translate(3px)}.link-grid a:hover .link-icon,.link-grid a:focus-visible .link-icon{background:color-mix(in srgb,var(--accent) 22%,white 78%);transform:scale(1.05)}.link-action span{transition:transform .15s ease}.site-footer{margin-top:1rem;text-align:center;color:var(--muted);font-size:.84rem}.site-footer p{margin:0}.portfolio{background:color-mix(in srgb,var(--surface) 85%,white 15%);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:2rem;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:rise .68s ease-out both;animation-delay:.1s;margin-top:1.4rem}.portfolio h2{margin:0 0 1.2rem;font-family:Permanent Marker,Sora,sans-serif;font-size:clamp(1.2rem,2.5vw,1.55rem);color:var(--text)}.portfolio-loading{color:var(--muted);font-size:.9rem;padding:.5rem 0}.portfolio-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.portfolio-card{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:12px;overflow:hidden;text-decoration:none;color:inherit;background:#fff;height:100%;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.portfolio-card:hover,.portfolio-card:focus-visible{border-color:var(--accent);box-shadow:0 12px 28px #0f5f4d24;transform:translateY(-3px)}.portfolio-card:focus-visible{outline:3px solid color-mix(in srgb,var(--accent) 50%,white 50%);outline-offset:3px}.portfolio-thumb-wrap{aspect-ratio:1 / 1;overflow:hidden;background:var(--line)}.portfolio-thumb{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}.portfolio-card:hover .portfolio-thumb,.portfolio-card:focus-visible .portfolio-thumb{transform:scale(1.04)}.portfolio-info{padding:.9rem 1rem 1rem;display:flex;flex-direction:column;gap:.35rem;flex:1}.portfolio-card-title{font-weight:600;font-size:.95rem;line-height:1.3}.portfolio-card-desc{margin:0;font-size:.8rem;color:var(--muted);line-height:1.55;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1}.portfolio-meta{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;color:var(--accent);font-weight:600;margin-top:.3rem}.portfolio-meta svg{width:.9rem;height:.9rem}@media (max-width: 640px){.portfolio{padding:1.3rem}}@keyframes rise{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes drift{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@media (max-width: 640px){.page-shell{padding-top:2rem}.hero,.contact{padding:1.3rem}.ambient-one{top:-1.5rem;right:-.4rem}.ambient-two{left:-.2rem;bottom:-1.4rem}.hero-logo{width:min(290px,82vw)}.top-logo-wrap{margin-bottom:.8rem}}
