*,*::before,*::after{box-sizing:border-box}*{margin:0}html,body{height:100%}
img,picture,svg,video,canvas{max-width:100%;display:block}input,button,textarea,select{font:inherit;color:inherit}
:where(a){color:inherit;text-underline-offset:.2em}:where(a):hover{text-decoration-thickness:2px}

:root {
  --color-bg: #fff;
  --color-text: #0b0d10;
  --color-muted: #5a6570;
  --color-primary: #d4a017;
  --color-surface: #fdfaf5;
  --color-border: #e2d4b8;
  --radius-sm: 8px;
  --radius-lg: 16px;
  --space-1: .25rem;
  --space-2: .5rem;
  --space-3: .75rem;
  --space-4: 1rem;
  --space-5: 1.5rem;
  --space-6: 2rem;
  --space-7: 3rem;
  --font-sans: system-ui, -apple-system, Segoe UI, Roboto, Cantarell, Noto Sans, Ubuntu, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  --step--1: clamp(.88rem, .86rem + .10vw, .94rem);
  --step-0: 1rem;
  --step-1: clamp(1.13rem, 1.07rem + .30vw, 1.25rem);
  --step-2: clamp(1.27rem, 1.18rem + .60vw, 1.56rem);
  --step-3: clamp(1.44rem, 1.29rem + 1.00vw, 1.95rem);
  --step-4: clamp(1.62rem, 1.38rem + 1.50vw, 2.44rem);
}

@media (prefers-color-scheme: dark){
:root {
  --color-bg: #fff;
  --color-text: #0b0d10;
  --color-muted: #5a6570;
  --color-primary: #d4a017;
  --color-surface: #fdfaf5;
  --color-border: #e2d4b8;
  --radius-sm: 8px;
  --radius-lg: 16px;
  --space-1: .25rem;
  --space-2: .5rem;
  --space-3: .75rem;
  --space-4: 1rem;
  --space-5: 1.5rem;
  --space-6: 2rem;
  --space-7: 3rem;
  --font-sans: system-ui, -apple-system, Segoe UI, Roboto, Cantarell, Noto Sans, Ubuntu, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  --step--1: clamp(.88rem, .86rem + .10vw, .94rem);
  --step-0: 1rem;
  --step-1: clamp(1.13rem, 1.07rem + .30vw, 1.25rem);
  --step-2: clamp(1.27rem, 1.18rem + .60vw, 1.56rem);
  --step-3: clamp(1.44rem, 1.29rem + 1.00vw, 1.95rem);
  --step-4: clamp(1.62rem, 1.38rem + 1.50vw, 2.44rem);
}
}
html{color-scheme:light dark}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);line-height:1.6}
.container{width:min(1100px,100% - 2rem);margin-inline:auto}.section{padding-block:var(--space-7)}
.site-header{position:sticky;top:0;z-index:10;background:color-mix(in oklab,var(--color-bg),transparent 5%);border-bottom:1px solid var(--color-border);backdrop-filter:blur(6px)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;padding-block:var(--space-3)}
.site-logo{display:inline-flex;align-items:center;gap:var(--space-3);font-weight:700;text-decoration:none}
.site-logo svg circle{fill:var(--color-primary)}.site-nav ul{list-style:none;display:flex;gap:var(--space-4);padding:0;margin:0}
.site-nav a{text-decoration:none;padding:.25rem .5rem;border-radius:var(--radius-sm)}.site-nav a[aria-current="page"]{background:var(--color-surface)}
.nav-toggle{display:none;border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--radius-sm);padding:.4rem .6rem}
@media (max-width:720px){.nav-toggle{display:inline-flex}.site-nav[hidden]{display:none!important}.site-nav{position:absolute;inset-inline:0;top:56px;background:var(--color-bg);border-bottom:1px solid var(--color-border)}.site-nav ul{flex-direction:column;padding:var(--space-4);gap:var(--space-3)}}

