@import"https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;600;700;900&family=Noto+Sans+JP:wght@400;500;600;700;800&display=swap";:root{--burgundy: #7a001c;--burgundy-2: #5e0016;--burgundy-3: #3d000e;--burgundy-light: rgba(122, 0, 28, .08);--burgundy-mid: rgba(122, 0, 28, .18);--gold: #c8a84b;--gold-2: #a88734;--gold-light: rgba(200, 168, 75, .16);--gold-shimmer: rgba(200, 168, 75, .35);--deep-purple: #2a0a1f;--deep-wine: #1a0510;--bg: #f7f4ef;--bg-warm: #fdf9f4;--card: #ffffff;--card-elevated: #fffef9;--ink: #1a0e14;--ink-2: #3d2535;--muted: #7a6270;--muted-light: #a89098;--line: #e8e0d8;--line-gold: rgba(200, 168, 75, .3);--shadow-xs: 0 1px 4px rgba(26, 5, 16, .06);--shadow-sm: 0 2px 10px rgba(26, 5, 16, .08);--shadow: 0 8px 28px rgba(26, 5, 16, .1);--shadow-lg: 0 16px 48px rgba(26, 5, 16, .14);--shadow-xl: 0 24px 64px rgba(26, 5, 16, .2);--shadow-burgundy: 0 6px 24px rgba(122, 0, 28, .32);--shadow-gold: 0 6px 20px rgba(200, 168, 75, .3);--radius: 18px;--radius-sm: 12px;--radius-xs: 8px;--transition: .22s ease;--transition-slow: .38s ease;--grad-hero: #5e0016;--grad-card: #fffef9;--grad-gold: #c8a84b;--grad-dark: #1f0717}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{margin:0;font-family:Noto Sans JP,Hiragino Sans,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.container{max-width:1060px;margin:0 auto;padding:0 20px}.grid{display:grid;gap:18px}.serif{font-family:"Noto Serif JP",Georgia,serif}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:14px 26px;border-radius:var(--radius-sm);font-weight:700;font-size:15px;text-decoration:none;cursor:pointer;border:none;letter-spacing:.02em;transition:transform .15s ease,box-shadow .22s ease,background .22s ease,opacity .22s ease;position:relative;overflow:hidden;white-space:nowrap}.btn:after{content:"";position:absolute;inset:0;background:#ffffff0f;pointer-events:none;border-radius:inherit}.btn:active{transform:translateY(1px) scale(.985)}.btn-primary{background:var(--burgundy);color:#fff;box-shadow:var(--shadow-burgundy)}.btn-primary:hover{background:#8c0020;box-shadow:0 8px 28px #7a001c6b;transform:translateY(-2px)}.btn-ghost{border:1.5px solid var(--burgundy);color:var(--burgundy);background:transparent;padding:12px 26px}.btn-ghost:hover{background:var(--burgundy-light);border-color:var(--burgundy-2);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.btn-gold{background:var(--grad-gold);color:#3d2200;box-shadow:var(--shadow-gold),0 0 0 2px #c8a84b40;font-weight:800;font-size:16px;padding:16px 32px;letter-spacing:.04em}.btn-gold:hover{box-shadow:0 8px 24px #c8a84b70;transform:translateY(-2px);filter:brightness(1.05)}button,.btn{min-height:46px}.tag{display:inline-flex;align-items:center;gap:5px;padding:5px 14px;border-radius:999px;font-size:12px;font-weight:700;background:var(--gold-light);border:1px solid var(--line-gold);color:var(--gold-2);letter-spacing:.06em;text-transform:uppercase}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);position:relative;overflow:hidden}.card-elevated{background:var(--card-elevated);border:1px solid var(--line-gold);border-radius:var(--radius);box-shadow:var(--shadow-lg)}.hero{position:relative;overflow:hidden;border-radius:32px;background:var(--burgundy-3);box-shadow:0 40px 96px #28000a99,0 0 0 1px #c8a84b38,inset 0 1px #c8a84b2e;padding:96px 40px 88px;text-align:center;border:1px solid rgba(200,168,75,.22);isolation:isolate}.hero-bg{position:absolute;inset:0;pointer-events:none;z-index:0;background:#5e001659}.hero-particles{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden;border-radius:inherit}.hero-particles:before,.hero-particles:after{content:"";position:absolute;width:5px;height:5px;border-radius:50%;background:#e8c96bb3;filter:blur(.5px)}.hero-particles:before{top:22%;left:14%;animation:particle-drift-a 14s ease-in-out infinite}.hero-particles:after{top:64%;right:18%;width:4px;height:4px;animation:particle-drift-b 18s ease-in-out infinite}@keyframes particle-drift-a{0%,to{transform:translate(0);opacity:.5}50%{transform:translate(40px,-28px);opacity:1}}@keyframes particle-drift-b{0%,to{transform:translate(0);opacity:.4}50%{transform:translate(-32px,-20px);opacity:.9}}.hero>*{position:relative;z-index:1}.hero-eyebrow{display:inline-flex;align-items:center;gap:6px;padding:5px 16px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;background:#c8a84b2e;border:1px solid rgba(200,168,75,.4);color:#e8c96b;margin-bottom:20px}.hero-title{font-family:"Noto Serif JP",Georgia,serif;font-weight:700;line-height:1.2;font-size:clamp(30px,5.5vw,52px);color:#fff;letter-spacing:-.02em;margin:0;text-shadow:0 2px 20px rgba(0,0,0,.3)}.hero-title .accent{color:#e8c96b;display:inline-block}.hero-sub{color:#ffffffc7;margin-top:16px;line-height:1.85;font-size:15.5px;max-width:520px;margin-left:auto;margin-right:auto}.hero-cta{margin-top:32px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.hero-grape{font-size:72px;line-height:1;margin-bottom:20px;display:block;animation:grape-sway 5s ease-in-out infinite;filter:drop-shadow(0 8px 16px rgba(0,0,0,.25))}.hero-divider{width:48px;height:2px;background:var(--grad-gold);margin:20px auto;border-radius:999px;opacity:.7}.hero-visual{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;margin-bottom:20px;animation:hero-float 5s ease-in-out infinite}@keyframes hero-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.hero-visual-glow{position:absolute;inset:-20px;background:#c8a84b1a;pointer-events:none;border-radius:50%;animation:glow-pulse 3s ease-in-out infinite}@keyframes glow-pulse{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}.hero-bottle-wrap{filter:drop-shadow(0 12px 24px rgba(0,0,0,.35));animation:bottle-sway 6s ease-in-out infinite}@keyframes bottle-sway{0%,to{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}.hero-grapes-wrap{filter:drop-shadow(0 6px 14px rgba(0,0,0,.25));animation:grapes-bob 4s ease-in-out infinite .8s}@keyframes grapes-bob{0%,to{transform:translateY(0) rotate(5deg)}50%{transform:translateY(-6px) rotate(-3deg)}}.svg-icon{display:flex;align-items:center;justify-content:center}.kpi-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.kpi-card{position:relative;background:var(--card-elevated);border:1px solid rgba(200,168,75,.32);border-radius:var(--radius);padding:24px 14px 20px;text-align:center;box-shadow:var(--shadow-sm),inset 0 1px #ffffffe6,inset 0 -1px #c8a84b14;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition),background var(--transition);cursor:default;overflow:hidden;isolation:isolate}.kpi-card:before{content:"";position:absolute;top:0;left:12%;right:12%;height:1px;background:#c8a84b73;z-index:1}.kpi-card:after{content:"";position:absolute;top:-40px;right:-40px;width:100px;height:100px;background:#c8a84b1a;border-radius:50%;z-index:0;pointer-events:none;transition:transform .5s ease,opacity .5s ease;opacity:.6}.kpi-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg),0 0 0 1px #c8a84b66,inset 0 1px #fff;border-color:var(--gold)}.kpi-card:hover:after{transform:scale(1.4);opacity:1}.kpi-card>*{position:relative;z-index:1}.kpi-icon{font-size:26px;margin-bottom:8px;line-height:1;display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:14px;background:var(--gold-light);border:1px solid var(--line-gold);margin-left:auto;margin-right:auto}.kpi-value{font-size:24px;font-weight:800;color:var(--burgundy);line-height:1.1;font-family:"Noto Serif JP",serif}.kpi-label{font-size:14px;color:var(--muted);margin-top:3px;font-weight:600;letter-spacing:.03em}.features{grid-template-columns:repeat(1,1fr)}@media(min-width:760px){.features{grid-template-columns:repeat(3,1fr)}}.feature{position:relative;padding:32px 26px 30px;border-radius:var(--radius);transition:transform .32s cubic-bezier(.2,.8,.2,1),box-shadow .32s ease,border-color .32s ease,background .32s ease;background:#fffdf9;border:1px solid var(--line);box-shadow:var(--shadow-sm);overflow:hidden;min-height:240px;display:flex;flex-direction:column;isolation:isolate}.feature:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--burgundy);opacity:0;transition:opacity .32s ease;z-index:1}.feature:after{content:"";position:absolute;top:-60px;right:-60px;width:160px;height:160px;background:#c8a84b14;border-radius:50%;opacity:0;transition:opacity .4s ease,transform .5s ease;z-index:0}.feature>*{position:relative;z-index:1}.feature:hover{transform:translateY(-8px);box-shadow:0 24px 48px #7a001c29,0 0 0 1px #c8a84b59;border-color:var(--gold);background:#fdf6ec}.feature:hover:before{opacity:1}.feature:hover:after{opacity:1;transform:scale(1.2)}.feature .icon-wrap{width:60px;height:60px;border-radius:18px;background:#c8a84b24;border:1px solid var(--line-gold);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:18px;box-shadow:inset 0 1px #fffc,0 4px 12px #7a001c14;transition:transform .32s cubic-bezier(.2,.8,.2,1)}.feature:hover .icon-wrap{transform:translateY(-2px) rotate(-3deg) scale(1.06)}.feature .icon{font-size:32px;display:block;margin-bottom:12px}.feature .title{font-weight:700;font-size:18px;color:var(--ink);font-family:"Noto Serif JP",serif;letter-spacing:.01em}.feature .desc{color:var(--muted);margin-top:10px;line-height:1.85;font-size:14px}.feature .feature-meta{margin-top:auto;padding-top:16px;display:flex;align-items:center;gap:6px;font-size:12px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-2);opacity:.75;transition:opacity .32s ease,transform .32s ease}.feature:hover .feature-meta{opacity:1;transform:translate(4px)}.hiw{grid-template-columns:repeat(1,1fr)}@media(min-width:900px){.hiw{grid-template-columns:1.2fr 1fr;align-items:start}}.hiw-steps .step{display:flex;gap:16px;padding:18px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--card);transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition)}.hiw-steps .step:hover{border-color:var(--line-gold);box-shadow:var(--shadow-sm);transform:translate(4px)}.step .num{width:38px;height:38px;flex-shrink:0;border-radius:12px;background:var(--grad-hero);color:#e8c96b;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;box-shadow:0 3px 10px #7a001c52;font-family:"Noto Serif JP",serif}.quote{position:relative;padding:18px 20px 18px 22px;border-left:3px solid var(--gold);background:#fffdf6;border-radius:0 var(--radius-sm) var(--radius-sm) 0;box-shadow:var(--shadow-xs)}.quote:before{content:"“";position:absolute;top:8px;left:8px;font-size:32px;color:var(--gold);opacity:.4;font-family:Georgia,serif;line-height:1}.quote p{margin:0;color:var(--ink);line-height:1.85;font-size:14px;padding-left:12px}.quote small{display:block;margin-top:10px;color:var(--muted);font-size:13px;font-weight:700;letter-spacing:.04em;padding-left:12px}.nav-home{display:flex;align-items:center;gap:9px;font-weight:700;font-size:17px;text-decoration:none;color:#fff;padding:6px 12px;border-radius:10px;transition:background .2s ease,transform .12s ease;letter-spacing:.01em}.nav-home:hover{background:#ffffff1a;transform:scale(1.02)}.nav-home .logo{font-size:24px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.nav-link{position:relative;display:inline-flex;align-items:center;gap:4px;color:#ffffffad;text-decoration:none;font-size:14px;font-weight:500;padding:7px 11px 9px;border-radius:8px;transition:color .18s ease,background .18s ease;letter-spacing:.01em;white-space:nowrap}.nav-link:after{content:"";position:absolute;left:11px;right:11px;bottom:4px;height:1.5px;background:#e8c96bf2;transform:scaleX(0);transform-origin:center;opacity:0;transition:transform .32s cubic-bezier(.2,.8,.2,1),opacity .22s ease;border-radius:999px}.nav-link:hover{color:#fff;background:#ffffff0f}.nav-link:hover:after{transform:scaleX(1);opacity:1}.nav-link.active{color:#fff;font-weight:700;background:#ffffff1a}.nav-link.active:after{transform:scaleX(1);opacity:1;background:#e8c96b;height:2px;box-shadow:0 0 8px #e8c96b80}.progress-track{background:var(--line);border-radius:999px;overflow:hidden}.progress-fill{background:var(--burgundy);height:100%;border-radius:999px;transition:width .4s ease;position:relative}.progress-fill:after{content:"";position:absolute;right:0;top:0;bottom:0;width:3px;background:var(--gold);border-radius:999px}.quiz-question-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px 24px;margin-bottom:18px;position:relative;overflow:hidden}.quiz-question-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad-gold)}.quiz-q-label{font-size:12px;font-weight:800;color:var(--gold-2);letter-spacing:.1em;margin-bottom:12px;text-transform:uppercase;display:flex;align-items:center;gap:6px}.quiz-q-label:after{content:"";flex:1;height:1px;background:var(--line-gold)}.quiz-choice{position:relative;display:flex;align-items:center;gap:14px;padding:16px 56px 16px 18px;border:1.5px solid var(--line);border-radius:var(--radius-sm);background:#fffdf9;cursor:pointer;transition:border-color .2s cubic-bezier(.2,.8,.2,1),background .2s cubic-bezier(.2,.8,.2,1),box-shadow .2s ease,transform .18s cubic-bezier(.2,.8,.2,1),color .2s ease;text-align:left;width:100%;font-family:inherit;line-height:1.55;font-size:clamp(14px,3vw,15px);word-break:break-word;color:var(--ink);font-weight:500;min-height:58px;-webkit-tap-highlight-color:transparent;overflow:hidden;isolation:isolate}.quiz-choice .choice-trail{position:absolute;right:18px;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;color:var(--muted-light);font-size:14px;font-weight:800;transition:all .2s cubic-bezier(.2,.8,.2,1);opacity:.7}.quiz-choice:hover:not(:disabled){border-color:#7a001c8c;background:#fff5ee;transform:translate(4px);box-shadow:-3px 0 0 var(--burgundy),0 6px 18px #7a001c1a;color:var(--burgundy)}.quiz-choice:hover:not(:disabled) .choice-trail{color:var(--burgundy);opacity:1;transform:translateY(-50%) translate(3px)}.quiz-choice:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--grad-hero);border-radius:4px 0 0 4px;opacity:0;transition:opacity .15s}.quiz-choice.selected:before{opacity:1}.quiz-choice.correct:before{background:#16a34a;opacity:1}.quiz-choice.incorrect:before{background:#dc2626;opacity:1}.quiz-choice.selected{border-color:var(--burgundy);background:#7a001c0f;font-weight:600;color:var(--burgundy);box-shadow:0 0 0 3px #7a001c1a,0 4px 16px #7a001c1a;transform:translate(4px)}.quiz-choice.selected .choice-trail{color:var(--burgundy);opacity:1}.quiz-choice.correct{border-color:#10b981;background:#ecfdf5;color:#047857;font-weight:700;box-shadow:0 0 0 3px #10b9812e,0 8px 24px #10b9812e;animation:correct-bounce .55s cubic-bezier(.36,1.6,.32,1)}.quiz-choice.correct:after{content:"";position:absolute;inset:0;background:#10b9811f;animation:ripple-out .7s ease-out forwards;pointer-events:none;border-radius:inherit}.quiz-choice.incorrect{border-color:#f43f5e;background:#fff1f2;color:#be123c;font-weight:700;box-shadow:0 0 0 3px #f43f5e29,0 8px 24px #f43f5e24;animation:wrong-shake .5s cubic-bezier(.36,.07,.19,.97)}.choice-indicator{width:30px;height:30px;border-radius:10px;border:1.5px solid var(--line-gold);background:#fffaf0;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;font-family:"Noto Serif JP",serif;letter-spacing:.02em;color:var(--gold-2);transition:all .22s cubic-bezier(.2,.8,.2,1);box-shadow:inset 0 1px #ffffffe6,0 1px 3px #7a001c14}.quiz-choice:hover:not(:disabled) .choice-indicator{border-color:var(--burgundy);color:var(--burgundy);transform:scale(1.05);background:#fff5ef}.quiz-choice.selected .choice-indicator{border-color:var(--burgundy);background:var(--burgundy);color:#fff;box-shadow:0 0 0 3px #7a001c2e,inset 0 1px #ffffff2e;transform:scale(1.08)}.quiz-choice.correct .choice-indicator{border-color:#10b981;background:#059669;color:#fff;box-shadow:0 0 0 3px #10b98138,0 4px 12px #10b98152;transform:scale(1.1)}.quiz-choice.incorrect .choice-indicator{border-color:#f43f5e;background:#e11d48;color:#fff;box-shadow:0 0 0 3px #f43f5e33,0 4px 12px #f43f5e4d;transform:scale(1.05)}.feedback-correct{padding:18px 20px;border-radius:var(--radius-sm);background:#f0fdf4;border:1.5px solid #22c55e;color:#15803d;font-weight:700;font-size:16px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 16px #16a34a1f}.feedback-incorrect{padding:18px 20px;border-radius:var(--radius-sm);background:#fff1f2;border:1.5px solid #f43f5e;color:#be123c;font-weight:700;font-size:16px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 16px #f43f5e1a}.feedback-icon{font-size:26px;flex-shrink:0}.flashcard-scene{width:100%;max-width:640px;height:clamp(240px,46vw,340px);margin:0 auto;perspective:1600px;perspective-origin:50% 30%;cursor:pointer;touch-action:pan-y;user-select:none;-webkit-user-select:none}.flashcard-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .78s cubic-bezier(.55,0,.18,1);will-change:transform}.flashcard-scene:after{content:"";position:absolute;bottom:-14px;left:12%;right:12%;height:18px;background:#1a051024;filter:blur(8px);pointer-events:none;transform:scaleX(.95);transition:opacity .3s ease}.flashcard-face{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 36px;border-radius:22px;backface-visibility:hidden;-webkit-backface-visibility:hidden}.flashcard-front{background:var(--card);border:1px solid var(--line-gold);box-shadow:var(--shadow-lg)}.flashcard-front:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--grad-gold);border-radius:22px 22px 0 0}.flashcard-back{transform:rotateY(180deg);background:var(--grad-hero);border:1px solid rgba(200,168,75,.25);box-shadow:var(--shadow-lg)}.flashcard-back:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--grad-gold);border-radius:22px 22px 0 0}.flashcard-face-label{position:absolute;top:16px;left:18px;font-size:12px;font-weight:800;letter-spacing:.1em;text-transform:uppercase}.flashcard-face-label.front{color:var(--muted-light)}.flashcard-face-label.back{color:#c8a84bbf}.flashcard-text{font-size:clamp(16px,4vw,23px);line-height:1.72;white-space:pre-wrap;word-break:break-word;font-weight:600;text-align:center}.flashcard-text.front{color:var(--ink)}.flashcard-text.back{color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.2)}.flashcard-hint{position:absolute;bottom:14px;right:18px;font-size:12px;font-weight:600}.flashcard-hint.front{color:var(--muted-light)}.flashcard-hint.back{color:#ffffff73}.known-badge{position:absolute;top:14px;right:16px;background:var(--grad-gold);color:#3d2200;font-size:12px;font-weight:800;padding:4px 10px;border-radius:999px;letter-spacing:.04em;box-shadow:var(--shadow-gold)}@keyframes grape-sway{0%,to{transform:rotate(-4deg) scale(1)}50%{transform:rotate(4deg) scale(1.04)}}@keyframes slide-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slide-down{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-7px)}40%{transform:translate(7px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}@keyframes pop-in{0%{transform:scale(.88);opacity:0}65%{transform:scale(1.05);opacity:1}to{transform:scale(1)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 #7a001c40}50%{box-shadow:0 0 0 8px #7a001c00}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}.animate-slide-up{animation:slide-up .32s ease forwards}.animate-fade-in{animation:fade-in .3s ease forwards}.shake{animation:shake .42s ease}.pop-in{animation:pop-in .38s ease forwards}@keyframes card-flip{0%{transform:rotateY(0)}to{transform:rotateY(180deg)}}.card-flip{animation:card-flip .7s cubic-bezier(.6,0,.2,1) forwards;transform-style:preserve-3d}@keyframes correct-bounce{0%{transform:scale(1)}20%{transform:scale(1.05)}40%{transform:scale(.97)}60%{transform:scale(1.03)}80%{transform:scale(.99)}to{transform:scale(1)}}@keyframes correct-glow{0%{box-shadow:0 0 #16a34a8c}to{box-shadow:0 0 0 18px #16a34a00}}.correct-bounce{animation:correct-bounce .55s cubic-bezier(.36,1.6,.32,1) forwards,correct-glow .7s ease-out forwards}@keyframes wrong-shake{0%,to{transform:translate(0) rotate(0)}15%{transform:translate(-9px) rotate(-.6deg)}30%{transform:translate(9px) rotate(.6deg)}45%{transform:translate(-7px) rotate(-.4deg)}60%{transform:translate(7px) rotate(.4deg)}75%{transform:translate(-3px)}90%{transform:translate(3px)}}@keyframes wrong-flash{0%,to{box-shadow:0 0 #dc262600}30%{box-shadow:0 0 0 6px #dc262633}}.wrong-shake{animation:wrong-shake .5s cubic-bezier(.36,.07,.19,.97) both,wrong-flash .5s ease-out}@keyframes fade-slide-up{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-slide-right{0%{opacity:0;transform:translate(-18px)}to{opacity:1;transform:translate(0)}}@keyframes fade-slide-down{0%{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:translateY(0)}}.fade-slide{animation:fade-slide-up .42s cubic-bezier(.2,.8,.2,1) both}.fade-slide-right{animation:fade-slide-right .42s cubic-bezier(.2,.8,.2,1) both}.fade-slide-down{animation:fade-slide-down .42s cubic-bezier(.2,.8,.2,1) both}@keyframes ripple-out{0%{transform:scale(0);opacity:.55}to{transform:scale(2.4);opacity:0}}.ripple-emerald,.ripple-red{position:absolute;top:50%;left:24px;width:24px;height:24px;border-radius:50%;pointer-events:none;transform-origin:center;margin-top:-12px;z-index:0}.ripple-emerald{background:#10b98166;animation:ripple-out .7s ease-out forwards}.ripple-red{background:#f43f5e66;animation:ripple-out .7s ease-out forwards}@keyframes shimmer-sweep{0%{transform:translate(-120%) skew(-20deg)}to{transform:translate(220%) skew(-20deg)}}.shimmer-sweep:before{content:"";position:absolute;top:0;left:0;width:24%;height:100%;background:#ffffff47;animation:shimmer-sweep 1s ease-in-out;pointer-events:none}@media(prefers-reduced-motion:reduce){.card-flip,.correct-bounce,.wrong-shake,.fade-slide,.fade-slide-right,.fade-slide-down,.ripple-emerald,.ripple-red,.shimmer-sweep:before,.hero-particles:before,.hero-particles:after,.hero-visual,.hero-bottle-wrap,.hero-grapes-wrap,.hero-grape{animation:none!important;transition:none!important}}.hero{animation:hero-entrance .65s cubic-bezier(.2,0,.2,1) forwards}@keyframes hero-entrance{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.kpi-strip{animation:fade-up .5s ease .15s both}.features{animation:fade-up .5s ease .25s both}@keyframes fade-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.feature:nth-child(1){animation:fade-up .45s ease .1s both}.feature:nth-child(2){animation:fade-up .45s ease .22s both}.feature:nth-child(3){animation:fade-up .45s ease .34s both}.kpi-card{transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition),background var(--transition)}.kpi-card:hover{background:#fffdf6}.section-heading{font-family:"Noto Serif JP",Georgia,serif;font-size:21px;font-weight:700;color:var(--ink);margin:0 0 20px;display:flex;align-items:center;gap:12px;letter-spacing:.01em}.section-heading:before{content:"";width:3px;height:18px;background:var(--burgundy);border-radius:999px;box-shadow:0 0 8px #c8a84b66}.section-heading:after{content:"";flex:1;height:1px;background:var(--line-gold)}.cta-banner{padding:44px 28px 40px;text-align:center;background:#fdf6ec;border:1px solid var(--line-gold);border-radius:var(--radius);box-shadow:var(--shadow),inset 0 1px #ffffffe6;position:relative;overflow:hidden;isolation:isolate}.cta-banner:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad-gold);box-shadow:0 0 12px #c8a84b99}.cta-banner:after{content:"";position:absolute;top:-80px;right:-80px;width:220px;height:220px;background:#7a001c08;border-radius:50%;pointer-events:none;z-index:0}.cta-banner>*{position:relative;z-index:1}.result-score-ring{position:relative;display:inline-block}@media(max-width:600px){.hero{padding:52px 20px 44px;border-radius:20px}.hero-visual{margin-bottom:14px}.hero-bottle-wrap svg{width:68px;height:auto}.hero-grapes-wrap svg{width:42px;height:auto}.hero-cta{gap:8px}.hero-cta .btn{padding:12px 18px;font-size:14px}.container{padding:0 14px}.grid{gap:12px}.kpi-strip{gap:10px}.kpi-value{font-size:20px}}@media(max-width:400px){.hero-cta .btn{padding:11px 14px;font-size:14px}.kpi-card{padding:16px 10px}}:focus-visible{outline:2.5px solid var(--gold);outline-offset:3px;border-radius:4px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:#7a001c40;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#7a001c66}.markdown-body{color:#333;line-height:1.8;font-size:16px}.markdown-body h2{font-size:22px;margin:32px 0 12px;padding-bottom:6px;border-bottom:1px solid #eee;color:#7a001c}.markdown-body h3{font-size:18px;margin:24px 0 10px;color:#555}.markdown-body h4{font-size:16px;margin:20px 0 8px;color:#555}.markdown-body p{margin:0 0 14px}.markdown-body ul,.markdown-body ol{margin:0 0 14px;padding-left:1.5em}.markdown-body li{margin-bottom:4px}.markdown-body strong{color:#7a001c}.markdown-body hr{border:0;border-top:1px solid #eee;margin:24px 0}.markdown-body blockquote{border-left:3px solid #7a001c;padding:4px 12px;margin:14px 0;color:#555;background:#faf6f7}.markdown-body code{background:#f4f0f1;padding:1px 6px;border-radius:3px;font-size:.9em;color:#7a001c}.markdown-body pre{background:#2b1518;color:#f7e8ec;padding:14px;border-radius:6px;overflow-x:auto;font-size:14px;line-height:1.6}.markdown-body pre code{background:transparent;color:inherit;padding:0}.markdown-body table{width:100%;border-collapse:collapse;margin:12px 0 20px;font-size:14px}.markdown-body th,.markdown-body td{border:1px solid #e3dcde;padding:8px 10px;text-align:left}.markdown-body th{background:#faf6f7;color:#7a001c}.markdown-body a{color:#7a001c;text-decoration:underline}@media(max-width:360px){.streak-pill{display:none!important}}
