/* New inner pages: works, workshop, blog, contact */
.inner-section { padding: 92px 80px; }
.inner-section.alt { background: var(--beige); }
.inner-section.soft { background: var(--green-pale); }
.section-head { max-width: 680px; margin-bottom: 42px; }
.section-head.center { margin-left: auto; margin-right: auto; text-align: center; }
.section-head.center .sec-tag { justify-content: center; }
.section-intro { color: var(--ink-mid); font-size: 15.5px; line-height: 1.9; }
.page-hero .hero-note {
  display: inline-flex; align-items: center; gap: 8px; margin-top: 24px;
  padding: 9px 16px; border-radius: 30px; background: rgba(255,255,255,.6);
  color: var(--green-deep); font-size: 12px; letter-spacing: .08em;
}
.organic-card {
  background: white; border: 1px solid rgba(127,175,155,.16);
  border-radius: 26px; box-shadow: 0 16px 44px rgba(46,42,36,.06);
}
.quote-mark {
  font-family: 'Noto Serif TC', serif; font-size: 58px; line-height: .7;
  color: var(--terra); opacity: .45; display: block; margin-bottom: 18px;
}

/* Works */
.art-grid { columns: 3 260px; column-gap: 24px; }
.art-card { break-inside: avoid; margin-bottom: 24px; overflow: hidden; }
.art-visual {
  min-height: 230px; position: relative; display: grid; place-items: center;
  overflow: hidden; isolation: isolate; padding: 30px;
}
.art-visual::before, .art-visual::after {
  content: ''; position: absolute; border-radius: 48% 52% 66% 34%;
  filter: blur(1px); z-index: -1; transform: rotate(-12deg);
}
.art-visual::before { width: 72%; height: 62%; background: var(--paint-a); }
.art-visual::after { width: 54%; height: 46%; background: var(--paint-b); transform: translate(28px,22px) rotate(18deg); opacity: .8; }
.art-visual span { font-family: 'Noto Serif TC', serif; font-size: 24px; color: rgba(46,42,36,.7); text-align: center; line-height: 1.6; }
.art-visual.photo { padding: 0; }
.art-visual.photo::before, .art-visual.photo::after { display: none; }
.art-visual.photo img { width: 100%; height: 100%; min-height: inherit; object-fit: cover; display: block; transition: transform .45s ease; }
.art-card:hover .art-visual.photo img { transform: scale(1.025); }
.art-card:nth-child(2n) .art-visual { min-height: 310px; }
.art-card:nth-child(3n) .art-visual { min-height: 265px; }
.art-copy { padding: 24px 24px 26px; }
.art-meta { font-size: 10px; color: var(--green-dark); letter-spacing: .2em; text-transform: uppercase; margin-bottom: 10px; }
.art-copy p { font-family: 'Noto Serif TC', serif; font-size: 17px; line-height: 1.8; color: var(--ink); }
.story-strip { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; }
.story-card { padding: 28px 24px; min-height: 220px; display: flex; flex-direction: column; justify-content: space-between; }
.story-card:nth-child(3n+1) { background: var(--green-light); }
.story-card:nth-child(3n+2) { background: var(--terra-light); }
.story-card:nth-child(3n) { background: var(--yellow-light); }
.story-card p { font-family: 'Noto Serif TC', serif; font-size: 16px; line-height: 1.9; }
.story-card span { font-size: 11px; color: var(--ink-light); letter-spacing: .12em; }
.feedback-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.feedback-card {
  padding:30px 28px; position:relative; overflow:hidden;
}
.feedback-card::before {
  content:'“'; position:absolute; top:8px; right:22px;
  font-family:'Noto Serif TC',serif; font-size:76px; line-height:1;
  color:var(--green); opacity:.12;
}
.feedback-card p {
  font-family:'Noto Serif TC',serif; font-size:17px; line-height:1.9;
  color:var(--ink); position:relative;
}
.feedback-card span {
  display:block; margin-top:18px; color:var(--terra-dark);
  font-size:11px; letter-spacing:.14em;
}
.exhibit-grid { display: grid; grid-template-columns: repeat(3,1fr); grid-auto-rows: 250px; gap: 18px; }
.exhibit-card { border-radius: 26px; padding: 28px; position: relative; overflow: hidden; display: flex; align-items: flex-end; color: white; }
.exhibit-card:first-child { grid-column: span 2; grid-row: span 2; }
.exhibit-card:nth-child(6) { grid-column: span 2; }
.exhibit-card::before { content:''; position:absolute; inset:0; background: linear-gradient(150deg,var(--ex-a),var(--ex-b)); z-index:-2; }
.exhibit-card::after { content:''; position:absolute; width:170px; height:170px; border-radius:50%; background:rgba(255,255,255,.13); top:-55px; right:-35px; z-index:-1; }
.exhibit-card.photo { background:var(--photo) center / cover no-repeat; }
.exhibit-card.photo::before { background:linear-gradient(to top,rgba(28,28,24,.78),rgba(28,28,24,.04) 65%); z-index:0; }
.exhibit-card.photo::after { display:none; }
.exhibit-card.photo img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.exhibit-card.photo img + div { position:relative; z-index:2; }
.exhibit-card.photo:has(img)::before { z-index:1; }
.exhibit-card.photo > div { position:relative; z-index:1; }
.exhibit-card h3 { font-family:'Noto Serif TC',serif; font-size:24px; font-weight:400; margin-bottom:6px; }
.exhibit-card p { font-size:12px; color:rgba(255,255,255,.76); }

