/*
Theme Name: SingaporeEast
Theme URI: https://singaporeeast.com
Description: Professional local guide theme for Singapore East
Version: 2.0
Author: Singapore East
Text Domain: singaporeeast
*/

:root {
  --red: #E8192C;
  --red-dark: #C01020;
  --red-light: #FFF0F2;
  --black: #111111;
  --dark: #1E1E1E;
  --gray-800: #2C2C2C;
  --gray-600: #555555;
  --gray-400: #888888;
  --gray-200: #E5E5E5;
  --gray-100: #F7F7F7;
  --white: #FFFFFF;
  --font-display: 'DM Serif Display', Georgia, serif;
  --font-body: 'DM Sans', -apple-system, sans-serif;
  --container: 1200px;
  --radius: 10px;
  --radius-sm: 6px;
  --shadow: 0 2px 12px rgba(0,0,0,0.08);
  --shadow-hover: 0 8px 28px rgba(0,0,0,0.14);
  --transition: 0.2s ease;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);font-size:1rem;line-height:1.7;color:var(--gray-800);background:var(--white);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;font-family:var(--font-body);border:none;background:none}

.skip-link{position:absolute;top:-100%;left:1rem;background:var(--red);color:var(--white);padding:0.5rem 1rem;border-radius:var(--radius-sm);font-size:14px;font-weight:600;z-index:9999}
.skip-link:focus{top:1rem}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}

/* HEADER */
.site-header{position:sticky;top:0;z-index:200;background:var(--black);box-shadow:0 3px 0 var(--red)}
.header-main-inner{display:flex;align-items:center;gap:24px;height:64px}
.logo-text{font-family:var(--font-display);font-size:1.5rem;color:var(--white);letter-spacing:-0.5px}
.logo-text strong{color:var(--red);font-weight:400;font-style:italic}
.site-nav{flex:1}
.nav-list{display:flex;gap:4px}
.nav-list li a{color:rgba(255,255,255,0.7);font-size:13px;font-weight:500;padding:6px 14px;border-radius:var(--radius-sm);transition:all var(--transition);text-transform:uppercase;letter-spacing:0.3px}
.nav-list li a:hover,.nav-list li.current-menu-item a{color:var(--white);background:rgba(255,255,255,0.1)}
.nav-list li.current-menu-item > a{color:var(--red)}
.search-toggle{color:rgba(255,255,255,0.6);padding:8px;border-radius:var(--radius-sm);transition:all var(--transition);display:flex;margin-left:auto}
.search-toggle:hover{color:var(--white);background:rgba(255,255,255,0.1)}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px}
.nav-toggle span{display:block;width:22px;height:2px;background:rgba(255,255,255,0.8);border-radius:2px}
.search-overlay{background:var(--dark);padding:16px 0;border-bottom:1px solid rgba(255,255,255,0.1)}
.search-overlay .search-form{display:flex;gap:8px}
.search-overlay input[type=search]{flex:1;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);color:var(--white);padding:10px 16px;border-radius:var(--radius-sm);font-size:15px;font-family:var(--font-body);outline:none}
.search-overlay input[type=search]:focus{border-color:var(--red)}
.search-overlay input::placeholder{color:rgba(255,255,255,0.3)}
.search-overlay button{background:var(--red);color:var(--white);padding:10px 20px;border-radius:var(--radius-sm);font-weight:600;font-size:14px;transition:background var(--transition)}
.search-overlay button:hover{background:var(--red-dark)}

/* BREADCRUMB */
.breadcrumb{padding:16px 24px;max-width:var(--container);margin:0 auto;display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:12px;color:var(--gray-400);font-family:monospace}
.breadcrumb a{color:var(--red)}
.breadcrumb a:hover{text-decoration:underline}

/* HERO */
.hero-section{background:var(--black);padding:60px 0;overflow:hidden}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.hero-eyebrow{display:inline-block;background:var(--red);color:var(--white);font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;padding:4px 12px;border-radius:3px;margin-bottom:16px}
.hero-title{font-family:var(--font-display);font-size:clamp(2rem,4vw,3.2rem);color:var(--white);line-height:1.15;margin-bottom:16px;letter-spacing:-1px}
.hero-title span{color:var(--red);font-style:italic}
.hero-desc{color:rgba(255,255,255,0.6);font-size:17px;margin-bottom:28px;line-height:1.6}
.hero-section .search-form{display:flex;max-width:440px}
.hero-section input[type=search]{flex:1;padding:14px 18px;border:none;border-radius:var(--radius-sm) 0 0 var(--radius-sm);font-size:15px;font-family:var(--font-body);outline:none}
.hero-section button[type=submit]{background:var(--red);color:var(--white);padding:14px 22px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-weight:600;font-size:14px;white-space:nowrap;transition:background var(--transition)}
.hero-section button:hover{background:var(--red-dark)}
.hero-image{border-radius:var(--radius);overflow:hidden;position:relative}
.hero-image a{display:block;position:relative}
.hero-image img{width:100%;height:380px;object-fit:cover}
.hero-image-caption{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,0.85));padding:40px 20px 20px}
.hero-cat{display:inline-block;background:var(--red);color:var(--white);font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:3px 8px;border-radius:3px;margin-bottom:8px}
.hero-image-caption h2{font-family:var(--font-display);color:var(--white);font-size:1.25rem;line-height:1.3}

