@import "https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&family=Inter:wght@300;400;500;600&display=swap";:root{--bg:#f7f5f0;--surface:#fff;--surface2:#f2ede6;--header-bg:#1c2b3a;--header-text:#e8e2d8;--accent:#b07d5a;--accent-dark:#8f6040;--accent-light:#d4a882;--text:#2a2a2a;--text-muted:#6b6460;--border:#e0dad2;--font-heading:"Playfair Display", Georgia, "Times New Roman", serif;--font-body:"Inter", system-ui, -apple-system, sans-serif;--radius:8px;--radius-lg:14px;--shadow-sm:0 1px 4px #00000012;--shadow-md:0 4px 14px #0000001a;--shadow-lg:0 8px 28px #00000021;--max-w:860px;--header-h:68px;--ease:.22s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px;overflow-x:hidden}body{background:var(--bg);font-family:var(--font-body);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-weight:400;line-height:1.75;overflow-x:hidden}img{max-width:100%;height:auto;display:block}a{color:var(--accent);transition:color var(--ease);text-decoration:none}a:hover{color:var(--accent-dark)}p{margin-bottom:1rem}strong,b{font-weight:600}em,i{font-style:italic}u{text-underline-offset:3px;text-decoration:underline}h1,h2,h3,h4{font-family:var(--font-heading);color:var(--text);font-weight:700;line-height:1.3}h1{margin-bottom:1rem;font-size:clamp(1.6rem,4vw,2.1rem)}h2{margin-bottom:.875rem;font-size:clamp(1.3rem,3vw,1.7rem)}h3{margin-bottom:.625rem;font-size:1.15rem}.site-wrapper{flex-direction:column;min-height:100vh;display:flex}.site-header{z-index:200;background:var(--header-bg);position:sticky;top:0;box-shadow:0 2px 16px #00000040}.header-bar{max-width:var(--max-w);height:var(--header-h);justify-content:space-between;align-items:center;gap:1rem;margin:0 auto;padding:0 1.5rem;display:flex}.site-identity{flex:1;align-items:center;gap:.875rem;min-width:0;text-decoration:none;display:flex}.site-identity img{object-fit:cover;border:2px solid var(--accent-light);border-radius:50%;flex-shrink:0;width:44px;height:44px}.site-title{font-family:var(--font-heading);color:var(--header-text);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.95rem;font-weight:600;line-height:1.35;display:-webkit-box;overflow:hidden}.main-nav{flex-shrink:0;align-items:center;gap:.125rem;display:flex}.main-nav a{border-radius:var(--radius);color:#e8e2d8a6;transition:background var(--ease), color var(--ease);white-space:nowrap;padding:.5rem .875rem;font-size:.875rem;font-weight:500}.main-nav a:hover{color:var(--header-text);background:#ffffff12}.main-nav a.active{background:var(--accent);color:#fff}.hamburger{color:#fff;cursor:pointer;border-radius:var(--radius);transition:background var(--ease);background:0 0;border:none;flex-shrink:0;padding:.5rem;display:none}.hamburger:hover{background:#ffffff14}.ham-lines{flex-direction:column;justify-content:center;gap:5px;width:22px;height:22px;display:flex}.ham-lines span{transform-origin:50%;background:#fff;border-radius:2px;height:2px;transition:transform .3s,opacity .3s,width .3s;display:block}.hamburger.open .ham-lines span:first-child{transform:translateY(7px)rotate(45deg)}.hamburger.open .ham-lines span:nth-child(2){opacity:0;width:0}.hamburger.open .ham-lines span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.mobile-nav{background:var(--header-bg);border-top:1px solid #ffffff12;flex-direction:column;gap:.25rem;padding:.75rem 1.5rem 1.25rem;display:none}.mobile-nav.open{display:flex}.mobile-nav a{border-radius:var(--radius);color:#e8e2d8a6;transition:background var(--ease), color var(--ease);padding:.75rem 1rem;font-size:1rem;font-weight:500;display:block}.mobile-nav a:hover,.mobile-nav a.active{background:var(--accent);color:#fff}.site-main{flex:1}.btn{border-radius:var(--radius);font-family:var(--font-body);cursor:pointer;transition:background var(--ease), color var(--ease), border-color var(--ease), box-shadow var(--ease);white-space:nowrap;border:1.5px solid #0000;justify-content:center;align-items:center;gap:.375rem;padding:.625rem 1.375rem;font-size:.9rem;font-weight:500;text-decoration:none;display:inline-flex}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-dark);border-color:var(--accent-dark);color:#fff;box-shadow:var(--shadow-md)}.btn-outline{color:var(--accent);border-color:var(--accent);background:0 0}.btn-outline:hover{background:var(--accent);color:#fff;box-shadow:var(--shadow-md)}.hero-slider{-webkit-user-select:none;user-select:none;background:#111;width:100%;position:relative;overflow:hidden}.slider-track{width:100%;position:relative}.slide-item{width:100%;display:none;position:absolute;inset:0}.slide-item.active{animation:.65s fadeIn;display:block;position:relative}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.slide-item img{object-fit:contain;object-position:center;background:#111;width:100%;height:auto;max-height:520px;display:block}.slide-overlay{pointer-events:none;background:linear-gradient(#0000 45%,#0006 100%);position:absolute;inset:0}.slider-controls{align-items:center;gap:.5rem;display:flex;position:absolute;bottom:1.25rem;left:50%;transform:translate(-50%)}.slider-dot{cursor:pointer;width:8px;height:8px;transition:background var(--ease), width var(--ease), border-radius var(--ease);background:#ffffff73;border:none;border-radius:50%;padding:0}.slider-dot.active{background:#fff;border-radius:4px;width:22px}.slider-arrow{color:#fff;cursor:pointer;width:44px;height:44px;transition:background var(--ease);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000061;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.5rem;line-height:1;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.slider-arrow:hover{background:#0000009e}.slider-arrow-prev{left:1rem}.slider-arrow-next{right:1rem}.breadcrumbs{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:.375rem;margin-bottom:1.5rem;font-size:.83rem;display:flex}.breadcrumbs a{color:var(--accent)}.breadcrumbs .sep{opacity:.5}.content-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);padding:2rem 2.25rem}.home-content{max-width:700px;margin:0 auto;padding:2.5rem 1.5rem 3rem}.home-cta{flex-wrap:wrap;justify-content:center;gap:.875rem;margin:2rem 0;display:flex}.intro-date{font-family:var(--font-heading);text-align:center;color:var(--text);margin:1.75rem 0 .75rem;font-size:1.4rem;font-weight:600}.intro-text{color:var(--text);text-align:center;margin-bottom:0;font-size:1.075rem;line-height:1.85}.hero-photo{text-align:center;margin:2.25rem auto}.hero-photo img{border-radius:var(--radius-lg);width:auto;max-width:100%;max-height:360px;box-shadow:var(--shadow-lg);margin:0 auto}.poem-card{background:var(--surface);border-left:4px solid var(--accent);border-radius:0 var(--radius-lg) var(--radius-lg) 0;box-shadow:var(--shadow-sm);border-top:1px solid var(--border);border-right:1px solid var(--border);border-bottom:1px solid var(--border);margin:2.25rem 0 0;padding:1.75rem 2rem 1.5rem}.poem-stanza{text-transform:uppercase;letter-spacing:.04em;color:var(--text);margin-bottom:1.25rem;font-size:.88rem;line-height:2.1}.poem-stanza:last-of-type{margin-bottom:.75rem}.poem-author{color:var(--text-muted);margin-top:1rem;font-size:.9rem;font-style:italic}.dag-page{max-width:var(--max-w);margin:0 auto;padding:2rem 1.5rem 3rem}.dag-title{font-family:var(--font-heading);text-align:center;color:var(--text);margin-bottom:.5rem;font-size:clamp(1.35rem,3.5vw,1.75rem)}.dag-divider{background:var(--accent);border-radius:2px;width:52px;height:3px;margin:.625rem auto 2rem}.dag-nav{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.875rem;margin:1.5rem 0;display:flex}.dag-nav .btn{max-width:260px;font-size:.85rem}.dag-nav .btn-prev{margin-right:auto}.dag-nav .btn-next{margin-left:auto}.diary-content{color:var(--text);font-size:1rem;line-height:1.9}.diary-content p{margin-bottom:1.1rem}.diary-content p:last-child{margin-bottom:0}.diary-content img{border-radius:var(--radius);max-width:100%;max-height:380px;box-shadow:var(--shadow-md);display:block;width:auto!important;height:auto!important;margin:1.75rem auto!important}.diary-content p>strong:first-child{font-family:var(--font-heading);color:var(--accent-dark);border-bottom:1px solid var(--border);margin-bottom:.5rem;padding-bottom:.1rem;font-size:1.05rem;display:block}.diary-content .rtecenter{text-align:center}.diary-content .rteright{text-align:right}.diary-content .rtejustify{text-align:justify}.diary-content em{font-style:italic}.foto-page{max-width:var(--max-w);margin:0 auto;padding:2rem 1.5rem 3rem}.page-title{font-family:var(--font-heading);text-align:center;color:var(--text);margin-bottom:.5rem;font-size:clamp(1.4rem,4vw,1.9rem)}.page-title-bar{background:var(--accent);border-radius:2px;width:52px;height:3px;margin:.625rem auto 2rem}.foto-gallery{grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:.75rem;margin-top:1rem;display:grid}.foto-thumb-btn{cursor:pointer;border-radius:var(--radius);aspect-ratio:1;transition:transform var(--ease), box-shadow var(--ease);background:0 0;border:none;padding:0;display:block;position:relative;overflow:hidden}.foto-thumb-btn:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.foto-thumb{object-fit:cover;width:100%;height:100%;transition:transform .35s;display:block}.foto-spinner{background:#f0f0f0;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.foto-spinner:after{content:"";border:3px solid #ccc;border-top-color:#9e0000;border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.foto-thumb-btn:hover .foto-thumb{transform:scale(1.07)}.lightbox-overlay{z-index:1000;background:#000000ed;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.lightbox-inner{justify-content:center;align-items:center;max-width:min(92vw,1100px);max-height:92vh;display:flex;position:relative}.lightbox-img{object-fit:contain;border-radius:var(--radius);max-width:min(88vw,1100px);max-height:85vh;box-shadow:0 0 80px #0009}.lightbox-close{color:#fff;cursor:pointer;width:40px;height:40px;transition:background var(--ease);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff21;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.3rem;display:flex;position:fixed;top:1.25rem;right:1.25rem}.lightbox-close:hover{background:#ffffff40}.lightbox-prev,.lightbox-next{color:#fff;cursor:pointer;width:50px;height:50px;transition:background var(--ease);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff21;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:2rem;display:flex;position:fixed;top:50%;transform:translateY(-50%)}.lightbox-prev:hover,.lightbox-next:hover{background:#ffffff40}.lightbox-prev{left:1rem}.lightbox-next{right:1rem}.lightbox-counter{color:#ffffffbf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;border-radius:20px;padding:.375rem 1rem;font-size:.85rem;position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%)}.site-footer{background:var(--header-bg);color:#e8e2d873;text-align:center;margin-top:2rem;padding:2rem 1.5rem;font-size:.85rem}.site-footer a{color:var(--accent-light)}.site-footer a:hover{color:var(--accent)}@media (width<=768px){.main-nav{display:none}.hamburger{display:flex}.slider-arrow{display:none}:root{--max-w:100%}.home-content{padding:1.75rem 1rem 2.5rem}.intro-text{font-size:1rem}.dag-page{padding:1.5rem 1rem 2.5rem}.dag-nav{flex-direction:column;align-items:stretch}.dag-nav .btn{text-align:center;max-width:100%;margin:0!important}.content-card{padding:1.25rem}.poem-card{padding:1.25rem 1.25rem 1rem}.foto-page{padding:1.5rem 1rem 2.5rem}.foto-gallery{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.5rem}}@media (width<=480px){:root{--header-h:58px}.site-identity img{width:36px;height:36px}.site-title{font-size:.82rem}.foto-gallery{grid-template-columns:repeat(3,1fr);gap:.375rem}.lightbox-prev{left:.5rem}.lightbox-next{right:.5rem}}
