:root{--white: #FDFAF4;--off-white: #F5F0E8;--cream: #EDE3D0;--green-deep: #1A4731;--green-mid: #2D6A4F;--teal: #0D9488;--teal-light: #5EEAD4;--gold: #B5860D;--gold-light: #D4A017;--gold-shine: #F0C050;--text-dark: #1C1A16;--text-mid: #4B3F2A;--text-light: #7A6A50;--shadow-sm: 0 2px 8px rgba(26, 71, 49, .08);--shadow-md: 0 8px 32px rgba(26, 71, 49, .12);--shadow-lg: 0 20px 60px rgba(26, 71, 49, .16);--card-radius: 16px;--section-gap: clamp(28px, 4vw, 48px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:Noto Sans JP,sans-serif;background-color:var(--white);color:var(--text-dark);line-height:1.7;overflow-x:hidden}.container{max-width:1140px;margin:0 auto;padding:0 clamp(20px,5vw,60px)}.bg-pattern{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.geometric-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 15% 20%,rgba(181,134,13,.06) 0%,transparent 40%),radial-gradient(circle at 85% 80%,rgba(13,148,136,.06) 0%,transparent 40%),radial-gradient(circle at 50% 50%,rgba(45,106,79,.04) 0%,transparent 60%);background-size:100% 100%}.site-header{position:sticky;top:0;z-index:100;background:#fdfaf4d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(181,134,13,.2);transition:box-shadow .3s}.site-header.scrolled{box-shadow:var(--shadow-md)}.header-inner{display:flex;align-items:center;justify-content:space-between;height:52px}.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text-dark)}.logo-icon{width:36px;height:36px;flex-shrink:0}.logo-text{font-family:"Noto Serif JP",serif;font-size:1.1rem;font-weight:700;letter-spacing:.05em;color:var(--green-deep)}.site-nav{display:flex;gap:32px}.nav-link{font-size:.9rem;font-weight:500;color:var(--text-mid);text-decoration:none;position:relative;padding-bottom:2px;transition:color .3s}.nav-link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:1.5px;background:var(--gold);transition:width .3s ease}.nav-link:hover{color:var(--gold)}.nav-link:hover:after{width:100%}.hero{position:relative;min-height:38vh;display:flex;align-items:center;overflow:hidden;z-index:1}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#1a47310d,#b5860d0a)}.hero-inner{position:relative;z-index:2;padding-top:32px;padding-bottom:32px}.botanical-svg{position:absolute;bottom:0;width:clamp(160px,20vw,260px);height:auto;pointer-events:none;z-index:0}.botanical-svg--left{left:0;transform:translate(-30%)}.botanical-svg--right{right:0;transform:translate(30%) scaleX(-1)}@media(max-width:900px){.botanical-svg--left{transform:translate(-45%)}.botanical-svg--right{transform:translate(45%) scaleX(-1)}}@media(max-width:600px){.botanical-svg{display:none}}.hero-title{font-family:"Noto Serif JP",serif;font-size:clamp(1.8rem,4.5vw,3rem);font-weight:700;line-height:1.25;color:var(--green-deep);margin-bottom:12px;animation:fadeInUp .8s ease both}.hero-title .highlight{position:relative;color:var(--gold)}.hero-title .highlight:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--gold),var(--teal));transform-origin:left;animation:slideIn 1s .6s ease both}.hero-subtitle{font-size:clamp(.88rem,1.5vw,1rem);color:var(--text-mid);max-width:420px;margin-bottom:24px;animation:fadeInUp .8s .2s ease both}.btn-primary{display:inline-block;padding:11px 32px;background:linear-gradient(135deg,var(--green-deep),var(--green-mid));color:var(--gold-shine);text-decoration:none;font-weight:600;font-size:.9rem;letter-spacing:.05em;border-radius:50px;border:2px solid transparent;background-clip:padding-box;box-shadow:var(--shadow-md),inset 0 1px #f0c05033;transition:transform .25s,box-shadow .25s,background .25s;animation:fadeInUp .8s .35s ease both;position:relative;overflow:hidden}.btn-primary:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 40%,rgba(240,192,80,.15));opacity:0;transition:opacity .3s}.btn-primary:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.btn-primary:hover:before{opacity:1}.scroll-indicator{margin-top:60px;display:flex;justify-content:flex-start}.scroll-indicator span{display:block;width:1px;height:60px;background:linear-gradient(to bottom,var(--gold),transparent);animation:scrollLine 1.8s ease-in-out infinite}@keyframes scrollLine{0%,to{opacity:0;transform:scaleY(.5) translateY(-20px)}50%{opacity:1;transform:scaleY(1) translateY(0)}}.section-header{display:flex;align-items:center;gap:20px;margin-bottom:clamp(20px,3vw,32px)}.section-title{font-family:"Noto Serif JP",serif;font-size:clamp(1.2rem,2.2vw,1.6rem);font-weight:700;color:var(--green-deep);white-space:nowrap}.ornament{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--gold) 50%,transparent);position:relative}.ornament:after{content:"✿";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:12px;color:var(--gold);background:var(--white);padding:0 5px;line-height:1}.apps-section{position:relative;z-index:1;padding:var(--section-gap) 0}.apps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px}.app-card{background:var(--off-white);border-radius:120px 120px var(--card-radius) var(--card-radius);border:1.5px solid rgba(181,134,13,.2);box-shadow:var(--shadow-sm);transition:transform .35s ease,box-shadow .35s ease,border-color .35s;display:flex;flex-direction:column;position:relative;overflow:hidden}.app-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:#b5860d80}.card-arch{width:100%;aspect-ratio:1 / .55;border-radius:200px 200px 0 0;background:linear-gradient(160deg,var(--green-deep) 0%,var(--green-mid) 50%,var(--teal) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;flex-shrink:0}.card-arch:before{content:"";position:absolute;top:12px;right:12px;bottom:12px;left:12px;border-radius:200px 200px 0 0;border:1px solid rgba(240,192,80,.25);pointer-events:none}.card-arch:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 40%,rgba(240,192,80,.12) 0%,transparent 70%)}.card-arch-leaf{position:absolute;bottom:0;opacity:.35;pointer-events:none}.card-arch-leaf--left{left:0;transform:scaleX(-1)}.card-arch-leaf--right{right:0}.card-arch img{width:85%;height:85%;object-fit:cover;border-radius:180px 180px 0 0;position:relative;z-index:1}.card-arch-icon{font-size:2.8rem;line-height:1;position:relative;z-index:1;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.card-arch-ring{position:absolute;top:6px;right:6px;bottom:6px;left:6px;border-radius:200px 200px 0 0;border:1.5px solid rgba(240,192,80,.4);pointer-events:none;z-index:2;transition:border-color .3s}.app-card:hover .card-arch-ring{border-color:#f0c050b3}.card-body{padding:14px 20px 8px;flex:1;display:flex;flex-direction:column;gap:6px}.card-tags{display:flex;flex-wrap:wrap;gap:5px}.card-tag{font-size:.7rem;font-weight:500;padding:3px 10px;border-radius:50px;background:#0d94881a;color:var(--teal);border:1px solid rgba(13,148,136,.2);letter-spacing:.04em}.card-title{font-family:"Noto Serif JP",serif;font-size:1.08rem;font-weight:700;color:var(--green-deep);text-align:center}.card-divider{width:40px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:2px auto}.card-desc{font-size:.86rem;color:var(--text-light);line-height:1.75;flex:1;text-align:center}.card-footer{padding:0 20px 18px;display:flex;justify-content:center}.card-link{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600;color:var(--green-deep);text-decoration:none;border:1.5px solid rgba(26,71,49,.3);padding:9px 24px;border-radius:50px;background:transparent;transition:background .25s,color .25s,border-color .25s,transform .2s;letter-spacing:.03em}.card-link:hover{background:var(--green-deep);color:var(--gold-shine);border-color:var(--green-deep);transform:translateY(-2px)}.card-link svg{width:14px;height:14px;transition:transform .2s}.card-link:hover svg{transform:translate(3px)}.about-section{position:relative;z-index:1;padding:var(--section-gap) 0;background:linear-gradient(135deg,#1a47310a,#b5860d08);border-top:1px solid rgba(181,134,13,.15);border-bottom:1px solid rgba(181,134,13,.15)}.about-inner{display:grid;grid-template-columns:200px 1fr;align-items:center;gap:60px}.stained-glass-panel{width:180px;height:180px;flex-shrink:0;animation:rotatePanel 30s linear infinite;opacity:.85}@keyframes rotatePanel{to{transform:rotate(360deg)}}.about-text{display:flex;flex-direction:column;gap:12px}.about-text .ornament{max-width:200px;flex:none;width:100%}.about-text .section-title{text-align:left}.about-text p{font-size:.95rem;color:var(--text-mid)}.contact-links{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}.contact-link{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;border:1.5px solid rgba(26,71,49,.25);color:var(--green-deep);text-decoration:none;background:transparent;transition:background .25s,color .25s,border-color .25s,transform .2s}.contact-link:hover{background:var(--green-deep);color:var(--gold-shine);border-color:var(--green-deep);transform:translateY(-2px)}.contact-icon{width:20px;height:20px;flex-shrink:0}.contact-section{position:relative;z-index:1;padding:var(--section-gap) 0;background:linear-gradient(135deg,#1a47310a,#b5860d08);border-top:1px solid rgba(181,134,13,.15)}.contact-container{max-width:680px;margin:0 auto}.custom-form{background:var(--white);padding:40px;border-radius:var(--card-radius);border:1.5px solid rgba(181,134,13,.2);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-weight:700;color:var(--green-deep);font-size:.95rem;display:flex;align-items:center;gap:12px}.form-label .required,.form-label .optional{font-size:.7rem;padding:2px 8px;border-radius:4px;font-weight:600;letter-spacing:.05em}.form-label .required{background:#b5860d26;color:var(--gold);border:1px solid rgba(181,134,13,.3)}.form-label .optional{background:#0d94881a;color:var(--teal);border:1px solid rgba(13,148,136,.3)}.form-help{font-size:.8rem;color:var(--text-light);margin-top:-4px;margin-bottom:2px}.form-input{width:100%;padding:14px 16px;border-radius:8px;border:1.5px solid rgba(26,71,49,.15);background:var(--off-white);color:var(--text-dark);font-family:inherit;font-size:1rem;transition:all .3s ease;resize:vertical}.form-input:focus{outline:none;border-color:var(--gold);background:var(--white);box-shadow:0 0 0 4px #b5860d1a}.form-input::placeholder{color:#7a6a5080}.form-actions{display:flex;align-items:center;justify-content:space-between;margin-top:16px;gap:16px}.form-submit{cursor:pointer;border:none;padding:14px 48px;font-size:1.05rem}@media(max-width:600px){.custom-form{padding:24px}.form-actions{flex-direction:column-reverse}.form-submit{width:100%}}.site-footer{background:var(--green-deep);color:#f4eccab3;text-align:center;padding:40px 0;position:relative;z-index:1}.footer-ornament{width:120px;height:1px;background:linear-gradient(90deg,transparent,var(--gold-light),transparent);margin:0 auto 20px}.footer-copy{font-size:.85rem;letter-spacing:.06em}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInCard{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:translateY(0)}@media(max-width:768px){.hero{min-height:30vh}.stained-glass-accent{width:220px;height:220px;top:-20px;right:-40px}.about-inner{grid-template-columns:1fr;text-align:center;gap:30px}.stained-glass-panel,.about-text .ornament{margin:0 auto}.apps-grid{grid-template-columns:1fr}.site-nav{gap:20px}}@media(max-width:480px){.site-nav{display:none}.hero-title{font-size:1.8rem}}