/* Workshop */
.intro-split { display:grid; grid-template-columns: .9fr 1.1fr; gap:72px; align-items:center; }
.intro-orbit { min-height:430px; border-radius:48% 52% 42% 58%; background:var(--green-light); position:relative; display:grid; place-items:center; padding:60px; }
.intro-orbit::before { content:''; position:absolute; inset:28px; border:1px dashed rgba(90,144,128,.32); border-radius:52% 48% 55% 45%; transform:rotate(9deg); }
.intro-orbit p { font-family:'Noto Serif TC',serif; font-size:25px; line-height:1.8; text-align:center; color:var(--green-deep); position:relative; }
.prose p { font-size:15px; color:var(--ink-mid); line-height:2; margin-bottom:16px; }
.prose strong { color:var(--terra-dark); font-weight:500; }
.sales-pages { background:var(--beige); }
.sales-pages-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:28px; align-items:start; max-width:1120px; margin:0 auto; }
.sales-page {
  overflow:hidden; padding:12px; background:white; border-radius:28px;
  border:1px solid rgba(127,175,155,.16); box-shadow:0 18px 48px rgba(46,42,36,.08);
}
.sales-page img { width:100%; height:auto; display:block; border-radius:19px; }
.sales-page-label { padding:14px 10px 6px; text-align:center; color:var(--ink-mid); font-size:12px; letter-spacing:.12em; }
.learn-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:16px; }
.learn-card { padding:28px 22px; }
.learn-num { font-family:'Noto Serif TC',serif; font-size:32px; color:var(--green); margin-bottom:24px; }
.learn-card h3 { font-size:15px; line-height:1.7; font-weight:500; }
.guide-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.guide-card { padding:32px; }
.guide-icon { font-size:24px; margin-bottom:20px; }
.guide-card h3 { font-family:'Noto Serif TC',serif; font-size:20px; font-weight:400; margin-bottom:12px; }
.guide-card p { color:var(--ink-mid); font-size:13.5px; line-height:1.9; }
.faq-list { max-width:820px; margin:0 auto; }
.faq-item { border-bottom:1px solid var(--beige-dark); padding:24px 0; }
.faq-item summary { cursor:pointer; list-style:none; font-family:'Noto Serif TC',serif; font-size:19px; display:flex; justify-content:space-between; gap:20px; }
.faq-item summary::after { content:'＋'; color:var(--terra); }
.faq-item[open] summary::after { content:'−'; }
.faq-item p { padding-top:16px; color:var(--ink-mid); font-size:14px; line-height:1.9; max-width:700px; }
.gift-card { display:flex; justify-content:space-between; gap:30px; align-items:center; padding:34px 40px; background:var(--yellow-light); border-radius:24px; margin-top:36px; }
.gift-card h3 { font-family:'Noto Serif TC',serif; font-size:22px; font-weight:400; margin-bottom:8px; }
.gift-card p { color:var(--ink-mid); font-size:13.5px; line-height:1.8; }

