@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Lora:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Caveat:wght@400;700&display=swap");:root{--bg-color:#faf7f0;--bg-card:#f4efe6;--text-primary:#2c2a29;--text-secondary:#706b64;--accent-color:#d4af37;--accent-glow:rgba(212,175,55,.15);--border-color:#e2dac6;--shadow-color:rgba(44,42,41,.08);--canvas-bg:#faf7f0;--font-serif:"Lora",Georgia,serif;--font-sans:"Inter",system-ui,-apple-system,sans-serif;--font-handwritten:"Caveat",cursive;--transition-smooth:all 0.3s cubic-bezier(0.4,0,0.2,1)}[data-theme=dark]{--bg-color:#121110;--bg-card:#1c1a18;--text-primary:#faf7f0;--text-secondary:#a39d95;--accent-color:#e6c280;--accent-glow:hsla(39,67%,70%,.15);--border-color:#2f2c2a;--shadow-color:rgba(0,0,0,.4);--canvas-bg:#151413}*{box-sizing:border-box;margin:0;padding:0}body,html{background-color:var(--bg-color);background-image:radial-gradient(rgba(212,175,55,.04) 1px,transparent 0),radial-gradient(rgba(0,0,0,.01) 1px,transparent 0);background-size:32px 32px;background-position:0 0,16px 16px;color:var(--text-primary);font-family:var(--font-sans);min-height:100vh;scroll-behavior:smooth;transition:var(--transition-smooth)}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);font-weight:600;letter-spacing:-.01em}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-color)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent-color)}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.navbar{position:-webkit-sticky;position:sticky;top:0;z-index:100;background:hsla(42,50%,96%,.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);transition:var(--transition-smooth)}[data-theme=dark] .navbar{background:rgba(18,17,16,.85)}.navbar-inner{justify-content:space-between;height:70px}.navbar-inner,.navbar-logo{display:flex;align-items:center}.navbar-logo{font-family:var(--font-serif);font-size:1.5rem;font-weight:700;color:var(--text-primary);gap:.5rem}.navbar-links{display:flex;gap:2rem;list-style:none;font-size:.95rem;font-weight:500}.navbar-link{color:var(--text-secondary);transition:var(--transition-smooth);position:relative;padding:.25rem 0}.navbar-link.active,.navbar-link:hover{color:var(--text-primary)}.navbar-link.active:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:2px;background-color:var(--accent-color);border-radius:2px}.theme-toggle-btn{background:none;border:1px solid var(--border-color);padding:.5rem;border-radius:50%;cursor:pointer;color:var(--text-primary);display:flex;align-items:center;justify-content:center;transition:var(--transition-smooth)}.theme-toggle-btn:hover{background:var(--bg-card);border-color:var(--accent-color)}.hamburger-btn{display:none}@media (max-width:767px){.desktop-controls{display:none!important}.hamburger-btn,.mobile-actions-wrapper{display:flex!important}.navbar-links{position:fixed;top:70px;left:0;right:0;bottom:0;background:var(--bg-color);flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;font-size:1.4rem;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:90;border-top:1px solid var(--border-color);padding:2rem;margin:0}.navbar-links.open{transform:translateX(0)}.navbar-link.active:after{bottom:-5px;height:3px}.mobile-user-select{display:block!important}}.glass-panel{background:hsla(42,50%,96%,.6);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(212,175,55,.2);box-shadow:0 12px 40px var(--shadow-color);border-radius:20px;position:relative;overflow:hidden}[data-theme=dark] .glass-panel{background:rgba(20,19,18,.6);border:1px solid hsla(39,67%,70%,.15)}.glass-panel:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--border-color),var(--accent-color),var(--border-color))}.timeline-section{position:relative;padding:3rem 0}.timeline-line{position:absolute;left:30px;top:0;bottom:0;width:3px;background:linear-gradient(180deg,rgba(212,175,55,.1),rgba(212,175,55,.7) 30%,rgba(212,175,55,.7) 70%,rgba(212,175,55,.1));z-index:1}.timeline-year-header{position:-webkit-sticky;position:sticky;top:90px;z-index:10;display:inline-block;font-family:var(--font-serif);font-size:2.6rem;font-weight:700;color:var(--accent-color);background:var(--bg-color);padding:.5rem 2rem .5rem 0;margin-bottom:2.5rem;text-shadow:1px 1px 0 var(--bg-card);transition:var(--transition-smooth)}.timeline-item{position:relative;display:flex;margin-bottom:4rem;padding-left:70px;z-index:2}.timeline-dot{position:absolute;left:21px;top:14px;width:20px;height:20px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff 0,var(--accent-color) 60%,#a68020 100%);box-shadow:0 4px 10px rgba(0,0,0,.35);z-index:3;transition:var(--transition-smooth)}.timeline-item:hover .timeline-dot{transform:scale(1.3) translateY(-2px);box-shadow:0 8px 15px rgba(212,175,55,.4)}.timeline-card{width:100%;display:grid;grid-template-columns:1fr;grid-gap:2rem;gap:2rem;padding:2.25rem;background:#fff;background-image:linear-gradient(rgba(0,0,0,.015) 1px,transparent 0);background-size:100% 24px;border:1px solid var(--border-color);border-left:5px solid var(--accent-color);border-radius:16px;box-shadow:0 10px 30px var(--shadow-color);transition:var(--transition-smooth)}[data-theme=dark] .timeline-card{background:var(--bg-card);background-image:linear-gradient(hsla(0,0%,100%,.008) 1px,transparent 0);background-size:100% 24px}@media(min-width:900px){.timeline-card{grid-template-columns:380px 1fr}}.timeline-card:hover{transform:translateY(-6px);border-color:var(--accent-color);box-shadow:0 18px 40px var(--shadow-color)}.timeline-card-media{position:relative;border-radius:10px;overflow:hidden;min-height:240px;background:rgba(0,0,0,.03);box-shadow:inset 0 2px 8px rgba(0,0,0,.06),0 4px 12px rgba(0,0,0,.05);border:1px solid var(--border-color)}.timeline-card-content{display:flex;flex-direction:column;justify-content:space-between}.memory-meta{display:flex;flex-wrap:wrap;gap:1.25rem;font-size:.88rem;color:var(--text-secondary);margin-bottom:1rem}.memory-tag{display:inline-block;background:rgba(212,175,55,.08);color:var(--text-primary);border:1px solid rgba(212,175,55,.25);padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:600;transition:var(--transition-smooth)}.memory-tag:hover{background:var(--accent-color);color:var(--bg-color)}.banner-today{display:flex;flex-direction:column;gap:1.25rem;padding:2.5rem;background:linear-gradient(135deg,var(--bg-card) 0,rgba(212,175,55,.15) 100%);border:2px solid var(--accent-color);outline:6px solid var(--accent-glow);border-radius:20px;margin-bottom:4rem;position:relative;overflow:hidden;box-shadow:0 15px 35px var(--shadow-color)}.banner-today:before{content:"✦";position:absolute;top:15px;right:20px;font-size:2.5rem;color:var(--accent-color);opacity:.45;animation:pulse 3s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:.45}50%{transform:scale(1.15);opacity:.75}}.washi-tape{position:absolute;top:-12px;left:35%;width:90px;height:24px;background:rgba(212,175,55,.28);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);border-left:1px dashed rgba(212,175,55,.5);border-right:1px dashed rgba(212,175,55,.5);transform:rotate(-4deg);z-index:10;box-shadow:0 2px 4px rgba(0,0,0,.04)}.video-wrapper{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:10px;box-shadow:0 8px 25px rgba(0,0,0,.15)}.video-wrapper iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.scrapbook-canvas{background-color:var(--canvas-bg);background-image:radial-gradient(var(--border-color) 1px,transparent 1px),radial-gradient(rgba(212,175,55,.15) 1.5px,transparent 1.5px);background-size:24px 24px,48px 48px;background-position:0 0,12px 12px;border-radius:24px;padding:3rem 2rem;min-height:85vh;margin-top:2rem;border:2px dashed var(--border-color);box-shadow:inset 0 0 30px var(--shadow-color);position:relative}.collage-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:3.5rem;gap:3.5rem}.polaroid-card{background:#fff;background-image:radial-gradient(rgba(0,0,0,.01) 8%,transparent 0);background-size:10px 10px;padding:1.25rem 1.25rem 3.25rem;border-radius:6px;box-shadow:3px 12px 35px rgba(44,42,41,.14);transform:rotate(var(--rotation,0deg));border:1px solid hsla(43,33%,83%,.55);color:#2c2a29;transition:var(--transition-smooth);position:relative}[data-theme=dark] .polaroid-card{background:#faf6eb;color:#2c2a29}.polaroid-card:hover{transform:translateY(-12px) rotate(0deg) scale(1.03);z-index:10;box-shadow:5px 20px 45px rgba(44,42,41,.22)}.polaroid-image{position:relative;width:100%;aspect-ratio:1;background:#ebe6db;border:1px solid rgba(0,0,0,.08);margin-bottom:1.25rem;overflow:hidden;box-shadow:inset 0 2px 6px rgba(0,0,0,.05)}.polaroid-caption{font-family:var(--font-handwritten);font-size:1.8rem;text-align:center;margin-top:.5rem;line-height:1.1;color:#3d352e}.sticker{position:absolute;font-size:3rem;z-index:5;filter:drop-shadow(0 5px 10px rgba(0,0,0,.18));cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;animation:wiggle 5s ease-in-out infinite;transition:var(--transition-smooth)}.sticker:hover{transform:scale(1.2) rotate(10deg)}@keyframes wiggle{0%,to{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}.form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.form-control{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary);padding:.85rem 1.1rem;border-radius:10px;font-family:var(--font-sans);font-size:1rem;box-shadow:inset 0 1px 4px rgba(0,0,0,.02);transition:var(--transition-smooth)}.form-control:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 4px var(--accent-glow);background:var(--bg-color)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;padding:.85rem 1.75rem;font-size:1rem;font-weight:600;border-radius:10px;border:1px solid transparent;cursor:pointer;box-shadow:0 2px 4px rgba(0,0,0,.05);transition:var(--transition-smooth)}.btn-primary{background:linear-gradient(135deg,#e6c280 0,var(--accent-color) 100%);color:#2c2a29;border:1px solid rgba(212,175,55,.5);box-shadow:0 4px 15px var(--accent-glow)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px var(--accent-glow);filter:brightness(1.05)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:none;border-color:var(--border-color);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-card);border-color:var(--accent-color)}.timeline-nav-wheel{position:fixed;bottom:2rem;right:2rem;z-index:50;display:flex;flex-direction:column;gap:.6rem;background:hsla(42,50%,96%,.9);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(212,175,55,.25);padding:.85rem;border-radius:24px;box-shadow:0 15px 35px var(--shadow-color)}[data-theme=dark] .timeline-nav-wheel{background:rgba(20,19,18,.9)}.nav-wheel-item{width:44px;height:44px;border-radius:50%;background:none;border:1px solid transparent;color:var(--text-secondary);font-weight:700;font-size:.9rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition-smooth)}.nav-wheel-item.active,.nav-wheel-item:hover{background:var(--accent-color);color:var(--bg-color);box-shadow:0 4px 12px var(--accent-glow)}@media (max-width:767px){.timeline-nav-wheel{display:none!important}.timeline-line{left:15px}.timeline-dot{left:12px;top:10px;width:18px;height:18px}.timeline-item{padding-left:35px;margin-bottom:2.5rem}.timeline-card{padding:1.5rem;gap:1.25rem}.timeline-card-media{min-height:180px}.timeline-year-header{font-size:2rem;margin-bottom:1.75rem;top:70px}.banner-today{padding:1.75rem;margin-bottom:2.5rem}.scrapbook-canvas{padding:1.5rem 1rem;border-radius:16px}.collage-grid{gap:2rem;grid-template-columns:repeat(auto-fill,minmax(230px,1fr))}.polaroid-card{padding:.85rem .85rem 2rem;transform:rotate(calc(var(--rotation, 0deg) * .4))}.polaroid-image{margin-bottom:.75rem}.polaroid-caption{font-size:1.4rem}.glass-panel{border-radius:16px}}@media (max-width:480px){.container{padding:0 1rem}}