/* CATEGORY PILLS */
.category-pills-section{padding:24px 0;border-bottom:1px solid var(--gray-200)}
.category-pills{display:flex;flex-wrap:wrap;gap:8px}
.cat-pill{background:var(--gray-100);color:var(--gray-600);font-size:13px;font-weight:500;padding:7px 16px;border-radius:50px;transition:all var(--transition);border:1px solid var(--gray-200)}
.cat-pill:hover{background:var(--red);color:var(--white);border-color:var(--red)}

/* SECTION HEADERS */
.section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:28px}
.section-title{font-family:var(--font-display);font-size:1.8rem;color:var(--black);letter-spacing:-0.5px;position:relative;padding-bottom:12px}
.section-title::after{content:'';position:absolute;bottom:0;left:0;width:40px;height:3px;background:var(--red)}
.see-all{color:var(--red);font-size:14px;font-weight:600}
.see-all:hover{text-decoration:underline}

/* FEATURED SECTION */
.featured-section{padding:60px 0}
.featured-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:24px}
.featured-main{border-radius:var(--radius);overflow:hidden;background:var(--black)}
.featured-main a{display:block}
.featured-main img{width:100%;height:340px;object-fit:cover;transition:transform 0.4s ease}
.featured-main a:hover img{transform:scale(1.03)}
.featured-main-body{padding:24px}
.featured-main-body .post-cat{display:inline-block;background:var(--red);color:var(--white);font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:3px 8px;border-radius:3px;margin-bottom:10px}
.featured-main-body h3{font-family:var(--font-display);font-size:1.5rem;color:var(--white);line-height:1.25;margin-bottom:10px}
.featured-main-body p{color:rgba(255,255,255,0.6);font-size:14px;line-height:1.6;margin-bottom:14px}
.featured-side{display:flex;flex-direction:column;gap:8px}
.featured-side-card{background:var(--white);border-radius:var(--radius);overflow:hidden;border:1px solid var(--gray-200);transition:box-shadow var(--transition)}
.featured-side-card:hover{box-shadow:var(--shadow)}
.featured-side-inner{display:flex;gap:14px;padding:14px;align-items:center}
.featured-side-inner img{width:90px;height:70px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}
.featured-side-body{flex:1;min-width:0}
.post-cat-small{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--red);display:block;margin-bottom:4px}
.featured-side-body h3{font-size:14px;font-weight:600;color:var(--black);line-height:1.35;margin-bottom:5px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.post-date,.post-meta time{font-size:12px;color:var(--gray-400)}

/* AREA SECTION */
.area-section{background:var(--gray-100);padding:60px 0}
.area-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.area-card{display:block;background:var(--white);border-radius:var(--radius);border:1px solid var(--gray-200);transition:all var(--transition)}
.area-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover);border-color:var(--red)}
.area-card-inner{padding:24px}
.area-card h3{font-family:var(--font-display);font-size:1.25rem;color:var(--black);margin-bottom:6px}
.area-card p{font-size:13px;color:var(--gray-400);margin-bottom:16px}
.area-link{font-size:13px;font-weight:600;color:var(--red)}

/* POSTS GRID */
.recent-section{padding:60px 0}
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post-card{border-radius:var(--radius);overflow:hidden;border:1px solid var(--gray-200);background:var(--white);transition:all var(--transition)}
.post-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover)}
.post-card-inner{display:flex;flex-direction:column;height:100%}
.post-card img{width:100%;height:200px;object-fit:cover;transition:transform 0.4s}
.post-card:hover img{transform:scale(1.04)}
.post-card-body{padding:18px;flex:1;display:flex;flex-direction:column}
.post-card-body h2,.post-card-body h3{font-family:var(--font-display);font-size:1.05rem;color:var(--black);line-height:1.35;margin:6px 0 8px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.post-card-body p{font-size:13px;color:var(--gray-600);line-height:1.6;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:12px}
.post-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--gray-400);margin-top:auto}
.dot{width:3px;height:3px;background:var(--gray-400);border-radius:50%;display:inline-block}