.hero {
  padding-block: calc(var(--space-7) + 1rem);
  background: linear-gradient(to bottom, #fff5dd 0%, #ffffff 60%);
}

.hero h1{font-size:var(--step-4);line-height:1.1}.hero p{max-width:60ch;margin-top:var(--space-3);font-size:var(--step-1);color:var(--color-muted)}
.actions{display:flex;gap:var(--space-3);margin-top:var(--space-4)}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-4);list-style:none;padding:0;margin-top:var(--space-5)}
.card{border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-5)}.card h3{font-size:var(--step-1);margin-bottom:var(--space-2)}
.site-footer{border-top:1px solid var(--color-border);padding-block:var(--space-5)}label{display:grid;gap:.4rem}
input,textarea{width:100%;padding:.6rem .8rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:inherit}
button,.btn{display:inline-flex;align-items:center;justify-content:center;border:1px solid color-mix(in oklab,var(--color-primary),#000 10%);background:var(--color-primary);color:#fff;text-decoration:none;border-radius:var(--radius-sm);padding:.6rem 1rem;font-weight:600;cursor:pointer}
.btn-ghost{background:transparent;border-color:var(--color-border);color:inherit}.flow>*+*{margin-top:var(--space-3)}.stack>*+*{margin-top:var(--space-3)}
.skip-link{position:absolute;left:-9999px;top:auto}.skip-link:focus{left:1rem;top:1rem;background:var(--color-surface);padding:.5rem .75rem;border-radius:var(--radius-sm);outline:2px solid var(--color-primary)}
.notice{margin-top:var(--space-4);padding:var(--space-3);border:1px dashed var(--color-border);border-radius:var(--radius-sm)}
@media (prefers-reduced-motion:reduce){*{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}
@media print{.nav-toggle,.site-nav,.actions,.btn{display:none!important}body{color:#000}}




/* === Masonry FIX: no shift, correct caption target === */
.masonry{column-gap:var(--space-4)}
.masonry figure{position:relative;overflow:hidden;display:block;break-inside:avoid;margin:0 0 var(--space-4)}
.masonry img{display:block;width:100%;height:auto;transform:none !important;transition:none !important}
.masonry figcaption{
  position:absolute;left:0;right:0;bottom:0;
  padding:.6rem .8rem;background:rgba(0,0,0,.65);color:#fff;
  opacity:0;transform:translateY(4px);
  transition:opacity .18s ease, transform .18s ease;
  pointer-events:none
}
.masonry figure:hover figcaption,
.masonry figure:focus-within figcaption{opacity:1;transform:translateY(0)}


/* === Simple grid layout for portfolio === */
.grid-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-4);
}
.grid-gallery figure {
  margin: 0;
  border-radius: var(--radius-sm);
  overflow: hidden;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
}
.grid-gallery img {
  display: block;
  width: 100%;
  height: auto;
}
.grid-gallery figcaption {
  padding: .6rem .8rem;
  font-size: var(--step--1);
  color: var(--color-muted);
  background: var(--color-surface);
}

/* Modern Card Look for Grid Gallery */
.grid-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-4);
  margin-top: var(--space-5);
}

.grid-gallery figure {
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--color-border);
  background: #fff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.grid-gallery figure:hover {
  transform: translateY(-3px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.grid-gallery img {
  width: 100%;
  display: block;
  height: auto;
  border-bottom: 1px solid var(--color-border);
}

.grid-gallery figcaption {
  font-size: var(--step--1);
  color: var(--color-muted);
  text-align: center;
  padding: 0.75rem;
}

/* === Hero grid with right-justified aside (320px) === */
.hero .container.hero-grid {
  display: grid;
  grid-template-columns: 1fr 320px;
  align-items: center;
  gap: var(--space-7, 3rem);
}
.hero-content { min-width: 0; }
.hero-aside { justify-self: end; }
.hero-aside img { width: 320px; height: auto; display: block; filter: drop-shadow(0 0 10px rgba(0,0,0,.18)); }

@media (max-width: 900px) {
  .hero .container.hero-grid { grid-template-columns: 1fr; }
  .hero-aside { justify-self: start; }
  .hero-aside img { width: min(72vw, 520px); }
}

/* Collapsible header (all sizes) */
.nav-toggle { display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  background: transparent; border: 1px solid var(--color-border); color: inherit;
  border-radius: var(--radius-lg); padding: .35rem .5rem; cursor: pointer;
  transition: background .15s ease, border-color .15s ease, transform .15s ease;
}
.nav-toggle:hover { background: var(--color-surface); }
.nav-toggle .icon { transition: transform .15s ease; }

/* Hide nav by default; show when header is open */
.site-header[data-nav-open="false"] .site-nav { display: none !important; }
.site-header[data-nav-open="true"]  .site-nav { display: block !important; }

/* Rotate chevron when open */
.site-header[data-nav-open="true"] .nav-toggle .icon { transform: rotate(180deg); }

/* Keep header above content */
.site-header { z-index: 1000; }

@media (max-width: 820px){
  /* Collapsible layout tweaks */
  .site-nav ul { display: flex; flex-direction: column; gap: var(--space-2); padding-block: var(--space-3); }
}


/* === Revert: desktop shows nav, toggle hidden === */
@media (min-width: 821px){
  .nav-toggle { display: none !important; }
  .site-nav { display: block !important; }
  /* Ensure it's visible regardless of data-nav-open on desktop */
  .site-header[data-nav-open="false"] .site-nav { display: block !important; }
}
