
/* ===== SHARED: Header ===== */
.header{position:fixed!important;top:0;left:0;right:0;z-index:1000;transition:box-shadow .3s;background:var(--white);border-bottom:none;padding:0}
.header-inner{display:none}
body{padding-top:59px}
.header-top{display:none!important;background:#1E2D3D;color:rgba(255,255,255,.75);font-size:.6875rem}
.header-top-inner{max-width:var(--max-w);margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:36px}
.header-top-left{display:flex;gap:24px}
.header-top-left a{color:rgba(255,255,255,.7);transition:color .3s;padding:4px 0;border-bottom:1px solid transparent}
.header-top-left a:hover{color:#fff;border-bottom-color:rgba(255,255,255,.3)}
.header-top-right{display:flex;gap:12px;align-items:center}
.header-top-btn{padding:5px 14px;border-radius:3px;font-size:.625rem;font-weight:700;letter-spacing:.05em;transition:all .3s}
.header-top-btn-torisetsu{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.35)}
.header-top-btn-torisetsu:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.6)}
.header-top-btn-company{background:transparent;color:#F0B441;border:1px solid rgba(240,180,65,.45)}
.header-top-btn-company:hover{background:#F0B441;color:#1E2D3D}
.header-top-social{color:rgba(255,255,255,.5);transition:color .3s;display:flex;align-items:center;justify-content:center;width:24px;height:24px}
.header-top-social:hover{color:#fff}
.header-top-btn-cta{background:var(--accent);color:#fff;border:1px solid var(--accent)}
.header-top-btn-cta:hover{background:var(--accent-hover);border-color:var(--accent-hover)}
.header-main{background:linear-gradient(180deg,rgba(255,255,255,.99),rgba(250,251,255,.98));backdrop-filter:blur(12px);border-bottom:1px solid var(--border);box-shadow:0 1px 4px rgba(30,45,61,.04)}
.header-main-inner{max-width:var(--max-w);margin:0 auto;padding:0 20px;display:flex;align-items:center;height:56px;gap:0}
.nav{display:flex;align-items:center;gap:0;flex:1;min-width:0}
.nav-link{font-size:.75rem;font-weight:500;color:var(--text);position:relative;padding:16px 12px;transition:color .3s;display:block;white-space:nowrap}
.nav-link:hover{color:#2EBF91;background:rgba(46,191,145,.04)}
.nav-link::after{content:'';position:absolute;bottom:0;left:12px;right:12px;height:2px;background:linear-gradient(90deg,#2EBF91,#4A8FD4,#9B7EC8,#F0B441);transform:scaleX(0);transition:transform .3s;border-radius:2px 2px 0 0}
.nav-link:hover::after{transform:scaleX(1)}
.nav-item{position:relative;flex-shrink:0}
.dropdown{display:none;position:absolute;top:100%;left:0;min-width:240px;background:var(--white);border:1px solid var(--border);border-radius:0 0 8px 8px;padding:8px 0;box-shadow:0 12px 32px rgba(0,0,0,.1)}
.nav-item:hover .dropdown{display:block}
.dropdown a{display:block;padding:10px 20px;font-size:.75rem;color:var(--text);transition:all .2s;border-left:3px solid transparent}
.dropdown a:hover{background:var(--light-bg);color:var(--main);border-left-color:var(--main)}
.header-cta-group{display:flex;gap:8px;align-items:center;flex-shrink:0;margin-left:auto}
.header-cta-group .btn{padding:8px 16px;font-size:.6875rem}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px;z-index:1002;position:relative}
.hamburger span{display:block;width:24px;height:2px;background:var(--text);margin:5px 0;transition:.3s}
.hamburger.active span:nth-child(1){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)}
.mobile-nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1000;opacity:0;transition:opacity .3s}
.mobile-nav-overlay.active{display:block;opacity:1}
.nav.mobile-open{display:flex!important;flex-direction:column;position:fixed;top:0;right:0;width:320px;max-width:85vw;height:100vh;background:var(--white);z-index:1001;padding:80px 24px 24px;overflow-y:auto;transform:translateX(100%);transition:transform .3s}
.nav.mobile-open.slide-in{transform:translateX(0)}
.nav.mobile-open .nav-item{border-bottom:1px solid var(--border)}
.nav.mobile-open .nav-link{padding:16px 0;font-size:.9375rem;white-space:normal}
.nav.mobile-open .nav-link::after{display:none}
.nav.mobile-open .dropdown{display:block;position:static;border:none;border-radius:0;box-shadow:none;padding:0 0 8px 16px;min-width:auto}
.nav.mobile-open .dropdown a{padding:10px 0;font-size:.8125rem;border-left:2px solid var(--main);padding-left:12px}
.mobile-menu-cta{display:none;margin-top:24px;padding-top:24px;border-top:1px solid var(--border)}
.nav.mobile-open .mobile-menu-cta{display:flex;flex-direction:column;gap:12px}
.mobile-menu-cta .btn{width:100%;text-align:center;justify-content:center}
/* ===== Logo: Header ===== */
.logo{display:flex;align-items:center;flex-shrink:0;margin-right:24px;text-decoration:none}
img.logo-full{height:36px;width:auto;max-height:36px;display:inline-block}
/* ===== Logo: Footer ===== */
.footer-logo-block{display:flex;align-items:center}
img.footer-logo-full{height:40px;width:auto;max-height:40px;display:inline-block;filter:brightness(0) invert(1)}
@keyframes torisetsu-pulse{0%,100%{box-shadow:0 0 0 0 rgba(255,255,255,.15)}50%{box-shadow:0 0 0 4px rgba(255,255,255,.08)}}
/* ===== SHARED: Buttons ===== */
.btn-primary{background:linear-gradient(135deg,#2EBF91,#1A9B73);color:var(--white);border-color:transparent}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(46,191,145,.3)}
.btn-secondary{background:var(--main);color:var(--white)}.btn-secondary:hover{background:var(--main-dark)}
.btn-outline{background:transparent;color:var(--accent);border:2px solid var(--accent)}.btn-outline:hover{background:var(--accent);color:var(--white)}
.btn-sm{padding:10px 24px;font-size:.875rem}
.btn-lg{padding:16px 40px;font-size:1rem}
/* ===== SHARED: Footer CTA ===== */
.footer-cta{background:linear-gradient(135deg,#1E2D3D 0%,#1A9B73 50%,#1E2D3D 100%);color:var(--white);text-align:center;padding:100px 0;position:relative;overflow:hidden}
.footer-cta::before{content:'';position:absolute;top:-50%;left:-20%;width:60%;height:200%;background:radial-gradient(ellipse,rgba(240,180,65,.08) 0%,transparent 60%)}

.footer-cta-blue{background:linear-gradient(135deg,#1E2D3D 0%,#3A7BBD 50%,#1E2D3D 100%)}
.footer-cta-rose{background:linear-gradient(135deg,#1E2D3D 0%,#C85060 50%,#1E2D3D 100%)}
.footer-cta-gold{background:linear-gradient(135deg,#1E2D3D 0%,#D4940A 50%,#1E2D3D 100%)}
.footer-cta-purple{background:linear-gradient(135deg,#1E2D3D 0%,#7A5EB0 50%,#1E2D3D 100%)}

/* --- Footer CTA Color Modifiers --- */
.footer-cta-title{font-size:clamp(1.25rem,2.5vw,1.75rem);font-weight:400;margin-bottom:8px;position:relative;z-index:1;line-height:1.8;color:var(--white)}
.footer-cta-sub{font-size:.9375rem;opacity:.8;margin-bottom:48px;position:relative;z-index:1}
.footer-cta-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}
.section-label{font-family:'Cormorant Garamond',serif;font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:12px}
.hero-torisetsu-link{display:inline-block;padding:10px 28px;font-size:.8125rem;border-radius:100px;border:1px solid rgba(240,180,65,.5);transition:all .3s;letter-spacing:.03em}
.hero-torisetsu-link:hover{background:rgba(240,180,65,.12);border-color:var(--accent)}
/* ===== SHARED: Footer ===== */
.footer{background:#141C28;color:rgba(255,255,255,.7);padding:80px 0 40px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:56px}
.footer-brand{display:flex;flex-direction:column;gap:16px}
.footer-brand .logo-text{color:var(--white)}
.footer-brand p{font-size:.8125rem;line-height:1.9}
.footer-social{display:flex;gap:16px;margin-top:16px}
.footer-social a{color:rgba(255,255,255,.4);transition:color .3s;display:flex;align-items:center;justify-content:center}
.footer-social a:hover{color:#fff}
.footer-nav-title{font-size:.75rem;color:var(--white);font-weight:500;margin-bottom:20px;letter-spacing:.05em}
.footer-nav a{display:block;font-size:.8125rem;padding:6px 0;transition:color .3s}
.footer-nav a:hover{color:var(--white)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:32px;border-top:1px solid rgba(255,255,255,.08);font-size:.6875rem}
.footer-bottom a{transition:color .3s}.footer-bottom a:hover{color:var(--white)}
/* ===== SHARED: FAQ ===== */
.faq-section{background:var(--white)}
.faq-list{max-width:720px;margin:0 auto 48px}
.faq-item{border-bottom:1px solid var(--border)}
.faq-question{width:100%;background:none;border:none;padding:24px 0;font-size:.9375rem;font-weight:500;color:var(--text);text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-family:'Zen Kaku Gothic New',sans-serif;line-height:1.7}
.faq-question::after{content:'+';font-size:1.25rem;color:var(--main);flex-shrink:0;margin-left:16px}
.faq-item.active .faq-question::after{content:'\2212'}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease}
.faq-item.active .faq-answer{max-height:500px;padding-bottom:24px}
.faq-answer p{font-size:.875rem;color:var(--text-light);line-height:2}
/* ===== SHARED: Mobile CTA ===== */
.mobile-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:999;background:var(--white);border-top:1px solid var(--border);padding:10px 16px;gap:6px;box-shadow:0 -4px 16px rgba(0,0,0,.08)}
.mobile-cta .btn{flex:1;padding:12px 8px;font-size:.8125rem}
.mobile-cta .btn-line{background:#06C755;color:#fff;border-color:#06C755}
/* ===== SHARED: Side CTA (right floating bar) ===== */
.side-cta{position:fixed;right:0;top:50%;transform:translateY(-50%);z-index:998;display:flex;flex-direction:column;gap:0;border-radius:12px 0 0 12px;overflow:hidden;box-shadow:-4px 0 24px rgba(0,0,0,.08);opacity:0.95;transition:opacity .3s}
.side-cta:hover{opacity:1}
.side-cta a{display:flex;padding:16px 12px;font-size:.6875rem;font-weight:700;writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:.15em;text-align:center;transition:all .3s;min-height:120px;align-items:center;justify-content:center}
.side-cta-primary{background:var(--accent);color:var(--white)}
.side-cta-primary:hover{background:var(--accent-hover)}
/* side-cta-secondary, tertiary 削除済（2026.04.03 AD添削） */
.side-cta-line{background:#06C755;color:#fff;min-height:auto!important;padding:16px 16px!important;letter-spacing:.08em!important}
.side-cta-line:hover{background:#05b04c}
.side-cta-line svg{width:20px;height:20px;fill:#fff}
.scout-side-tab{position:fixed;right:0;bottom:60px;z-index:997;background:#4A8FD4;color:#fff;font-size:.6875rem;font-weight:700;writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:.15em;padding:16px 0;width:44px;border-radius:12px 0 0 12px;text-decoration:none;box-shadow:-4px 0 24px rgba(0,0,0,.08);transition:background .3s;min-height:120px;display:flex;align-items:center;justify-content:center}
.scout-side-tab:hover{background:#3d7fbe}
/* ===== SHARED: Section & Animation ===== */
.section-header{text-align:center;margin-bottom:80px}
.section-title{font-size:clamp(1.5rem,3vw,2rem);font-weight:600;margin-bottom:20px}
.fade-in{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* ===== ART DIRECTION SYSTEM ===== */

/* --- Scroll Reveal --- */
.art-reveal{opacity:0;transform:translateY(40px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.art-reveal.is-visible{opacity:1;transform:none}
.art-reveal-left{opacity:0;transform:translateX(-40px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.art-reveal-left.is-visible{opacity:1;transform:none}
.art-reveal-right{opacity:0;transform:translateX(40px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.art-reveal-right.is-visible{opacity:1;transform:none}
.art-reveal-scale{opacity:0;transform:scale(.92);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.art-reveal-scale.is-visible{opacity:1;transform:none}
.art-delay-1{transition-delay:.15s}.art-delay-2{transition-delay:.3s}.art-delay-3{transition-delay:.45s}.art-delay-4{transition-delay:.6s}

/* --- Immersive Page Hero --- */
.art-hero{position:relative;min-height:48vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background:#1E2D3D}
.art-hero-full{min-height:60vh}
.art-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 40%;opacity:1;filter:none}
.art-hero-photo .art-hero-bg{opacity:.35;filter:saturate(.6)}
.art-hero-photo::after{background:linear-gradient(180deg,rgba(0,0,0,.05) 0%,rgba(0,0,0,.25) 60%,rgba(0,0,0,.45) 100%)!important}
.art-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.02) 0%,rgba(0,0,0,.08) 60%,rgba(0,0,0,.15) 100%);pointer-events:none}

.art-hero-blue{background:linear-gradient(135deg,#2D5A9E 0%,#4A8FD4 45%,#6BA8E0 100%)}
.art-hero-blue::after{background:linear-gradient(180deg,rgba(74,143,212,.05) 0%,rgba(74,143,212,.12) 60%,rgba(74,143,212,.2) 100%)!important}
.art-hero-rose{background:linear-gradient(135deg,#C85060 0%,#E06070 45%,#FFAA7A 100%)}
.art-hero-rose::after{background:linear-gradient(180deg,rgba(224,96,112,.05) 0%,rgba(224,96,112,.12) 60%,rgba(224,96,112,.2) 100%)!important}
.art-hero-gold{background:linear-gradient(135deg,#D4940A 0%,#F0B441 45%,#FFCC6A 100%)}
.art-hero-gold::after{background:linear-gradient(180deg,rgba(240,180,65,.05) 0%,rgba(240,180,65,.12) 60%,rgba(240,180,65,.2) 100%)!important}
.art-hero-purple{background:linear-gradient(135deg,#7A5EB0 0%,#9B7EC8 45%,#B89FD8 100%)}
.art-hero-purple::after{background:linear-gradient(180deg,rgba(155,126,200,.05) 0%,rgba(155,126,200,.12) 60%,rgba(155,126,200,.2) 100%)!important}
.art-hero-dark{background:linear-gradient(135deg,#1E2D3D 0%,#2D4050 45%,#3D5060 100%)}
.art-hero-dark::after{background:linear-gradient(180deg,rgba(30,45,61,.05) 0%,rgba(30,45,61,.12) 60%,rgba(30,45,61,.2) 100%)!important}

/* --- Hero Color Modifiers --- */
.art-hero-content{position:relative;z-index:2;padding:0 24px;max-width:760px}
.art-hero-content.art-reveal{animation:hero-fallback .9s .3s both}
@keyframes hero-fallback{to{opacity:1;transform:none}}
.art-hero-label{font-family:'Cormorant Garamond',serif;font-size:.8125rem;letter-spacing:.35em;text-transform:uppercase;color:rgba(240,180,65,.8);margin-bottom:20px}
.art-hero-kana{font-family:'Klee One',cursive;font-size:clamp(.8rem,1.5vw,.9375rem);color:rgba(255,255,255,.5);letter-spacing:.25em;margin-bottom:12px}
.art-hero-title{font-family:'Zen Old Mincho',serif;font-size:clamp(1.35rem,3.2vw,2.25rem);font-weight:600;color:#fff;line-height:1.8;margin-bottom:24px;text-shadow:0 2px 40px rgba(0,0,0,.3)}
.art-hero-sub{font-size:clamp(.8125rem,1.2vw,.9375rem);color:rgba(255,255,255,.75);line-height:2.2;max-width:560px;margin:0 auto}
.art-hero-line{width:1px;height:36px;background:linear-gradient(180deg,transparent,rgba(240,180,65,.5));margin:28px auto 0}
.art-hero-cta{margin-top:32px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap;position:relative;z-index:2}

/* --- Decorative Orbs --- */
.art-orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;z-index:1}
.art-orb-teal{background:rgba(46,191,145,.1)}
.art-orb-gold{background:rgba(240,180,65,.08)}
.art-orb-rose{background:rgba(224,96,112,.07)}

.art-orb-blue{background:rgba(74,143,212,.1)}
.art-orb-purple{background:rgba(155,126,200,.08)}


/* --- Sparkle Particles --- */
@keyframes art-sparkle{0%,100%{transform:translateY(0) scale(1);opacity:.3}50%{transform:translateY(-20px) scale(1.3);opacity:.7}}
.art-sparkle{position:absolute;width:4px;height:4px;background:var(--sub);border-radius:50%;z-index:1;animation:art-sparkle ease-in-out infinite}

/* --- Section Backgrounds --- */
.art-section{position:relative;overflow:hidden}
.art-section-warm{background:var(--off-white)}
.art-section-white{background:#fff}
.art-section-inner{max-width:780px;margin:0 auto;padding:0 24px}
.art-section-wide{max-width:1000px;margin:0 auto;padding:0 24px}
.art-pad{padding:100px 0}
.art-pad-lg{padding:120px 0}

/* --- Section Headers --- */
.art-section-en{font-family:'Cormorant Garamond',serif;font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;color:var(--sub);margin-bottom:8px}
.art-section-ja{font-family:'Zen Old Mincho',serif;font-size:.8125rem;font-weight:500;color:var(--heading);letter-spacing:.2em;margin-bottom:40px}
.art-section-title{font-family:'Zen Old Mincho',serif;font-size:clamp(1.25rem,2.8vw,1.75rem);font-weight:600;color:var(--heading);line-height:1.8;margin-bottom:40px}
.art-section-body{font-size:.9375rem;color:var(--text-light);line-height:2.4;max-width:620px;margin:0 auto;text-align:left}
.art-section-body p{margin-bottom:24px}

/* --- Watermark Text --- */
.art-watermark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Zen Old Mincho',serif;font-weight:700;color:rgba(46,191,145,.03);white-space:nowrap;pointer-events:none;z-index:0;letter-spacing:.1em;font-size:clamp(3rem,10vw,7rem)}
.art-watermark-en{font-family:'Cormorant Garamond',serif;font-size:clamp(3rem,10vw,6rem);font-weight:400;color:rgba(240,180,65,.08);letter-spacing:.08em}

/* --- Vertical Line Separator --- */
.art-vline-top::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:1px;height:80px;background:linear-gradient(180deg,var(--sub),transparent)}
.art-hline{width:48px;height:1px;background:linear-gradient(90deg,transparent,var(--sub),transparent);margin:0 auto}

/* --- Keyword Highlight Box --- */
.art-keyword{background:transparent;border-radius:0;padding:16px 0;margin:32px auto;max-width:560px;border-left:none;text-align:center}
.art-keyword-warm{background:transparent}
.art-keyword-term{font-family:'Klee One',cursive;font-size:.75rem;letter-spacing:.08em;color:var(--main);margin-bottom:4px;font-weight:400;opacity:.85}
.art-keyword-def{font-size:.8125rem;color:var(--text-light);line-height:2}

/* --- Quote Decoration --- */
.art-quote{position:relative;max-width:640px;margin:0 auto;padding:40px 24px}
.art-quote::before,.art-quote::after{position:absolute;font-family:'Cormorant Garamond',serif;font-size:4rem;color:rgba(46,191,145,.15);line-height:1}
.art-quote::before{content:'\201C';top:0;left:-8px}
.art-quote::after{content:'\201D';bottom:-8px;right:-8px}
.art-quote p{font-family:'Zen Old Mincho',serif;font-size:clamp(.9375rem,1.6vw,1.0625rem);color:var(--text-light);line-height:2.4;text-align:left}

/* --- Photo Strip --- */
.art-photo-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;overflow:hidden}
.art-photo-strip img{width:100%;aspect-ratio:4/3;object-fit:cover;filter:saturate(.85);transition:filter .6s}
.art-photo-strip img:hover{filter:saturate(1)}

/* --- Art Cards --- */
.art-card{background:var(--white);border-radius:16px;padding:40px 36px;border:1px solid var(--border);position:relative;overflow:hidden;transition:all .4s cubic-bezier(.16,1,.3,1)}
.art-card:hover{border-color:rgba(46,191,145,.3);box-shadow:0 16px 48px rgba(30,45,61,.08);transform:translateY(-4px)}
.art-card-accent::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--main),var(--sub));opacity:0;transition:opacity .4s}
.art-card-accent:hover::before{opacity:1}
.art-card-num{font-family:'Cormorant Garamond',serif;font-size:2.5rem;font-weight:400;line-height:1;margin-bottom:16px}
.art-card-title{font-family:'Zen Old Mincho',serif;font-size:1.125rem;font-weight:600;color:var(--heading);margin-bottom:12px;line-height:1.7}
.art-card-text{font-size:.875rem;color:var(--text-light);line-height:2.2}

/* --- Numbered List (like Values) --- */
.art-numbered{display:grid;grid-template-columns:64px 1fr;gap:32px;align-items:start;padding:48px 24px;text-align:left;position:relative;border-radius:12px;margin-bottom:12px;transition:background .4s}
.art-numbered:hover{background:rgba(46,191,145,.03)}
.art-numbered-num{font-family:'Cormorant Garamond',serif;font-size:2.5rem;font-weight:400;line-height:1;padding-top:4px;grid-row:1/span 4}
.art-numbered-title{font-family:'Zen Old Mincho',serif;font-size:1.25rem;font-weight:600;color:var(--heading);margin-bottom:8px;line-height:1.5;grid-column:2}
.art-numbered-en{font-family:'Cormorant Garamond',serif;font-size:.6875rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sub);margin-bottom:12px;grid-column:2}
.art-numbered-desc{grid-column:2}
.art-numbered-desc{font-size:.875rem;color:var(--text-light);line-height:2.2}

/* --- Closing Statement --- */
.art-closing{padding:120px 0 100px;text-align:center;position:relative;background:linear-gradient(180deg,#fff 0%,var(--off-white) 100%)}
.art-closing::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:48px;height:1px;background:linear-gradient(90deg,transparent,var(--sub),transparent)}
.art-closing-text{font-family:'Zen Old Mincho',serif;font-size:clamp(.9375rem,1.8vw,1.125rem);font-weight:500;color:var(--heading);line-height:2.4;max-width:560px;margin:0 auto;letter-spacing:.03em}

/* --- Number Colors --- */
.art-color-teal{color:var(--main)}.art-color-gold{color:var(--sub)}.art-color-rose{color:#E06070}

/* ===== ART DIRECTION: Responsive ===== */
@media(max-width:768px){
  .art-hero{min-height:40vh}
  .art-hero-full{min-height:55vh}
  .art-pad{padding:72px 0}
  .art-pad-lg{padding:80px 0}
  .art-orb{display:none}
  .art-numbered{grid-template-columns:48px 1fr;gap:20px;padding:36px 16px}
  .art-numbered-num{font-size:2rem}
  .art-keyword{padding:28px 20px;margin:32px auto}
  .art-photo-strip{grid-template-columns:1fr}
  .art-card{padding:28px 24px}
  .art-watermark,.art-watermark-en{display:none}
  .art-quote{padding:32px 16px}
  .art-closing{padding:80px 0 72px}
}
/* ===== SHARED: Responsive ===== */
@media(max-width:1024px){
  .side-cta{display:none}
  .scout-side-tab{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .header-top{display:none}
  .header-cta-group{display:none}
  .nav{display:none}
  .hamburger{display:block}
  .section-header{margin-bottom:48px}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .footer-bottom{flex-direction:column;gap:16px;text-align:center}
  .mobile-cta{display:flex}
  body{padding-bottom:80px;padding-top:60px}
  .page-hero{padding:60px 0 40px}
  .btn-lg{padding:16px 32px}
  .footer-cta-buttons{flex-direction:column;align-items:center;gap:12px}
}