/* SINGLE POST LAYOUT */
.article-layout{display:grid;grid-template-columns:1fr 300px;gap:60px;align-items:start;padding:0 0 80px}
.article-header{padding:24px 0 0}
.article-cat{display:inline-block;background:var(--red);color:var(--white);font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;border-radius:3px;margin-bottom:16px}
.article-title{font-family:var(--font-display);font-size:clamp(1.8rem,4vw,2.8rem);color:var(--black);line-height:1.2;margin-bottom:20px;letter-spacing:-0.5px}
.article-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:13px;color:var(--gray-400);padding:16px 0;border-top:1px solid var(--gray-200);border-bottom:1px solid var(--gray-200);margin-bottom:28px}
.article-author{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--gray-600)}
.article-author img{border-radius:50%;width:32px;height:32px;object-fit:cover}
.meta-tag{background:var(--gray-100);padding:2px 8px;border-radius:3px;font-size:11px}
.article-featured-image{margin-bottom:32px;border-radius:var(--radius);overflow:hidden}
.article-featured-image img{width:100%;max-height:460px;object-fit:cover}
.image-caption{padding:10px 14px;background:var(--gray-100);font-size:12px;color:var(--gray-400);font-style:italic;text-align:center}

/* ARTICLE CONTENT */
.article-content{font-size:17px;line-height:1.85;color:var(--gray-800)}
.article-content p{margin-bottom:1.6em}
.article-content h2{font-family:var(--font-display);font-size:1.65rem;color:var(--black);margin:2.5em 0 0.8em;padding-bottom:0.5em;border-bottom:1px solid var(--gray-200);position:relative;line-height:1.3}
.article-content h2::before{content:'';position:absolute;bottom:-1px;left:0;width:40px;height:2px;background:var(--red)}
.article-content h3{font-family:var(--font-display);font-size:1.25rem;color:var(--black);margin:2em 0 0.6em;line-height:1.3}
.article-content h4{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px;color:var(--gray-400);margin:1.5em 0 0.5em;font-family:monospace}
.article-content strong{font-weight:600;color:var(--black)}
.article-content a{color:#1a73e8;text-decoration:underline;text-decoration-color:rgba(26,115,232,0.35);text-underline-offset:3px;transition:text-decoration-color var(--transition)}
.article-content a:hover{text-decoration-color:#1a73e8}
.article-content ul{margin:0 0 1.8em 0}
.article-content ul li{padding:8px 0 8px 22px;position:relative;border-bottom:1px solid var(--gray-100);font-size:16px}
.article-content ul li:last-child{border-bottom:none}
.article-content ul li::before{content:'';position:absolute;left:0;top:19px;width:8px;height:2px;background:var(--red)}
.article-content ol{margin:0 0 1.8em 0;counter-reset:ol-counter}
.article-content ol li{padding:10px 0 10px 42px;position:relative;border-bottom:1px solid var(--gray-100);font-size:16px;counter-increment:ol-counter}
.article-content ol li::before{content:counter(ol-counter);position:absolute;left:0;top:10px;width:28px;height:28px;background:var(--red);color:var(--white);border-radius:50%;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:monospace}
.article-content figure{margin:2em 0}
.article-content figure img{width:100%;border-radius:var(--radius)}
.article-content figcaption{font-size:12px;color:var(--gray-400);text-align:center;margin-top:8px;font-style:italic}
.article-content table{width:100%;border-collapse:collapse;margin:2em 0;font-size:14px;border-radius:var(--radius);overflow:hidden;box-shadow:0 0 0 1px var(--gray-200)}
.article-content thead{background:var(--black);color:var(--white)}
.article-content thead th{padding:13px 16px;text-align:left;font-size:12px;font-weight:600;letter-spacing:0.5px;text-transform:uppercase;font-family:monospace}
.article-content tbody tr{border-bottom:1px solid var(--gray-200);transition:background var(--transition)}
.article-content tbody tr:last-child{border-bottom:none}
.article-content tbody tr:nth-child(even){background:var(--gray-100)}
.article-content tbody tr:hover{background:var(--red-light)}
.article-content tbody td{padding:12px 16px;vertical-align:top;line-height:1.5}
.article-content tbody td:first-child{font-weight:600;color:var(--black)}
.article-content blockquote{margin:2em 0;padding:20px 24px;background:var(--red-light);border-left:4px solid var(--red);font-style:italic;font-size:1.05rem;color:var(--dark);line-height:1.7}
.article-content hr{border:none;border-top:1px solid var(--gray-200);margin:2.5em 0}

/* TAGS */
.article-tags{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:2.5em 0 1.5em;padding-top:2em;border-top:1px solid var(--gray-200)}
.tags-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--gray-400)}
.tag-pill{background:var(--gray-100);color:var(--gray-600);font-size:12px;padding:5px 12px;border-radius:20px;transition:all var(--transition);border:1px solid var(--gray-200)}
.tag-pill:hover{background:var(--red);color:var(--white);border-color:var(--red)}

