@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400&family=DM+Sans:wght@400;500;600;700&family=Noto+Sans+JP:wght@300;400;500;600;700&family=Noto+Serif+JP:wght@300;400;500;600;700&display=swap");:root{--bg-primary:#F0F7FF;--bg-secondary:#ffffff;--bg-tertiary:#E8F1FB;--bg-card:#ffffff;--bg-glass:rgba(255,255,255,0.65);--bg-glass-hover:rgba(255,255,255,0.85);--text-primary:#1A2B3C;--text-secondary:#4A5E73;--text-muted:#6B8299;--accent-primary:#66a6ff;--accent-secondary:#89f7fe;--accent-light:#C8E3FF;--accent-gradient:linear-gradient(120deg,#89f7fe,#66a6ff);--accent-glow:rgba(102,166,255,0.18);--warm-beige:#FFF3E8;--warm-cream:#FFF8F0;--warm-gold:#FF9F43;--success:#2ed573;--warning:#ffa502;--danger:#ff4757;--info:#70a1ff;--border-color:rgba(102,166,255,0.12);--border-hover:rgba(102,166,255,0.25);--font-primary:"Noto Sans JP",sans-serif;--font-serif:"Noto Serif JP","Cormorant Garamond",serif;--font-display:"Cormorant Garamond","Noto Serif JP",serif;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:2rem;--font-size-4xl:2.5rem;--font-size-5xl:3.5rem;--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--space-4xl:6rem;--radius-sm:0.375rem;--radius-md:0.75rem;--radius-lg:1rem;--radius-xl:1.5rem;--radius-2xl:2rem;--radius-full:9999px;--shadow-sm:0 1px 3px rgba(102,166,255,0.08),0 1px 2px rgba(0,0,0,0.03);--shadow-md:0 4px 16px rgba(102,166,255,0.10),0 2px 6px rgba(0,0,0,0.03);--shadow-lg:0 10px 30px rgba(102,166,255,0.12),0 4px 12px rgba(0,0,0,0.04);--shadow-xl:0 20px 50px rgba(102,166,255,0.15);--transition-fast:0.15s ease;--transition-base:0.3s ease;--transition-slow:0.5s ease;--max-width:1200px;--header-height:72px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body,html{overflow-x:hidden}body{font-family:var(--font-primary);background:var(--bg-primary);color:var(--text-primary);line-height:1.8;min-height:100vh}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 24;vertical-align:text-bottom;line-height:1;display:inline-block}.material-symbols-outlined.icon-sm{font-size:14px;font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 20}.material-symbols-outlined.icon-md{font-size:20px}.material-symbols-outlined.icon-lg{font-size:28px}.material-symbols-outlined.icon-xl{font-size:48px;font-variation-settings:"FILL" 0,"wght" 200,"GRAD" 0,"opsz" 48}.material-symbols-outlined.icon-filled{font-variation-settings:"FILL" 1,"wght" 300,"GRAD" 0,"opsz" 24}a{color:var(--accent-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-secondary)}img{max-width:100%;display:block}button{cursor:pointer;border:none;background:none}button,input,select,textarea{font-family:var(--font-primary);color:var(--text-primary)}input,select,textarea{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.75rem 1rem;font-size:var(--font-size-base);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;width:100%}input:focus,select:focus,textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg)}.glass{background:var(--bg-glass);backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);border:1px solid rgba(255,255,255,.45);border-radius:var(--radius-xl);box-shadow:var(--shadow-md),inset 0 1px 0 rgba(255,255,255,.5)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:.6rem 1.5rem;border-radius:var(--radius-full);font-weight:500;font-size:var(--font-size-sm);transition:all var(--transition-base);white-space:nowrap;letter-spacing:.02em}.btn-primary{background:var(--accent-gradient);color:white;box-shadow:0 4px 14px rgba(102,166,255,.3)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(102,166,255,.4)}.btn-secondary{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-tertiary);border-color:var(--border-hover)}.btn-lg{padding:.85rem 2rem;font-size:var(--font-size-base)}.badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:.25rem .75rem;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:700;letter-spacing:.03em;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 1px 4px rgba(0,0,0,.08)}.badge-success{color:#1d4ed8;border:1.5px solid #2563eb}.badge-success,.badge-warning{background:rgba(255,255,255,.92)}.badge-warning{color:#a06218;border:1.5px solid #c47d1e}.badge-danger{color:#a03030;border:1.5px solid #b44040}.badge-danger,.badge-muted{background:rgba(255,255,255,.92)}.badge-muted{color:#4a5060;border:1.5px solid #6b7280}.section-title{font-family:var(--font-serif);font-size:var(--font-size-2xl);font-weight:500;margin-bottom:var(--space-xl);color:var(--text-primary);display:flex;align-items:center;gap:var(--space-sm);letter-spacing:.04em}.section-title:after{content:"";flex:1 1;height:1px;background:linear-gradient(90deg,var(--border-color),transparent);margin-left:var(--space-md)}.watercolor-bg{position:relative}.watercolor-bg:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at 15% 20%,rgba(137,247,254,.15) 0,transparent 50%),radial-gradient(ellipse at 85% 60%,rgba(200,227,255,.3) 0,transparent 50%),radial-gradient(ellipse at 50% 90%,rgba(102,166,255,.08) 0,transparent 40%);pointer-events:none;z-index:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes softPulse{0%,to{opacity:.6}50%{opacity:1}}.animate-fadeInUp{animation:fadeInUp .7s cubic-bezier(.23,1,.32,1) forwards}.animate-fadeIn{animation:fadeIn .5s ease forwards}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--accent-light);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--accent-secondary)}@media (max-width:768px){:root{--font-size-5xl:2rem;--font-size-4xl:1.6rem;--font-size-3xl:1.35rem;--font-size-2xl:1.2rem;--space-2xl:2rem;--space-3xl:2.5rem;--space-4xl:3.5rem;--header-height:56px}.container{padding:0 var(--space-lg)}input,select,textarea{padding:.85rem 1rem;font-size:16px;border-radius:var(--radius-md)}.btn{padding:.7rem 1.4rem;font-size:var(--font-size-sm);min-height:44px}.btn-lg{padding:.85rem 1.8rem;font-size:var(--font-size-base);width:100%}.glass{border-radius:var(--radius-lg)}.section-title{font-size:var(--font-size-xl);margin-bottom:var(--space-lg)}.badge{font-size:.65rem;padding:.15rem .5rem}}.footer{margin-top:var(--space-4xl);border-top:1px solid var(--border-color);background:var(--warm-cream);padding:var(--space-3xl) 0 var(--space-xl);position:relative}.footer:before{content:"";position:absolute;top:0;left:0;right:0;height:200px;background:linear-gradient(180deg,var(--bg-primary),var(--warm-cream));pointer-events:none;transform:translateY(-100%)}.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;grid-gap:var(--space-2xl);gap:var(--space-2xl)}.footer-brand{max-width:280px}.footer-logo{display:inline-flex;align-items:center;gap:var(--space-sm);text-decoration:none;color:var(--text-primary);margin-bottom:var(--space-md)}.footer-logo .logo-icon{font-size:1.3rem}.footer-logo .logo-text{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:600;color:var(--accent-primary);letter-spacing:.04em}.footer-desc{color:var(--text-muted);font-size:var(--font-size-sm);line-height:1.9}.footer-links h4{font-family:var(--font-serif);font-size:var(--font-size-sm);font-weight:500;margin-bottom:var(--space-md);color:var(--text-primary);letter-spacing:.06em}.footer-links ul{list-style:none;display:flex;flex-direction:column;gap:var(--space-sm)}.footer-links a{color:var(--text-muted);font-size:var(--font-size-sm);transition:color var(--transition-fast)}.footer-links a:hover{color:var(--accent-primary)}.footer-bottom{margin-top:var(--space-2xl);padding-top:var(--space-lg);border-top:1px solid rgba(0,0,0,.05);text-align:center;color:var(--text-muted);font-size:var(--font-size-xs);letter-spacing:.04em}@media (max-width:768px){.footer-grid{grid-template-columns:1fr 1fr;gap:var(--space-xl)}.footer-brand{grid-column:span 2;max-width:none}}@media (max-width:480px){.footer-grid{grid-template-columns:1fr}.footer-brand{grid-column:span 1}}.header{position:fixed;top:0;left:0;right:0;height:var(--header-height);z-index:1000;background:rgba(250,251,252,.78);backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);border-bottom:1px solid var(--border-color)}.header-inner{justify-content:space-between;height:100%}.header-inner,.header-logo{display:flex;align-items:center}.header-logo{gap:var(--space-sm);text-decoration:none;color:var(--text-primary)}.logo-icon{font-size:1.4rem}.logo-text{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:600;color:var(--accent-primary);letter-spacing:.04em}.header-nav{display:flex;align-items:center;gap:var(--space-xl)}.nav-link{color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:400;text-decoration:none;transition:color var(--transition-fast);position:relative;letter-spacing:.03em}.nav-link:hover{color:var(--accent-primary)}.nav-link:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:var(--accent-primary);transition:width var(--transition-base);border-radius:var(--radius-full)}.nav-link:hover:after{width:100%}.nav-login,.nav-user{margin-left:var(--space-sm)}.nav-user{display:flex;align-items:center;gap:var(--space-sm)}.nav-user-name{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:400;text-decoration:none;transition:color var(--transition-fast)}.nav-user-name:hover{color:var(--accent-primary)}.hamburger{display:none;flex-direction:column;gap:5px;padding:var(--space-sm);z-index:1001}.hamburger span{display:block;width:22px;height:1.5px;background:var(--text-primary);transition:all var(--transition-base);border-radius:var(--radius-full)}.hamburger.active span:first-child{transform:rotate(45deg) translate(5px,5px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}@media (max-width:768px){.hamburger{display:flex}.logo-text{font-size:var(--font-size-base)}.header-nav{position:fixed;top:0;right:-100%;width:min(280px,80vw);height:100vh;height:100dvh;background:var(--bg-secondary);flex-direction:column;padding:calc(var(--header-height) + var(--space-xl)) var(--space-xl) var(--space-xl);transition:right var(--transition-base);border-left:1px solid var(--border-color);gap:var(--space-xs);align-items:stretch;box-shadow:-10px 0 30px rgba(0,0,0,.05)}.header-nav.open{right:0}.nav-link{font-size:var(--font-size-base);padding:var(--space-md) 0;border-bottom:1px solid var(--border-color)}.nav-link:after{display:none}.nav-user{flex-direction:column;margin-left:0;margin-top:var(--space-md);gap:var(--space-sm)}.nav-user-name{font-size:var(--font-size-sm)}.nav-login{margin-left:0;margin-top:var(--space-md);width:100%;text-align:center;min-height:44px;display:flex;align-items:center;justify-content:center}}