:root{
  --bg:#f3eadc;
  --paper:#fffaf1;
  --paper-2:#fbf1e3;
  --ink:#2b241f;
  --muted:#7b6b5f;
  --line:rgba(75,55,42,.16);
  --shadow:0 16px 40px rgba(49,35,25,.12);
  --radius:24px;
  --gap:14px;
  --accent:#8f4b43;
  --accent-2:#b97b60;
  --safe-top:env(safe-area-inset-top, 0px);
  --safe-bottom:env(safe-area-inset-bottom, 0px);
  color-scheme:light;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--bg);}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 18% 8%, rgba(255,255,255,.82), transparent 34rem),
    radial-gradient(circle at 85% 14%, rgba(194,126,98,.16), transparent 28rem),
    linear-gradient(180deg, #f6eddf 0%, #efe2d0 100%);
  min-height:100vh;
}
a{color:inherit;text-decoration:none}
button,input{font:inherit}
button{cursor:pointer}
img{max-width:100%;display:block}
:focus-visible{outline:3px solid rgba(125,73,58,.55); outline-offset:3px; border-radius:14px;}
.site-shell{width:min(1120px,100%);margin:0 auto;padding:18px 14px calc(34px + var(--safe-bottom));}
.site-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:4px 0 16px;}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:-.02em;}
.brand-mark{width:38px;height:38px;border-radius:14px;background:var(--ink);color:var(--paper);display:grid;place-items:center;box-shadow:var(--shadow)}
.top-link{min-height:42px;padding:10px 14px;border:1px solid var(--line);border-radius:999px;background:rgba(255,250,241,.65);color:var(--muted);font-weight:700;}
.hero{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:32px;background:linear-gradient(135deg,#fff8ec 0%,#f4deca 100%);box-shadow:var(--shadow);padding:24px;margin-bottom:18px;}
.hero:before,.hero:after{content:"";position:absolute;border-radius:999px;filter:blur(.2px);pointer-events:none;}
.hero:before{width:190px;height:190px;right:-62px;top:-52px;background:radial-gradient(circle,rgba(143,75,67,.22),transparent 67%)}
.hero:after{width:260px;height:95px;right:18px;bottom:16px;background:linear-gradient(110deg,rgba(255,255,255,.62),rgba(255,255,255,.12));transform:rotate(-8deg);border:1px solid rgba(255,255,255,.42)}
.hero-kicker{position:relative;z-index:1;color:var(--accent);font-weight:900;letter-spacing:.08em;text-transform:uppercase;font-size:.76rem;margin-bottom:8px}
.hero h1{position:relative;z-index:1;margin:0;font-size:clamp(2rem,7.8vw,4.9rem);line-height:.95;letter-spacing:-.075em;max-width:10ch;}
.hero p{position:relative;z-index:1;margin:12px 0 0;color:var(--muted);font-size:clamp(1rem,3.2vw,1.18rem);line-height:1.45;max-width:38rem;}
.hero-art{position:absolute;right:18px;bottom:18px;width:min(38vw,360px);height:160px;opacity:.76;pointer-events:none;}
.hero-art i{position:absolute;display:block;border-radius:18px;background:rgba(255,250,241,.75);border:1px solid rgba(95,64,48,.13);box-shadow:0 10px 30px rgba(59,36,22,.08)}
.hero-art i:nth-child(1){width:44%;height:58%;left:2%;bottom:10%;transform:rotate(-9deg)}
.hero-art i:nth-child(2){width:38%;height:70%;left:31%;bottom:2%;transform:rotate(5deg)}
.hero-art i:nth-child(3){width:34%;height:50%;right:2%;bottom:22%;transform:rotate(-2deg)}
.hero-art i:after{content:"";position:absolute;inset:12px;border-radius:14px;background:linear-gradient(135deg,rgba(143,75,67,.18),rgba(132,117,77,.14));}
.hero.compact{padding:18px 18px 16px;border-radius:28px;min-height:148px;}
.hero.compact h1{font-size:clamp(2rem,7vw,3.8rem);max-width:11ch;}
.hero.compact .hero-art{height:118px;opacity:.48;}
.cards-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--gap);}
.home-card{min-height:144px;border:1px solid var(--line);border-radius:28px;background:rgba(255,250,241,.78);padding:16px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 8px 24px rgba(60,40,24,.07);transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;}
.home-card:hover{transform:translateY(-2px);box-shadow:0 18px 42px rgba(60,40,24,.13);border-color:rgba(143,75,67,.25)}
.card-icon{width:42px;height:42px;border-radius:16px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;display:grid;place-items:center;font-weight:900;}
.home-card h2{margin:12px 0 6px;font-size:1.32rem;letter-spacing:-.035em;}
.home-card p{margin:0;color:var(--muted);font-size:.93rem;line-height:1.35;}
.card-count{font-size:.78rem;color:var(--muted);font-weight:800;letter-spacing:.03em;text-transform:uppercase;}
.ghost-row{margin:16px 0 8px;display:flex;gap:10px;flex-wrap:wrap;}
.ghost-pill{min-height:42px;padding:10px 13px;border:1px dashed rgba(75,55,42,.24);border-radius:999px;background:rgba(255,250,241,.46);color:var(--muted);font-weight:800;}
.section-note{margin:18px 0 0;padding:16px;border:1px solid var(--line);border-radius:22px;background:rgba(255,250,241,.56);color:var(--muted);line-height:1.45;}
.person-switcher{display:flex;gap:8px;overflow-x:auto;padding:4px 0 13px;margin:-4px 0 0;scrollbar-width:none;}
.person-switcher::-webkit-scrollbar{display:none}.chip{white-space:nowrap;min-height:42px;padding:10px 14px;border-radius:999px;border:1px solid var(--line);background:rgba(255,250,241,.72);color:var(--muted);font-weight:800;}.chip[aria-current="page"],.chip.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.timeline-nav{position:sticky;top:0;z-index:9;margin:0 -14px 18px;padding:10px 14px 12px;background:linear-gradient(180deg,rgba(243,234,220,.96),rgba(243,234,220,.84));backdrop-filter:blur(16px);border-bottom:1px solid rgba(75,55,42,.10);}
.year-scroller{display:flex;gap:9px;overflow-x:auto;scroll-snap-type:x proximity;scroll-padding:14px;scrollbar-width:none;}
.year-scroller::-webkit-scrollbar{display:none}.year-chip{scroll-snap-align:start;min-width:70px;min-height:48px;border:1px solid var(--line);border-radius:18px;background:rgba(255,250,241,.8);display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:900;color:var(--ink);}.year-chip small{display:block;color:var(--muted);font-weight:800;font-size:.68rem;margin-top:2px}.year-chip.active{background:var(--accent);border-color:var(--accent);color:#fff}.year-chip.active small{color:rgba(255,255,255,.82)}
.timeline-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:8px 0 0;color:var(--muted);font-weight:800;font-size:.82rem;}
.timeline-layout{display:grid;grid-template-columns:minmax(0,1fr);gap:16px;}
.timeline-year{scroll-margin-top:92px;margin-bottom:30px;}
.year-heading{display:flex;align-items:end;justify-content:space-between;gap:12px;margin:18px 0 10px;border-bottom:1px solid var(--line);padding-bottom:9px;}
.year-heading h2{font-size:clamp(2.1rem,10vw,4.2rem);letter-spacing:-.08em;line-height:.9;margin:0;}.year-heading span{color:var(--muted);font-weight:900;}
.month-block{margin:18px 0 22px;}.month-title{display:flex;align-items:center;gap:10px;margin:0 0 10px;color:var(--muted);font-weight:900;text-transform:uppercase;letter-spacing:.07em;font-size:.74rem;}.month-title:after{content:"";height:1px;flex:1;background:var(--line);}
.photo-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:11px;}.photo-card{display:block;border:1px solid var(--line);border-radius:19px;background:rgba(255,250,241,.72);overflow:hidden;box-shadow:0 8px 20px rgba(50,35,23,.07);}.photo-thumb{aspect-ratio:1/1;background:#eadcca;overflow:hidden;}.photo-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .24s ease;}.photo-card:hover img{transform:scale(1.035)}.photo-caption{min-height:46px;padding:8px 10px;display:flex;align-items:center;justify-content:space-between;gap:6px;}.photo-caption strong{font-size:.82rem;line-height:1.1}.photo-caption span{font-size:.72rem;color:var(--muted);font-weight:800;}.person-badge{display:inline-flex;align-items:center;gap:4px;min-height:24px;padding:4px 7px;border-radius:999px;background:rgba(143,75,67,.12);color:var(--accent);font-weight:900;font-size:.7rem;margin-bottom:4px;}
.load-more-wrap{text-align:center;margin:24px 0 46px}.load-more{min-height:50px;padding:12px 20px;border:0;border-radius:999px;background:var(--ink);color:var(--paper);font-weight:900;box-shadow:var(--shadow)}.status{padding:16px;border:1px solid var(--line);border-radius:22px;background:rgba(255,250,241,.62);color:var(--muted);line-height:1.4;}
.desktop-rail{display:none}.viewer{width:min(100vw,980px);height:min(100dvh,820px);padding:0;border:0;border-radius:0;background:#1d1714;color:#fff;max-width:none;max-height:none;}.viewer::backdrop{background:rgba(15,10,7,.78);backdrop-filter:blur(8px)}.viewer-shell{height:100%;display:grid;grid-template-rows:auto 1fr;padding:calc(10px + var(--safe-top)) 10px calc(12px + var(--safe-bottom));}.viewer-bar{display:flex;align-items:center;gap:10px;justify-content:space-between;min-height:48px}.viewer-title{font-weight:900;line-height:1.15;}.viewer-actions{display:flex;gap:8px}.viewer-actions a,.viewer-actions button{min-height:42px;border-radius:999px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.1);color:#fff;padding:9px 12px;font-weight:900}.viewer-stage{min-height:0;display:grid;place-items:center}.viewer-stage img{max-width:100%;max-height:100%;object-fit:contain;border-radius:12px;background:#000}.no-scroll{overflow:hidden}.empty{padding:18px;border:1px dashed var(--line);border-radius:22px;color:var(--muted);background:rgba(255,250,241,.42)}
.footer{margin-top:34px;color:var(--muted);font-size:.86rem;line-height:1.4;text-align:center;}
.accent-rose{--accent:#9f6060;--accent-2:#c18d80}.accent-olive{--accent:#6f7650;--accent-2:#a5a673}.accent-lilac{--accent:#7b6a91;--accent-2:#b49ac1}.accent-wine{--accent:#8b4553;--accent-2:#bb7b7c}.accent-graphite{--accent:#4e5453;--accent-2:#8b8c84}.accent-all{--accent:#8f4b43;--accent-2:#b97b60}
@media (min-width:720px){.site-shell{padding:24px 24px 54px}.cards-grid{grid-template-columns:repeat(3,minmax(0,1fr));}.home-card{min-height:178px;padding:20px}.photo-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.hero{padding:40px}.hero.compact{padding:28px 32px}.timeline-nav{margin:0 -24px 22px;padding-left:24px;padding-right:24px}.year-chip{min-width:86px}.viewer{border-radius:28px;height:min(92dvh,840px);}.viewer-shell{padding:14px}.viewer-stage img{border-radius:18px}}
@media (min-width:1040px){.timeline-layout{grid-template-columns:minmax(0,1fr) 88px}.desktop-rail{display:block;position:sticky;top:86px;align-self:start}.desktop-rail-inner{display:flex;flex-direction:column-reverse;gap:8px;align-items:stretch}.rail-year{min-height:42px;border:1px solid var(--line);background:rgba(255,250,241,.72);border-radius:14px;color:var(--muted);font-weight:900}.rail-year.active{background:var(--accent);color:white;border-color:var(--accent)}}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}

/* Home page with generated crystal villa artwork */
.home-page body,
body.home-page{
  background:
    radial-gradient(circle at 20% 0%, rgba(255,255,255,.9), transparent 30rem),
    linear-gradient(180deg, #f6eddf 0%, #ede0ce 100%);
}
.home-shell{max-width:1160px;}
.home-header{margin-bottom:12px;}
.home-hero{
  position:relative;
  min-height:min(72vh,720px);
  border:1px solid var(--line);
  border-radius:34px;
  overflow:hidden;
  box-shadow:var(--shadow);
  background:#dac4a8;
  isolation:isolate;
}
.home-hero-image{position:absolute;inset:0;z-index:0;}
.home-hero-image img{width:100%;height:100%;object-fit:cover;object-position:center center;}
.home-hero:after{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(180deg, rgba(26,20,15,.12) 0%, rgba(26,20,15,.18) 42%, rgba(26,20,15,.58) 100%),
    radial-gradient(circle at 18% 20%, rgba(255,255,255,.55), transparent 18rem);
  pointer-events:none;
}
.home-hero-content{
  position:absolute;
  z-index:2;
  left:clamp(18px,5vw,52px);
  right:clamp(18px,5vw,52px);
  bottom:clamp(18px,6vw,56px);
  max-width:720px;
  color:white;
  text-shadow:0 2px 24px rgba(0,0,0,.42);
}
.home-hero-content .hero-kicker{color:rgba(255,255,255,.88);}
.home-hero-content h1{
  margin:0;
  font-size:clamp(3.2rem,18vw,8.6rem);
  line-height:.82;
  letter-spacing:-.09em;
}
.home-hero-content p{
  margin:16px 0 0;
  max-width:32rem;
  font-size:clamp(1.04rem,3.5vw,1.42rem);
  line-height:1.34;
  font-weight:750;
  color:rgba(255,255,255,.9);
}
.home-cards{margin-top:16px;}
.home-ghost-row{margin-bottom:0;}
@media (max-width:520px){
  .home-hero{min-height:62vh;border-radius:28px;}
  .home-hero-image img{object-position:center top;}
  .home-hero-content h1{font-size:clamp(3rem,19vw,5.3rem);}
  .home-hero-content p{font-size:1rem;max-width:22rem;}
}
