:root{--cream: #fff7f1;--cream-strong: #ffefe6;--rose: #c52f46;--rose-dark: #8f1930;--rose-soft: #ffdce4;--gold: #d6a645;--green: #5b8a62;--ink: #40212a;--muted: #7e5963;--white: #ffffff;--shadow: 0 24px 70px rgba(143, 25, 48, .14);--radius-large: 34px;--radius-medium: 24px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;color:var(--ink);background:radial-gradient(circle at 15% 10%,rgba(255,220,228,.85),transparent 30%),radial-gradient(circle at 86% 5%,rgba(214,166,69,.18),transparent 24%),linear-gradient(135deg,var(--cream),#fffdf9 45%,var(--cream-strong));font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,textarea,select{font:inherit}button{cursor:pointer}img{display:block;max-width:100%}.page-shell{position:relative;overflow:hidden;width:min(1180px,calc(100% - 32px));margin:0 auto;padding:28px 0 80px}.section-card{position:relative;margin:28px 0;padding:clamp(26px,4vw,56px);overflow:hidden;border:1px solid rgba(197,47,70,.12);border-radius:var(--radius-large);background:#ffffffc7;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.section-card:before{content:"";position:absolute;inset:14px;z-index:-1;border:1px solid rgba(214,166,69,.25);border-radius:calc(var(--radius-large) - 10px);pointer-events:none}.floating-decoration{position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none}.floating-decoration span{position:absolute;color:#c52f4629;font-size:clamp(36px,5vw,92px);transform:rotate(-12deg)}.floating-decoration span:nth-child(1){left:4%;top:12%}.floating-decoration span:nth-child(2){right:6%;top:16%;color:#5b8a622e}.floating-decoration span:nth-child(3){left:9%;bottom:14%;color:#d6a64538}.floating-decoration span:nth-child(4){right:12%;bottom:19%}.floating-decoration span:nth-child(5){left:46%;top:3%;color:#5b8a6229}.floating-decoration span:nth-child(6){right:40%;bottom:3%}.hero-section{min-height:700px}.multi-page-shell{padding-top:28px}.site-header{margin-top:0;padding-bottom:clamp(34px,5vw,68px)}.site-title-block{margin-bottom:0}.home-navigation-section{margin-top:28px}.home-navigation{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(16px,3vw,26px);max-width:980px;margin:0 auto}.navigation-card{display:grid;grid-template-columns:auto minmax(0,1fr);gap:18px;align-items:center;min-height:158px;padding:clamp(20px,3vw,30px);border:1px solid rgba(197,47,70,.12);border-radius:var(--radius-medium);color:inherit;background:linear-gradient(145deg,#fffffff0,#fff7f1f0),radial-gradient(circle at 100% 0,rgba(255,220,228,.72),transparent 34%);box-shadow:0 18px 48px #8f19301a;text-decoration:none;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.navigation-card:hover{border-color:#c52f4647;box-shadow:0 24px 58px #8f193029;transform:translateY(-3px)}.navigation-icon{display:grid;place-items:center;width:62px;height:62px;border-radius:50%;background:var(--rose-soft);box-shadow:inset 0 0 0 1px #c52f461f;font-size:1.9rem}.navigation-card strong{display:block;margin-bottom:8px;color:var(--rose-dark);font-family:Georgia,Times New Roman,serif;font-size:clamp(1.35rem,2.2vw,2rem);line-height:1.1}.navigation-card small{display:block;color:var(--muted);font-size:1rem;line-height:1.55}.back-link-row{display:flex;justify-content:flex-start;margin:18px 0 -4px}.back-link{display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:12px 18px;color:var(--white);background:linear-gradient(135deg,var(--rose),var(--rose-dark));box-shadow:0 12px 28px #8f193033;font-weight:900;text-decoration:none;transition:transform .18s ease,box-shadow .18s ease}.back-link:hover{box-shadow:0 18px 34px #8f193047;transform:translateY(-2px)}.hero-topline{display:flex;justify-content:space-between;gap:16px;margin-bottom:34px;color:var(--rose-dark);font-size:.95rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.hero-title-block{max-width:820px;margin:0 auto 48px;text-align:center}.rings-mark{position:relative;width:88px;height:52px;margin:0 auto 18px}.rings-mark span{position:absolute;top:8px;width:46px;height:46px;border:6px solid var(--gold);border-radius:50%;box-shadow:inset 0 0 0 2px #fff9}.rings-mark span:first-child{left:8px}.rings-mark span:last-child{right:8px}h1,h2,h3,p{margin-top:0}h1{margin-bottom:12px;color:var(--rose-dark);font-family:Georgia,Times New Roman,serif;font-size:clamp(3.2rem,10vw,8rem);line-height:.92;letter-spacing:-.06em}h2{margin-bottom:14px;color:var(--rose-dark);font-family:Georgia,Times New Roman,serif;font-size:clamp(2rem,5vw,4.2rem);line-height:1}h3{margin-bottom:10px;color:var(--rose-dark);font-size:clamp(1.25rem,2vw,1.8rem)}p{color:var(--muted);line-height:1.7}.couple-names{margin-bottom:12px;color:var(--gold);font-size:clamp(1.25rem,3vw,2.1rem);font-weight:800}.hero-subtitle{max-width:720px;margin:0 auto 12px;color:var(--ink);font-size:clamp(1.05rem,2vw,1.35rem);font-weight:600}.hero-text{max-width:700px;margin:0 auto}.section-heading{max-width:760px;margin:0 auto 34px;text-align:center}.section-heading p:last-child{margin-bottom:0}.section-eyebrow{margin-bottom:10px;color:var(--rose);font-size:.9rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase}.congratulation-layout{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:clamp(12px,3vw,26px);align-items:center}.congratulation-card{display:grid;grid-template-columns:170px minmax(0,1fr);gap:clamp(18px,3vw,34px);align-items:center;min-height:260px;padding:clamp(22px,4vw,42px);border:1px solid rgba(197,47,70,.12);border-radius:var(--radius-medium);background:linear-gradient(145deg,#fffffff0,#fff7f1f0),radial-gradient(circle at 0 0,rgba(255,220,228,.8),transparent 30%);box-shadow:0 18px 48px #8f19301f;animation:fade-slide .26s ease-out}.person-photo{width:160px;height:160px;border:8px solid var(--white);border-radius:50%;object-fit:cover;box-shadow:0 12px 32px #8f193033}.person-role{margin-bottom:6px;color:var(--gold);font-weight:800;text-transform:lowercase}.video-congratulation-card{grid-template-columns:210px minmax(0,1fr);min-height:430px}.person-summary{display:grid;justify-items:center;gap:18px;text-align:center}.person-summary h3{margin-bottom:0}.video-frame{display:grid;place-items:center;min-width:0;padding:12px;border-radius:24px;background:radial-gradient(circle at 10% 0,rgba(255,220,228,.35),transparent 30%),#40212aeb;box-shadow:inset 0 0 0 1px #ffffff1f}.congratulation-video{width:100%;max-height:min(58vh,520px);border-radius:18px;background:#160a0f;aspect-ratio:16 / 9;object-fit:contain}.family-photos-section{overflow:visible}.photo-carousel{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:clamp(12px,3vw,26px);align-items:center}.photo-card{margin:0;padding:clamp(16px,3vw,28px);border:1px solid rgba(197,47,70,.12);border-radius:var(--radius-medium);background:linear-gradient(145deg,#fffffff0,#fff7f1f0),radial-gradient(circle at 100% 0,rgba(214,166,69,.18),transparent 28%);box-shadow:0 18px 48px #8f19301f;animation:fade-slide .26s ease-out}.photo-stage{position:relative;display:grid;place-items:center;height:clamp(320px,54vw,620px);overflow:hidden;border-radius:22px;background:radial-gradient(circle at 20% 15%,rgba(255,220,228,.35),transparent 30%),#40212aeb}.photo-stage img{width:100%;height:100%;object-fit:contain}.photo-card figcaption,.fullscreen-photo-card figcaption{display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;margin-top:16px;color:var(--muted)}.photo-card figcaption strong,.fullscreen-photo-card figcaption strong{color:var(--rose-dark)}.fullscreen-button,.fullscreen-close{border:0;color:var(--white);background:#8f1930db;box-shadow:0 12px 26px #14080c47;font-weight:900;transition:transform .18s ease,background .18s ease}.fullscreen-button:hover,.fullscreen-close:hover{transform:translateY(-2px);background:var(--rose-dark)}.fullscreen-button{position:absolute;right:18px;bottom:18px;border-radius:999px;padding:12px 18px}.fullscreen-viewer{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;width:100vw;height:100vh;height:100dvh;padding:78px 108px 38px;overflow:hidden;background:#160a0ff5}.fullscreen-viewer:fullscreen{width:100vw;height:100vh;height:100dvh;background:#160a0ffa}.fullscreen-photo-card{display:grid;grid-template-rows:minmax(0,1fr) auto;align-items:center;justify-items:center;width:min(100%,1400px);height:100%;min-width:0;min-height:0;margin:0}.fullscreen-photo-card img{align-self:center;justify-self:center;width:100%;height:100%;min-height:0;max-width:100%;max-height:calc(100dvh - 160px);border-radius:22px;object-fit:contain}.fullscreen-photo-card figcaption{justify-self:center;width:min(900px,100%);color:#ffffffc7}.fullscreen-photo-card figcaption strong{color:var(--white)}.fullscreen-close{position:absolute;top:18px;right:18px;z-index:2;display:grid;place-items:center;width:48px;height:48px;border-radius:50%;font-size:2rem;line-height:1}.fullscreen-arrow{position:absolute;top:50%;z-index:2;transform:translateY(-50%)}.fullscreen-arrow-left{left:32px}.fullscreen-arrow-right{right:32px}.round-button{display:grid;place-items:center;width:54px;height:54px;border:0;border-radius:50%;color:var(--white);background:linear-gradient(135deg,var(--rose),var(--rose-dark));box-shadow:0 12px 28px #8f193038;font-size:2.2rem;line-height:1;transition:transform .18s ease,box-shadow .18s ease}.round-button:hover,.primary-button:hover{transform:translateY(-2px);box-shadow:0 18px 34px #8f193047}.fullscreen-arrow:hover{transform:translateY(calc(-50% - 2px))}.carousel-dots{display:flex;justify-content:center;gap:10px;margin-top:22px}.dot{width:12px;height:12px;border:0;border-radius:999px;background:#c52f4640;transition:width .18s ease,background .18s ease}.active-dot{width:36px;background:var(--rose)}.timeline-wrapper{position:relative;min-height:var(--timeline-height);margin-top:14px;padding:0}.timeline-curve{position:absolute;inset:0;width:100%;height:100%;overflow:visible;pointer-events:none}.timeline-curve path{fill:none;stroke:var(--rose);stroke-linecap:round;stroke-width:8;filter:drop-shadow(0 10px 10px rgba(197,47,70,.18))}.timeline-items{position:relative;z-index:1;display:grid;padding:80px 0;grid-auto-rows:330px;min-height:var(--timeline-height)}.timeline-item{position:relative;min-height:330px;opacity:0;transform:translateY(42px);transition:opacity .6s ease,transform .6s ease}.timeline-item-visible{opacity:1;transform:translateY(0)}.timeline-dot{position:absolute;top:50%;left:50%;z-index:3;width:24px;height:24px;border:5px solid var(--white);border-radius:50%;background:var(--rose);box-shadow:0 8px 20px #8f193047;transform:translate(-50%,-50%)}.timeline-card{position:absolute;top:50%;z-index:2;display:grid;gap:12px;width:min(420px,calc(50% - 88px));padding:14px;border:1px solid rgba(197,47,70,.12);border-radius:22px;background:#ffffffeb;box-shadow:0 16px 44px #8f19301f;transform:translateY(-50%)}.timeline-item-left .timeline-card{right:calc(50% + 72px)}.timeline-item-right .timeline-card{left:calc(50% + 72px)}.timeline-card img{width:100%;height:120px;border-radius:16px;object-fit:cover}.timeline-card h3{margin-bottom:6px;font-size:1.1rem}.timeline-card p{margin-bottom:0;font-size:.94rem;line-height:1.55}.timeline-date{color:var(--rose);font-weight:900}.quiz-card{max-width:880px;margin:0 auto;padding:clamp(18px,4vw,38px);border:1px solid rgba(197,47,70,.12);border-radius:var(--radius-medium);background:radial-gradient(circle at 10% 0,rgba(255,220,228,.9),transparent 28%),linear-gradient(145deg,#fffffff0,#fff7f1f5);box-shadow:0 18px 48px #8f19301f}.scoreboard{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:16px;margin-bottom:30px}.score-pill{display:flex;align-items:center;gap:14px;min-width:145px;padding:12px 18px;border:1px solid rgba(197,47,70,.15);border-radius:999px;background:var(--white)}.score-pill span{color:var(--muted);font-weight:700}.score-pill strong{display:grid;place-items:center;width:34px;height:34px;margin-left:auto;border-radius:50%;color:var(--white);background:var(--rose)}.score-heart{color:var(--rose);font-size:2rem}.question-meta{display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;margin-bottom:18px;color:var(--rose-dark);font-weight:800}.answer-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:24px 0}.answer-option{min-height:70px;padding:18px;border:2px solid rgba(197,47,70,.16);border-radius:18px;color:var(--ink);background:var(--white);text-align:left;transition:border-color .18s ease,transform .18s ease,background .18s ease}.answer-option:hover:not(:disabled),.selected-option{border-color:var(--rose);background:var(--rose-soft);transform:translateY(-2px)}.correct-option,.correct-option:hover{border-color:var(--green);background:#5b8a6224}.wrong-option,.wrong-option:hover{border-color:var(--rose-dark);background:#c52f4624}.answer-explanation{margin-bottom:0;color:var(--rose-dark);font-weight:700}.quiz-actions{display:flex;justify-content:center;margin-top:24px}.primary-button{border:0;border-radius:999px;padding:14px 24px;color:var(--white);background:linear-gradient(135deg,var(--rose),var(--rose-dark));box-shadow:0 12px 28px #8f193033;font-weight:900;transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease}.primary-button:disabled{cursor:not-allowed;opacity:.45;transform:none;box-shadow:none}.game-result{padding:32px 0 12px;text-align:center}.result-icon{margin-bottom:10px;font-size:4rem}@keyframes fade-slide{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:900px){.home-navigation,.congratulation-layout{grid-template-columns:1fr}.congratulation-layout>.round-button{display:none}.congratulation-card{grid-template-columns:1fr;justify-items:center;text-align:center}.video-congratulation-card{min-height:auto}.video-frame{width:100%}.photo-carousel{grid-template-columns:1fr}.photo-arrow{justify-self:center}.photo-carousel .photo-arrow:first-child{order:2}.photo-card{order:1}.photo-carousel .photo-arrow:last-child{order:3}.fullscreen-viewer{padding:74px 64px 28px}.fullscreen-photo-card img{max-height:calc(100dvh - 145px)}.fullscreen-arrow{width:46px;height:46px;font-size:1.8rem}.fullscreen-arrow-left{left:10px}.fullscreen-arrow-right{right:10px}.timeline-wrapper{min-height:auto;padding:10px 0 0 32px}.timeline-curve{display:none}.timeline-wrapper:before{content:"";position:absolute;top:12px;bottom:12px;left:11px;width:6px;border-radius:999px;background:var(--rose)}.timeline-items{display:grid;grid-auto-rows:auto;gap:20px;padding:0;min-height:auto}.timeline-item{min-height:auto}.timeline-dot{top:32px;left:-13px;transform:none}.timeline-card{position:relative;top:auto;right:auto;left:auto;grid-template-columns:160px minmax(0,1fr);align-items:center;width:100%;transform:none}}@media(max-width:640px){.navigation-card{grid-template-columns:1fr;justify-items:center;text-align:center}.back-link-row{justify-content:center}.page-shell{width:min(100% - 18px,1180px);padding-bottom:34px}.section-card{padding:22px;border-radius:24px}.hero-topline{flex-direction:column;text-align:center}.person-photo{width:132px;height:132px}.timeline-card{grid-template-columns:1fr}.timeline-card img{height:170px}.answer-grid{grid-template-columns:1fr}}.timeline-card img{width:100%;max-width:100%;height:auto;aspect-ratio:16 / 9;object-fit:cover;border-radius:16px}:is(.photo-stage img,.fullscreen-photo-card img){max-width:100%;height:auto;object-fit:contain}