/* Blog */
.category-nav { display:flex; flex-wrap:wrap; gap:10px; margin-top:28px; }
.category-nav a { text-decoration:none; color:var(--green-deep); background:white; padding:10px 17px; border-radius:24px; font-size:12px; border:1px solid rgba(127,175,155,.22); }
.featured-post { display:grid; grid-template-columns:1.05fr .95fr; overflow:hidden; margin-bottom:42px; }
.post-art { min-height:360px; background:linear-gradient(140deg,var(--green),var(--green-deep)); position:relative; overflow:hidden; display:grid; place-items:center; padding:40px; }
.post-art::before,.post-art::after { content:''; position:absolute; border:2px solid rgba(255,255,255,.24); border-radius:50%; }
.post-art::before { width:280px;height:280px;transform:translate(-70px,80px); }
.post-art::after { width:170px;height:170px;transform:translate(110px,-95px); }
.post-art span { color:white; font-family:'Noto Serif TC',serif; font-size:32px; line-height:1.6; text-align:center; position:relative; }
.post-copy { padding:50px; display:flex; flex-direction:column; justify-content:center; }
.post-tag { font-size:10px; color:var(--terra-dark); letter-spacing:.2em; margin-bottom:14px; }
.post-copy h2,.post-card h3 { font-family:'Noto Serif TC',serif; font-weight:400; line-height:1.6; }
.post-copy h2 { font-size:28px; margin-bottom:16px; }
.post-copy p,.post-card p { color:var(--ink-mid); font-size:13.5px; line-height:1.9; }
.read-more { margin-top:20px; color:var(--green-dark); text-decoration:none; font-size:12px; letter-spacing:.08em; }
.post-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.post-card { padding:28px; }
.post-card { display:block; text-decoration:none; color:inherit; transition:transform .25s ease, box-shadow .25s ease; }
.post-card:hover { transform:translateY(-4px); box-shadow:0 20px 52px rgba(46,42,36,.09); }
.post-card h3 { font-size:19px; margin-bottom:12px; }
.blog-post-grid .post-card { min-height:260px; }
.blog-featured .post-art { background:radial-gradient(circle at 78% 28%, rgba(244,215,135,.5), transparent 24%), linear-gradient(140deg,var(--green-deep),var(--green)); }
.blog-featured .blog-handdrawn-art {
  background:
    radial-gradient(circle at 18% 20%, rgba(255,255,255,.72), transparent 28%),
    radial-gradient(circle at 78% 82%, rgba(244,215,135,.28), transparent 28%),
    linear-gradient(145deg,#f6f0e4,#e9f2ec 52%,#f3e0d6);
  color:var(--green-deep);
}
.blog-featured .blog-handdrawn-art::before {
  inset:0; width:auto; height:auto; transform:none; border:0; border-radius:0;
  background:repeating-linear-gradient(0deg,rgba(90,144,128,.06) 0 1px,transparent 1px 22px);
  opacity:.55;
}
.blog-featured .blog-handdrawn-art::after {
  inset:0; width:auto; height:auto; transform:none; border:0; border-radius:0;
  background:
    radial-gradient(circle at 24% 35%, rgba(127,175,155,.08) 0 2px, transparent 3px),
    radial-gradient(circle at 72% 64%, rgba(193,122,90,.07) 0 1.5px, transparent 3px);
  background-size:28px 28px,34px 34px;
  opacity:.7;
}
.blog-handdrawn-art svg { position:absolute; inset:18px 20px 12px; width:calc(100% - 40px); height:calc(100% - 30px); z-index:1; }
.blog-handdrawn-art span {
  z-index:2; color:var(--green-deep); background:rgba(255,250,241,.82);
  border:1.5px solid rgba(90,144,128,.22); border-radius:28px 22px 30px 20px;
  padding:18px 28px; box-shadow:0 16px 34px rgba(46,42,36,.08);
}
.blog-handdrawn-art .wash { opacity:.72; filter:blur(.2px); }
.blog-handdrawn-art .wash-green { fill:#b8d8c2; }
.blog-handdrawn-art .wash-yellow { fill:#f4d787; }
.blog-handdrawn-art .wash-terra { fill:#e8b6a1; }
.blog-handdrawn-art .ink,.blog-handdrawn-art .thin {
  fill:none; stroke:#3d3a33; stroke-linecap:round; stroke-linejoin:round;
}
.blog-handdrawn-art .ink { stroke-width:4.6; opacity:.78; }
.blog-handdrawn-art .thin { stroke-width:2.4; opacity:.52; }
.blog-handdrawn-art .paper-left { fill:rgba(255,250,241,.78); stroke:#3d3a33; stroke-width:2.2; opacity:.78; }
.blog-handdrawn-art .paper-right { fill:rgba(255,255,255,.72); stroke:#3d3a33; stroke-width:2.2; opacity:.76; }
.blog-handdrawn-art .fill-green { fill:#7faf9b; stroke:#3d3a33; stroke-width:3; opacity:.9; }
.blog-handdrawn-art .pencil { fill:#e8c767; stroke:#3d3a33; stroke-width:3.3; stroke-linejoin:round; }
.blog-handdrawn-art .pencil-tip { fill:#c17a5a; stroke:#3d3a33; stroke-width:3.3; stroke-linejoin:round; }
.blog-handdrawn-art .terra-line,.blog-handdrawn-art .spark { fill:none; stroke:#c17a5a; stroke-width:3; stroke-linecap:round; }
.blog-handdrawn-art .dot-a { fill:#c17a5a; opacity:.8; }
.blog-handdrawn-art .dot-b { fill:#7faf9b; opacity:.78; }
.pending-topic-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.pending-topic-card { padding:30px; }
.pending-topic-card h3 { font-family:'Noto Serif TC',serif; font-size:20px; font-weight:400; line-height:1.6; margin-bottom:16px; color:var(--green-deep); }
.pending-topic-card ul { display:grid; gap:12px; list-style:none; }
.pending-topic-card li { position:relative; padding-left:18px; color:var(--ink-mid); font-size:13.5px; line-height:1.7; }
.pending-topic-card li::before { content:''; position:absolute; left:0; top:.72em; width:6px; height:6px; border-radius:50%; background:var(--terra); }

/* Blog article */
.blog-article-page { background:var(--cream); padding-top:70px; }
.blog-article-hero {
  padding:86px 80px 58px;
  background:radial-gradient(circle at 14% 20%, rgba(127,175,155,.22), transparent 30%), linear-gradient(135deg,var(--green-pale),var(--cream) 58%,var(--terra-light));
  text-align:center;
}
.blog-article-hero .back-link {
  display:inline-flex; color:var(--green-deep); text-decoration:none;
  font-size:13px; margin-bottom:28px;
}
.blog-article-hero .post-tag { margin-bottom:16px; }
.blog-article-hero h1 {
  max-width:920px; margin:0 auto 20px;
  font-family:'Noto Serif TC',serif; font-size:clamp(34px,5vw,58px);
  font-weight:500; line-height:1.35; color:var(--ink);
}
.blog-article-hero p { max-width:720px; margin:0 auto; color:var(--ink-mid); font-size:16px; line-height:2; }
.blog-article-body { padding:70px 80px 96px; }
.blog-prose { max-width:860px; margin:0 auto; padding:54px 64px; }
.blog-prose h2,.blog-prose h3 {
  font-family:'Noto Serif TC',serif; font-weight:500; color:var(--ink);
  line-height:1.55; margin:34px 0 16px;
}
.blog-prose h2 { font-size:30px; }
.blog-prose h3 { font-size:24px; color:var(--green-deep); }
.blog-prose p,.blog-prose li { color:var(--ink-mid); font-size:16px; line-height:2.05; }
.blog-prose p { margin-bottom:16px; }
.blog-prose ul { list-style:none; display:grid; gap:10px; margin:16px 0 22px; }
.blog-prose li { position:relative; padding-left:22px; }
.blog-prose li::before { content:''; position:absolute; left:0; top:16px; width:8px; height:8px; border-radius:50%; background:var(--terra); }
.blog-prose hr { border:0; border-top:1px solid var(--beige-dark); margin:34px 0; }
.article-table { overflow:auto; margin:20px 0 26px; }
.article-table table { width:100%; border-collapse:collapse; min-width:560px; background:var(--cream); border-radius:18px; overflow:hidden; }
.article-table td { border:1px solid var(--beige-dark); padding:14px 16px; color:var(--ink-mid); font-size:13.5px; line-height:1.7; vertical-align:top; }
.article-nav-links {
  max-width:860px; margin:28px auto 0; display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap;
}
.article-nav-links a {
  text-decoration:none; color:var(--green-deep); background:white; border:1px solid rgba(127,175,155,.2);
  border-radius:999px; padding:10px 16px; font-size:13px;
}

/* Little Days */
.little-days-page { background:var(--cream); padding-top:70px; }
.little-hero {
  padding:92px 80px 72px;
  background:
    radial-gradient(circle at 12% 20%, rgba(244,215,135,.36), transparent 26%),
    radial-gradient(circle at 84% 78%, rgba(127,175,155,.22), transparent 30%),
    linear-gradient(135deg,var(--green-pale),var(--cream) 58%,var(--terra-light));
}
.little-hero-inner { max-width:1180px; margin:0 auto; display:grid; grid-template-columns:1.04fr .96fr; gap:62px; align-items:center; }
.little-hero-copy h1 { font-family:'Noto Serif TC',serif; font-size:clamp(48px,7vw,88px); font-weight:500; color:var(--green-deep); line-height:1.1; margin:16px 0; }
.little-hero-lead { font-family:'Noto Serif TC',serif; color:var(--ink); font-size:clamp(25px,3vw,38px); line-height:1.55; margin-bottom:18px; }
.little-hero-copy p:not(.little-hero-lead) { max-width:620px; color:var(--ink-mid); font-size:16px; line-height:2; }
.little-hero-actions { display:flex; flex-wrap:wrap; gap:12px; margin-top:28px; }
.little-hero-actions .btn-line {
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:13px 26px 13px 28px;
  border:1.5px solid rgba(127,175,155,.38);
  background:rgba(255,255,255,.72);
  color:var(--green-deep);
  font-family:var(--font-serif);
  font-size:15px;
  font-weight:500;
  letter-spacing:.05em;
  box-shadow:0 12px 32px rgba(90,144,128,.12);
}
.little-hero-actions .btn-line::after {
  content:'↓';
  display:grid;
  place-items:center;
  width:24px;
  height:24px;
  border-radius:50%;
  background:var(--green-pale);
  color:var(--green-dark);
  font-family:var(--font-sans);
  font-size:13px;
  line-height:1;
}
.little-hero-actions .btn-line:hover {
  transform:translateY(-2px);
  background:var(--white);
  border-color:rgba(193,122,90,.36);
  color:var(--terra-dark);
  box-shadow:0 16px 38px rgba(193,122,90,.14);
}
.little-hero-actions .btn-line:hover::after {
  background:var(--terra-light);
  color:var(--terra-dark);
}
.little-hero-card {
  min-height:430px; border-radius:42px; background:rgba(255,255,255,.78);
  border:1px solid rgba(127,175,155,.18); box-shadow:0 24px 70px rgba(46,42,36,.09);
  padding:36px; position:relative; overflow:hidden;
}
.little-day-illustration { height:250px; position:relative; border-radius:34px; background:linear-gradient(180deg,#f9f4ea,#edf6ef); overflow:hidden; }
.little-day-illustration .sun { position:absolute; width:70px; height:70px; border-radius:50%; background:#f4d787; top:32px; left:46px; box-shadow:0 0 0 14px rgba(244,215,135,.2); }
.little-day-illustration .hill { position:absolute; border-radius:50% 50% 0 0; bottom:-36px; }
.little-day-illustration .h1 { width:340px; height:165px; left:-44px; background:#b8d8c2; }
.little-day-illustration .h2 { width:280px; height:130px; right:-32px; background:#d6e7dc; }
.little-day-illustration .child-dot { position:absolute; width:22px; height:22px; border-radius:50%; background:#c17a5a; bottom:76px; box-shadow:0 30px 0 -7px #3d3a33; }
.little-day-illustration .c1 { left:150px; }
.little-day-illustration .c2 { left:210px; background:#7faf9b; bottom:92px; }
.little-day-illustration .c3 { left:270px; background:#e8c767; bottom:74px; }
.little-day-illustration .path-line { position:absolute; width:190px; height:64px; border-bottom:3px dashed rgba(90,144,128,.45); border-radius:50%; bottom:34px; left:120px; transform:rotate(-8deg); }
.little-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:20px; }
.little-stats div { background:var(--green-pale); border-radius:22px; padding:18px 12px; text-align:center; }
.little-stats strong { display:block; font-family:'Noto Serif TC',serif; font-size:28px; color:var(--green-deep); line-height:1; margin-bottom:8px; }
.little-stats span { color:var(--ink-mid); font-size:12px; line-height:1.5; }
.little-directory,.little-section { padding:88px 80px; }
.little-directory { background:white; }
.little-directory-grid { max-width:1120px; margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.little-directory-card { display:block; text-decoration:none; color:inherit; padding:28px; transition:transform .25s ease, box-shadow .25s ease; }
.little-directory-card:hover { transform:translateY(-4px); box-shadow:0 20px 54px rgba(46,42,36,.09); }
.little-directory-card span,.little-problem-card span,.little-feature-list span {
  display:inline-flex; color:var(--terra-dark); font-size:11px; letter-spacing:.18em; margin-bottom:16px;
}
.little-directory-card h3,.little-problem-card h3,.little-core-card h3,.little-feature-list h3 {
  font-family:'Noto Serif TC',serif; color:var(--ink); font-weight:500; line-height:1.55; margin-bottom:10px;
}
.little-directory-card h3 { font-size:21px; }
.little-directory-card p,.little-problem-card p,.little-core-card p,.little-feature-list p { color:var(--ink-mid); font-size:14px; line-height:1.9; }
.little-section.alt { background:var(--green-pale); }
.little-split { max-width:1160px; margin:0 auto; display:grid; grid-template-columns:.85fr 1.15fr; gap:56px; align-items:start; }
.little-copy p { color:var(--ink-mid); font-size:15.5px; line-height:2; }
.little-problem-grid { display:grid; gap:18px; }
.little-problem-card { padding:28px; }
.little-problem-card h3 { font-size:23px; }
.little-statement { max-width:860px; margin:0 auto 34px; text-align:center; }
.little-statement p { color:var(--ink-mid); font-size:16px; line-height:2; margin-bottom:14px; }
.little-statement blockquote { margin:28px auto 0; max-width:760px; padding:26px 32px; border-radius:28px; background:white; color:var(--green-deep); font-family:'Noto Serif TC',serif; font-size:18px; line-height:2; }
.little-pillars { max-width:1040px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.little-pillars div { background:white; border-radius:24px; padding:24px 20px; border:1px solid rgba(127,175,155,.16); }
.little-pillars span { color:var(--terra-dark); font-size:12px; letter-spacing:.12em; }
.little-pillars p { color:var(--ink-mid); font-size:14px; line-height:1.8; margin-top:10px; }
.little-core-grid { max-width:1120px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.little-core-card { padding:30px; }
.core-num { font-family:'Noto Serif TC',serif; color:var(--green); font-size:34px; margin-bottom:18px; }
.little-core-card h3 { font-size:24px; }
.little-core-card small { display:block; color:var(--ink-light); font-size:12px; line-height:1.8; margin-top:16px; padding-top:16px; border-top:1px solid var(--beige); }
.little-feature-head { max-width:1080px; margin:0 auto 34px; display:grid; grid-template-columns:.8fr 1.2fr; gap:40px; align-items:end; }
.little-feature-head p { color:var(--ink-mid); font-size:15px; line-height:2; }
.little-feature-list { max-width:1080px; margin:0 auto; display:grid; gap:14px; }
.little-feature-list article {
  display:grid; grid-template-columns:80px .72fr 1.18fr; gap:24px; align-items:center;
  padding:24px 28px; background:white; border-radius:24px; border:1px solid rgba(127,175,155,.16);
}
.little-feature-list h3 { font-size:22px; margin-bottom:0; }
.little-voice-grid { max-width:1080px; margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.little-voice-grid article { padding:32px; position:relative; overflow:hidden; }
.little-voice-grid article::before { content:'“'; position:absolute; top:4px; right:20px; font-family:'Noto Serif TC',serif; font-size:86px; color:var(--green); opacity:.12; }
.little-voice-grid p { color:var(--ink); font-family:'Noto Serif TC',serif; font-size:16px; line-height:2; position:relative; }
.little-voice-grid span { display:block; color:var(--terra-dark); font-size:12px; letter-spacing:.08em; margin-top:18px; }
.little-reserve { padding:84px 80px; background:var(--green-deep); color:white; text-align:center; }
.little-reserve > div { max-width:860px; margin:0 auto; }
.little-reserve .sec-tag { justify-content:center; color:rgba(255,255,255,.75); }
.little-reserve h2 { font-family:'Noto Serif TC',serif; font-size:clamp(30px,5vw,54px); font-weight:500; line-height:1.45; margin:18px 0; }
.little-reserve p { color:rgba(255,255,255,.74); font-size:15px; line-height:2; }
.little-reserve .little-hero-actions { justify-content:center; }

/* Contact */
.contact-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.studio-card { padding:34px; }
.studio-card h3 { font-family:'Noto Serif TC',serif; font-size:25px; font-weight:400; margin-bottom:18px; }
.studio-line { display:flex; gap:12px; color:var(--ink-mid); font-size:14px; line-height:1.7; margin-bottom:11px; }
.map-placeholder { margin-top:24px; height:180px; border-radius:20px; background:var(--green-light); position:relative; display:grid; place-items:center; overflow:hidden; }
.map-placeholder::before { content:''; position:absolute; inset:-30px; background:repeating-linear-gradient(35deg,transparent 0 34px,rgba(127,175,155,.22) 35px 38px); transform:rotate(-5deg); }
.map-placeholder span { position:relative; background:white; color:var(--green-deep); padding:9px 15px; border-radius:20px; font-size:12px; }
.line-banner { background:var(--green-deep); color:white; border-radius:28px; padding:42px 48px; display:flex; align-items:center; justify-content:space-between; gap:30px; }
.line-banner h2 { font-family:'Noto Serif TC',serif; font-size:28px; font-weight:400; margin-bottom:8px; }
.line-banner p { color:rgba(255,255,255,.7); font-size:13.5px; line-height:1.8; }
.form-wrap { display:grid; grid-template-columns:.75fr 1.25fr; gap:60px; align-items:start; }
.contact-form { padding:38px; }
.form-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.field.full { grid-column:1 / -1; }
.field label { display:block; font-size:12px; color:var(--ink-mid); margin-bottom:8px; }
.field input,.field select,.field textarea {
  width:100%; border:1px solid var(--beige-dark); border-radius:13px; padding:13px 14px;
  background:var(--cream); color:var(--ink); font-family:'Noto Sans TC',sans-serif; outline:none;
}
.field textarea { min-height:130px; resize:vertical; }
.field input:focus,.field select:focus,.field textarea:focus { border-color:var(--green); box-shadow:0 0 0 3px rgba(127,175,155,.12); }
.form-note { font-size:11px; color:var(--ink-light); line-height:1.7; margin-top:14px; }

/* Cross-page photo moments */
.site-photo-section { background:var(--cream); }
.site-photo-section.soft-green { background:var(--green-pale); }
.site-photo-grid {
  display:grid;
  grid-template-columns:1.08fr .92fr 1fr;
  gap:18px;
  align-items:stretch;
}
.site-photo-card {
  position:relative;
  min-height:280px;
  border-radius:34px;
  overflow:hidden;
  background:white;
  box-shadow:0 22px 55px rgba(46,42,36,.08);
  border:1px solid rgba(127,175,155,.16);
}
.site-photo-card.tall { min-height:430px; }
.site-photo-card.wide { grid-column:span 2; }
.site-photo-card img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform:scale(1.01);
}
.site-photo-caption {
  position:absolute;
  left:18px;
  right:18px;
  bottom:16px;
  padding:13px 16px;
  border-radius:20px;
  background:rgba(250,247,242,.86);
  backdrop-filter:blur(12px);
  color:var(--ink);
  box-shadow:0 12px 28px rgba(46,42,36,.08);
}
.site-photo-caption span {
  display:block;
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--green-deep);
  margin-bottom:4px;
}
.site-photo-caption strong {
  font-family:var(--font-serif);
  font-size:18px;
  font-weight:500;
}
.about-photo-accent {
  max-width:760px;
  margin:0 auto;
  display:grid;
  grid-template-columns:.8fr 1.2fr;
  gap:28px;
  align-items:center;
}
.about-photo-accent .site-photo-card {
  min-height:220px;
  border-radius:28px;
}
.about-photo-accent-copy p {
  color:var(--ink-mid);
  line-height:2;
  margin-top:12px;
}

@media (max-width: 1000px) {
  .inner-section { padding:72px 36px; }
  .story-strip,.learn-grid { grid-template-columns:repeat(2,1fr); }
  .story-card:last-child,.learn-card:last-child { grid-column:1 / -1; }
  .feedback-grid { grid-template-columns:repeat(2,1fr); }
  .pending-topic-grid { grid-template-columns:repeat(2,1fr); }
  .exhibit-grid { grid-template-columns:1fr 1fr; }
  .exhibit-card:first-child,.exhibit-card:nth-child(6) { grid-row:auto; grid-column:1 / -1; }
  .intro-split,.featured-post,.form-wrap { grid-template-columns:1fr; gap:36px; }
  .sales-pages-grid { gap:20px; }
  .guide-grid,.post-grid { grid-template-columns:repeat(2,1fr); }
  .little-hero,
  .little-directory,
  .little-section,
  .little-reserve { padding-left:36px; padding-right:36px; }
  .little-hero-inner,
  .little-split,
  .little-feature-head { grid-template-columns:1fr; gap:38px; }
  .little-directory-grid,
  .little-core-grid,
  .little-pillars,
  .little-voice-grid { grid-template-columns:repeat(2,1fr); }
  .little-feature-list article { grid-template-columns:64px 1fr; align-items:start; }
  .little-feature-list article p { grid-column:2; }
  .site-photo-grid { grid-template-columns:1fr 1fr; }
  .site-photo-card.wide { grid-column:1 / -1; }
  .about-photo-accent { grid-template-columns:1fr; max-width:560px; }
}
@media (max-width: 680px) {
  .inner-section { padding:58px 20px; }
  .page-hero { padding:58px 22px 50px; }
  .page-hero h1 { font-size:32px; }
  .sec-h2 { font-size:28px; }
  .art-grid { columns:1; }
  .story-strip,.learn-grid,.guide-grid,.post-grid,.contact-grid,.form-grid,.exhibit-grid,.feedback-grid,.pending-topic-grid { grid-template-columns:1fr; }
  .sales-pages-grid { grid-template-columns:1fr; }
  .story-card:last-child,.learn-card:last-child,.exhibit-card:first-child,.exhibit-card:nth-child(6),.field.full { grid-column:auto; }
  .intro-orbit { min-height:320px; padding:40px; }
  .intro-orbit p { font-size:21px; }
  .gift-card,.line-banner { align-items:flex-start; flex-direction:column; padding:30px 26px; }
  .post-art { min-height:260px; }
  .post-copy,.contact-form { padding:28px 24px; }
  .blog-article-page { padding-top:138px; }
  .blog-article-hero,.blog-article-body { padding-left:24px; padding-right:24px; }
  .blog-prose { padding:34px 24px; }
  .little-days-page { padding-top:138px; }
  .little-hero,
  .little-directory,
  .little-section,
  .little-reserve { padding-left:22px; padding-right:22px; }
  .little-hero { padding-top:62px; padding-bottom:54px; }
  .little-directory,
  .little-section { padding-top:64px; padding-bottom:64px; }
  .little-hero-card { min-height:auto; border-radius:30px; padding:24px; }
  .little-day-illustration { height:210px; border-radius:24px; }
  .little-stats,
  .little-directory-grid,
  .little-core-grid,
  .little-pillars,
  .little-voice-grid { grid-template-columns:1fr; }
  .little-directory-card,
  .little-core-card,
  .little-problem-card,
  .little-voice-grid article { padding:24px; }
  .little-feature-list article { grid-template-columns:1fr; gap:10px; padding:22px; }
  .little-feature-list article p { grid-column:auto; }
  .little-statement blockquote { padding:22px; font-size:16px; }
  .site-photo-grid { grid-template-columns:1fr; }
  .site-photo-card,
  .site-photo-card.tall { min-height:280px; }
  .site-photo-card.wide { grid-column:auto; }
  .about-photo-accent .site-photo-card { min-height:210px; }
}
