/* ===== TokyoLifeExperience — URBAN preset style.css ===== */
/* Modern city-magazine. Sans-serif + mono. Strict 0px corners. Cool light palette. */

.tle-progress { position: fixed; top: 0; left: 0; height: 2px; background: #FF3B30; z-index: 50; width: 0%; transition: width 0.1s linear; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.tle-skip-link { position: absolute; top: -40px; left: 0; background: #1B1B1A; color: #fff; padding: 8px 16px; z-index: 100; }
.tle-skip-link:focus { top: 0; }

.tle-wordmark { font-family: 'Bebas Neue', 'Inter', sans-serif; font-weight: 700; letter-spacing: -0.02em; color: #1B1B1A; line-height: 1; }
.tle-tagline { font-family: 'JetBrains Mono', monospace; color: #A8A8A4; letter-spacing: 0.1em; }

.tle-input,.tle-textarea,.tle-select { display: block; width: 100%; padding: 0.75rem 1rem; background: #fff; border: 1px solid #DDDCD6; font-family: inherit; font-size: 0.95rem; line-height: 1.5; color: #1B1B1A; box-sizing: border-box; border-radius: 0; }
.tle-input:focus { outline: none; border-color: #1B1B1A; box-shadow: 0 0 0 3px rgba(27,27,26,0.1); }
.tle-textarea { min-height: 140px; resize: vertical; }

.tle-newsletter-form { display: flex; gap: 0.5rem; max-width: 28rem; margin: 0 auto; align-items: stretch; }
.tle-newsletter-form .tle-input { flex: 1 1 auto; min-width: 0; }
.tle-newsletter-form button { flex: 0 0 auto; white-space: nowrap; cursor: pointer; border: 0; font-family: 'Bebas Neue', sans-serif; font-weight: 700; letter-spacing: 0.1em; padding: 0 1.5rem; color: #fff; background: #FF3B30; transition: background 150ms; border-radius: 0; }
.tle-newsletter-form button:hover { background: #1B1B1A; }
@media (max-width: 480px) { .tle-newsletter-form { flex-direction: column; } }

.tle-honeypot { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; pointer-events: none; opacity: 0; }

.tle-cookie { position: fixed; bottom: 1rem; left: 1rem; right: 1rem; z-index: 90; max-width: 720px; margin: 0 auto; background: #1B1B1A; color: #F5F5F4; padding: 1rem 1.25rem; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 0.85rem; }
.tle-cookie.hidden { display: none; }
.tle-cookie a { color: #FF3B30; text-decoration: underline; }
.tle-cookie-actions { display: flex; gap: 0.5rem; }
.tle-cookie button { padding: 0.6rem 1.25rem; font-family: 'Bebas Neue', sans-serif; font-weight: 700; letter-spacing: 0.1em; border: 0; cursor: pointer; }
.tle-cookie-accept { background: #FF3B30; color: #fff; }
.tle-cookie-reject { background: transparent; color: #D6D3D1; border: 1px solid #DDDCD6 !important; }
.tle-cookie-reject:hover { background: #292524; color: #fff; }

.tle-prose { font-family: 'Inter', 'Noto Sans JP', sans-serif; color: #1B1B1A; line-height: 1.85; font-size: 1rem; }
.tle-prose h2 { font-family: 'Noto Sans JP', sans-serif; font-weight: 900; font-size: 1.65rem; margin-top: 2.5rem; margin-bottom: 1.25rem; padding-left: 0.85rem; border-left: 4px solid #FF3B30; line-height: 1.4; }
.tle-prose h3 { font-weight: 700; font-size: 1.15rem; margin-top: 2rem; margin-bottom: 0.75rem; }
.tle-prose p { margin-bottom: 1.25rem; }
.tle-prose a { color: #FF3B30; text-decoration: underline; text-underline-offset: 3px; font-weight: 500; }
.tle-prose blockquote { border-left: 3px solid #FF3B30; padding-left: 1.25rem; margin: 2rem 0; font-style: italic; color: #4B4B48; }
.tle-prose ul, .tle-prose ol { margin: 1.25rem 0; padding-left: 1.5rem; }
.tle-prose ul li, .tle-prose ol li { margin-bottom: 0.5rem; }

.tle-pullquote { font-family: 'Noto Serif JP', serif; font-weight: 700; font-size: 1.4rem; line-height: 1.6; color: #1B1B1A; border-top: 2px solid #FF3B30; border-bottom: 2px solid #FF3B30; padding: 1.5rem 0; margin: 2.5rem 0; text-align: center; }

.tle-sidebar-fact { background: #FFFFFF; border: 1px solid #DDDCD6; padding: 1.25rem 1.5rem; margin: 2rem 0; }
.tle-sidebar-fact-label { font-family: 'JetBrains Mono', monospace; font-size: 0.7rem; letter-spacing: 0.15em; font-weight: 700; color: #FF3B30; margin-bottom: 0.5rem; text-transform: uppercase; }
.tle-sidebar-fact p { margin-bottom: 0.5rem; font-size: 0.95rem; }
.tle-sidebar-fact p:last-child { margin-bottom: 0; }

.tle-callout { background: #EEF2FB; border-left: 4px solid #0047AB; padding: 1.25rem 1.5rem; margin: 2rem 0; font-size: 0.95rem; color: #0047AB; }
.tle-callout-label { font-family: 'JetBrains Mono', monospace; font-size: 0.7rem; font-weight: 700; letter-spacing: 0.15em; margin-bottom: 0.5rem; text-transform: uppercase; }

.tle-data-strip { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: #DDDCD6; margin: 2rem 0; border: 1px solid #DDDCD6; }
@media (min-width: 768px) { .tle-data-strip { grid-template-columns: repeat(4, 1fr); } }
.tle-data-cell { background: #fff; padding: 1.25rem 1rem; text-align: center; }
.tle-data-num { font-family: 'Bebas Neue', sans-serif; font-weight: 700; font-size: 2.5rem; color: #FF3B30; line-height: 1; letter-spacing: 0.02em; }
.tle-data-label { font-family: 'JetBrains Mono', monospace; font-size: 0.7rem; letter-spacing: 0.05em; color: #6B6B68; margin-top: 0.4rem; }

.tle-numbered-list { counter-reset: nlist; padding-left: 0; list-style: none; margin: 1.5rem 0; }
.tle-numbered-list li { counter-increment: nlist; padding-left: 3rem; position: relative; margin-bottom: 1.5rem; }
.tle-numbered-list li::before { content: counter(nlist, decimal-leading-zero); position: absolute; left: 0; top: 0; font-family: 'Bebas Neue', sans-serif; font-weight: 700; font-size: 1.75rem; color: #FF3B30; }

.tle-spot-card { background: #F8F8F6; border-left: 4px solid #FF3B30; padding: 1.25rem 1.5rem; margin: 2rem 0; }
.tle-spot-card .tle-spot-meta { display: flex; gap: 0.75rem; align-items: baseline; margin-bottom: 0.5rem; }
.tle-spot-card .tle-spot-num { font-family: 'Bebas Neue', sans-serif; font-size: 1.5rem; color: #FF3B30; line-height: 1; }
.tle-spot-card .tle-spot-cat { font-family: 'JetBrains Mono', monospace; font-size: 0.7rem; letter-spacing: 0.1em; color: #6B6B68; text-transform: uppercase; }
.tle-spot-card h3 { font-weight: 900; font-size: 1.1rem; margin: 0.25rem 0 0.5rem; }
.tle-spot-card dl { display: grid; grid-template-columns: 5rem 1fr; gap: 0.4rem 1rem; font-size: 0.85rem; margin: 0.5rem 0; }
.tle-spot-card dt { font-family: 'JetBrains Mono', monospace; color: #6B6B68; font-weight: 500; font-size: 0.75rem; text-transform: uppercase; }
.tle-spot-card dd { color: #1B1B1A; margin: 0; }

.tle-card { background: #fff; border: 1px solid #DDDCD6; transition: border-color 150ms; border-radius: 0; }
.tle-card:hover { border-color: #1B1B1A; }
.tle-card-image { width: 100%; aspect-ratio: 16/10; object-fit: cover; display: block; }
.tle-card-body { padding: 1.25rem; }
.tle-card-meta { display: flex; gap: 0.5rem; font-family: 'JetBrains Mono', monospace; font-size: 0.7rem; letter-spacing: 0.05em; color: #6B6B68; margin-bottom: 0.6rem; text-transform: uppercase; }
.tle-card-meta a { color: #FF3B30; font-weight: 700; }
.tle-card-title { font-family: 'Noto Sans JP', sans-serif; font-weight: 900; font-size: 1.15rem; line-height: 1.45; color: #1B1B1A; margin-bottom: 0.6rem; }
.tle-card-excerpt { font-size: 0.875rem; color: #4B4B48; line-height: 1.6; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }

.tle-ad-slot { margin: 2rem 0; min-height: 100px; display: flex; align-items: center; justify-content: center; }
.tle-ad-in-article { margin: 2.5rem auto; }
.tle-ad-sidebar { min-height: 250px; }
@media (min-width: 1024px) { .tle-ad-sidebar { position: sticky; top: 100px; } }
.tle-ad-footer-banner { min-height: 90px; padding: 0 1rem; }
.tle-ad-archive-top { min-height: 90px; }
.tle-ad-home-mid { min-height: 90px; }

/* Notes */
.tle-note-body { white-space: pre-line; font-family: 'Inter','Noto Sans JP',sans-serif; line-height: 1.85; color: #1B1B1A; }

/* Hero overlay shared */
.tle-hero-overlay { background: linear-gradient(to bottom, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.7) 100%); }