/* SHARE BAR */
.share-bar{padding:20px 0;border-top:1px solid var(--gray-200);border-bottom:1px solid var(--gray-200);margin:1.5em 0}
.share-label{display:block;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--gray-400);margin-bottom:12px}
.share-buttons{display:flex;flex-wrap:wrap;gap:8px}
.share-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;transition:all var(--transition)}
.share-fb{background:#1877F2;color:var(--white)}
.share-wa{background:#25D366;color:var(--white)}
.share-tg{background:#0088CC;color:var(--white)}
.share-copy{background:var(--gray-100);color:var(--gray-600);border:1px solid var(--gray-200)}
.share-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}

/* AUTHOR BIO */
.author-bio{display:flex;gap:20px;align-items:flex-start;background:var(--gray-100);border-radius:var(--radius);padding:24px;margin:2.5em 0}
.author-bio img{border-radius:50%;width:72px;height:72px;object-fit:cover;flex-shrink:0}
.author-bio-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--gray-400);display:block;margin-bottom:4px}
.author-bio strong{display:block;font-size:16px;color:var(--black);margin-bottom:6px}
.author-bio p{font-size:14px;color:var(--gray-600);line-height:1.6}

/* RELATED */
.related-posts{margin-top:3em}
.related-title{font-family:var(--font-display);font-size:1.4rem;color:var(--black);margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--gray-200);position:relative}
.related-title::before{content:'';position:absolute;bottom:-1px;left:0;width:40px;height:2px;background:var(--red)}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.related-card{border-radius:var(--radius);overflow:hidden;border:1px solid var(--gray-200);display:block;transition:all var(--transition)}
.related-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.related-card img{width:100%;height:130px;object-fit:cover}
.related-card-body{padding:12px}
.related-card-body h4{font-family:var(--font-display);font-size:0.9rem;color:var(--black);line-height:1.35;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-top:4px}

/* SIDEBAR */
.article-sidebar{position:sticky;top:80px}
.sidebar-widget{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);padding:22px;margin-bottom:20px}
.sidebar-widget-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--gray-400);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--gray-200)}
.toc-list a{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--gray-600);padding:6px 0;border-bottom:1px solid var(--gray-100);transition:color var(--transition)}
.toc-list a:last-child{border-bottom:none}
.toc-list a::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--gray-200);flex-shrink:0;transition:background var(--transition)}
.toc-list a:hover,.toc-list a.active{color:var(--red)}
.toc-list a:hover::before,.toc-list a.active::before{background:var(--red)}
.sidebar-posts{display:flex;flex-direction:column;gap:2px}
.sidebar-post-item a{display:flex;gap:12px;align-items:flex-start;padding:8px 0;border-bottom:1px solid var(--gray-100)}
.sidebar-post-item:last-child a{border-bottom:none}
.sidebar-post-item img{width:70px;height:52px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}
.sidebar-post-title{display:block;font-size:13px;font-weight:500;color:var(--black);line-height:1.35;margin-bottom:4px}
.sidebar-post-title:hover{color:var(--red)}
.sidebar-post-date{font-size:11px;color:var(--gray-400)}
.sidebar-cats li a{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:14px;color:var(--gray-600);border-bottom:1px solid var(--gray-100);transition:color var(--transition)}
.sidebar-cats li:last-child a{border-bottom:none}
.sidebar-cats li a:hover{color:var(--red)}
.cat-count{background:var(--gray-100);color:var(--gray-400);font-size:11px;padding:2px 7px;border-radius:10px;font-family:monospace}
.newsletter-widget{background:var(--black);border-color:var(--black)}
.newsletter-widget .sidebar-widget-title{color:rgba(255,255,255,0.4);border-color:rgba(255,255,255,0.1)}
.newsletter-widget p{font-size:13px;color:rgba(255,255,255,0.55);margin-bottom:14px;line-height:1.5}
.newsletter-form input{width:100%;padding:10px 14px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,0.15);background:rgba(255,255,255,0.08);color:var(--white);font-size:13px;font-family:var(--font-body);outline:none;margin-bottom:8px}
.newsletter-form input:focus{border-color:var(--red)}
.newsletter-form input::placeholder{color:rgba(255,255,255,0.3)}
.newsletter-form button{width:100%;padding:10px;background:var(--red);color:var(--white);border-radius:var(--radius-sm);font-size:13px;font-weight:600;transition:background var(--transition)}
.newsletter-form button:hover{background:var(--red-dark)}

/* ARCHIVE */
.archive-header{padding:40px 0 32px}
.archive-type{display:inline-block;background:var(--red);color:var(--white);font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;border-radius:3px;margin-bottom:12px}
.archive-title{font-family:var(--font-display);font-size:2.2rem;color:var(--black)}
.archive-desc{font-size:16px;color:var(--gray-600);margin-top:10px;max-width:600px}
.archive-layout{display:grid;grid-template-columns:1fr 280px;gap:48px;padding-bottom:80px}
.archive-sidebar{position:sticky;top:80px}
.pagination{padding:40px 0}
.nav-links{display:flex;gap:8px;flex-wrap:wrap}
.page-numbers{padding:8px 14px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;border:1px solid var(--gray-200);color:var(--gray-600);transition:all var(--transition)}
.page-numbers:hover,.page-numbers.current{background:var(--red);color:var(--white);border-color:var(--red)}

/* FOOTER */
.site-footer{background:var(--black);margin-top:80px}
.footer-main{padding:64px 0 48px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px}
.footer-logo .logo-text{font-size:1.3rem}
.footer-brand p{font-size:13px;color:rgba(255,255,255,0.45);line-height:1.7;margin-top:14px;max-width:240px}
.footer-social{display:flex;gap:12px;margin-top:20px}
.footer-social a{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,0.07);color:rgba(255,255,255,0.5);display:flex;align-items:center;justify-content:center;transition:all var(--transition)}
.footer-social a:hover{background:var(--red);color:var(--white)}
.footer-col h3{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,0.9);margin-bottom:16px;font-family:monospace}
.footer-col ul li{margin-bottom:10px}
.footer-col ul li a{font-size:13px;color:rgba(255,255,255,0.45);transition:color var(--transition)}
.footer-col ul li a:hover{color:var(--white)}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.08);padding:20px 0}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,0.3)}

/* ERROR PAGE */
.error-page{text-align:center;padding:80px 0}
.error-page h1{font-family:var(--font-display);font-size:8rem;color:var(--red);line-height:1}
.error-page h2{font-family:var(--font-display);font-size:2rem;margin:16px 0 12px}
.error-page p{color:var(--gray-600);margin-bottom:28px}
.btn-primary{display:inline-block;background:var(--red);color:var(--white);padding:12px 28px;border-radius:var(--radius-sm);font-weight:600;transition:background var(--transition)}
.btn-primary:hover{background:var(--red-dark)}

/* PAGE */
.page-layout{max-width:820px;margin:0 auto;padding:40px 0 80px}
.page-title{font-family:var(--font-display);font-size:2.2rem;color:var(--black);margin-bottom:24px}
.page-thumbnail{margin-bottom:32px;border-radius:var(--radius);overflow:hidden}
.page-content{font-size:17px;line-height:1.85}
.no-posts{font-size:16px;color:var(--gray-600);padding:40px 0}

/* MOBILE RESPONSIVE */
@media (max-width:1024px){
  .article-layout{grid-template-columns:1fr}
  .archive-layout{grid-template-columns:1fr}
  .article-sidebar,.archive-sidebar{position:static}
}
@media (max-width:900px){
  .hero-inner{grid-template-columns:1fr}
  .hero-image{display:none}
  .featured-grid{grid-template-columns:1fr}
  .area-grid{grid-template-columns:repeat(2,1fr)}
  .posts-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .site-nav{display:none}
  .nav-toggle{display:flex}
}
@media (max-width:580px){
  .area-grid,.posts-grid,.related-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .article-title{font-size:1.8rem}
  .hero-title{font-size:2rem}
  .share-buttons{flex-direction:column}
  .author-bio{flex-direction:column}
}

/* MOBILE NAV */
.mobile-nav-open .site-nav{display:block;position:fixed;top:64px;left:0;right:0;background:var(--dark);padding:16px;z-index:199;border-bottom:3px solid var(--red)}
.mobile-nav-open .nav-list{flex-direction:column;gap:4px}
.mobile-nav-open .nav-list li a{display:block;padding:12px 16px;border-radius:var(--radius-sm)}

/* FOCUS & ACCESSIBILITY */
:focus-visible{outline:2px solid var(--red);outline-offset:3px;border-radius:2px}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms!important;transition-duration:0.01ms!important}}
