/* ==========================================================================
   ABOUT — cinematic storytelling, angular frame instead of rounded card
   ========================================================================== */

.about-section { background: var(--black-deep); position: relative; }

.about-grid {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: var(--space-2xl);
  align-items: center;
}

@media (max-width: 980px) { .about-grid { grid-template-columns: 1fr; gap: var(--space-lg); } }

.about-visual {
  position: relative;
  aspect-ratio: 4/5;
  overflow: hidden;
  background: var(--ink);
  clip-path: polygon(0 0, 100% 0, 100% 94%, 94% 100%, 0 100%);
}

.about-visual::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(150deg, transparent 45%, rgba(200,155,60,0.14) 100%);
}

.about-visual img { width: 100%; height: 100%; object-fit: cover; opacity: 0.85; }

.about-visual-frame { position: absolute; inset: 14px; pointer-events: none; }
.about-visual-frame::before, .about-visual-frame::after {
  content: '';
  position: absolute;
  width: 22px; height: 22px;
  border: 1px solid var(--gold);
  opacity: 0.8;
}
.about-visual-frame::before { top: 0; left: 0; border-right: none; border-bottom: none; }
.about-visual-frame::after { bottom: 0; right: 0; border-left: none; border-top: none; }

.about-copy .lede { margin-bottom: var(--space-sm); }
.about-copy p + p { margin-top: 1.1rem; }

.about-stats { display: flex; gap: var(--space-lg); margin-top: var(--space-md); flex-wrap: wrap; }

.about-stat-num {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 2.7rem;
  color: var(--gold);
  line-height: 1;
}

.about-stat-label {
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(242,239,233,0.5);
  margin-top: 0.5rem;
}

/* reveal-on-scroll: opacity/transform drive visibility (safe for IntersectionObserver,
   which reports zero intersection on a fully clip-path-hidden element). The horizontal
   wipe motion comes from a width-based clip on ::before is avoided — instead we use a
   translateX + clip combination that always keeps a sliver of the element's box visible
   so the observer can still detect it pre-reveal. */
.reveal {
  opacity: 0;
  transform: translateX(-18px);
  transition: opacity 0.8s var(--ease-stage), transform 0.8s var(--ease-stage);
}
.reveal.is-visible { opacity: 1; transform: translateX(0); }
.reveal-delay-1.is-visible { transition-delay: 0.1s; }
.reveal-delay-2.is-visible { transition-delay: 0.2s; }
.reveal-delay-3.is-visible { transition-delay: 0.3s; }

@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* ==========================================================================
   SERVICES — angular tiles with sweeping diagonal hover light
   ========================================================================== */

.services-section { background: var(--black); }

.services-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line-soft); }

@media (max-width: 1080px) { .services-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .services-grid { grid-template-columns: 1fr; } }

.service-card {
  position: relative;
  background: var(--black);
  padding: 2.6rem 2rem;
  overflow: hidden;
  transition: background var(--dur-fast);
}

/* diagonal light sweep across the tile on hover, replacing the old radial glow-from-top */
.service-card::before {
  content: '';
  position: absolute;
  top: 0; left: -60%;
  width: 40%; height: 100%;
  background: linear-gradient(105deg, transparent, rgba(200,155,60,0.16), transparent);
  transform: skewX(-12deg);
  transition: left 0.7s var(--ease-stage);
}

.service-card:hover::before { left: 120%; }
.service-card:hover { background: var(--ink); }

.service-icon {
  width: 42px; height: 42px;
  margin-bottom: 1.5rem;
  color: var(--gold);
  transition: transform var(--dur-med) var(--ease-stage);
}

.service-card:hover .service-icon { transform: rotate(90deg); }

.service-card h3 { font-size: 1.25rem; margin-bottom: 0.7rem; position: relative; z-index: 1; }
.service-card p { font-size: 0.9rem; position: relative; z-index: 1; }

.service-card.is-secondary { background: var(--black-deep); }
.service-card.is-secondary::after {
  content: '';
  position: absolute;
  inset: 10px;
  border: 1px dashed var(--line);
  pointer-events: none;
}

/* ==========================================================================
   EXPERIENCE TIMELINE — radial marker instead of circular badge
   ========================================================================== */

.timeline-section { background: var(--black-deep); }

.timeline { position: relative; display: flex; flex-direction: column; gap: 0; max-width: 720px; margin: 0 auto; }

.timeline-rail {
  position: absolute;
  left: 27px; top: 14px; bottom: 14px;
  width: 1px;
  background: linear-gradient(180deg, transparent, var(--gold) 8%, var(--gold) 92%, transparent);
}

.timeline-rail-fill {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 0%;
  background: var(--gold-bright);
  box-shadow: 0 0 8px var(--gold);
  transition: height 0.4s linear;
}

.timeline-step { position: relative; display: flex; gap: 1.9rem; padding: 1.6rem 0; }

.timeline-marker {
  flex-shrink: 0;
  width: 54px; height: 54px;
  border: 1px solid var(--line);
  background: var(--black);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.25rem;
  color: rgba(242,239,233,0.35);
  z-index: 1;
  transform: rotate(45deg);
  transition: all var(--dur-med) var(--ease-stage);
}

.timeline-marker span { transform: rotate(-45deg); display: block; }

.timeline-step.is-active .timeline-marker {
  border-color: var(--gold);
  color: var(--gold);
  box-shadow: 0 0 16px rgba(200,155,60,0.35);
  background: var(--ink);
}

.timeline-content h3 { font-size: 1.28rem; margin-bottom: 0.35rem; transition: color var(--dur-med); }
.timeline-content p { font-size: 0.92rem; }
.timeline-step.is-active .timeline-content h3 { color: var(--gold); }

/* ==========================================================================
   WHY CHOOSE US — column rule grid instead of bordered boxes
   ========================================================================== */

.why-section { background: var(--black); }

.why-grid { display: grid; grid-template-columns: repeat(4, 1fr); }

@media (max-width: 1080px) { .why-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .why-grid { grid-template-columns: 1fr; } }

.why-card {
  text-align: center;
  padding: 2.4rem 1.5rem;
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line-soft);
}

.why-icon { width: 38px; height: 38px; margin: 0 auto 1.3rem; color: var(--gold); }
.why-card h3 { font-size: 1.08rem; margin-bottom: 0.55rem; }
.why-card p { font-size: 0.88rem; }

/* ==========================================================================
   360 INTERACTIVE SHOWCASE
   ========================================================================== */

.showcase-section { background: var(--black-deep); overflow: hidden; }

.showcase-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-lg); align-items: center; }

@media (max-width: 980px) { .showcase-grid { grid-template-columns: 1fr; } }

.showcase-stage {
  position: relative;
  aspect-ratio: 1/1;
  max-width: 460px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: grab;
}

.showcase-stage:active { cursor: grabbing; }

/* octagonal viewfinder ring instead of plain dashed circle */
.showcase-ring {
  position: absolute;
  inset: 8%;
  border: 1px dashed var(--line);
  clip-path: polygon(30% 0,70% 0,100% 30%,100% 70%,70% 100%,30% 100%,0 70%,0 30%);
  animation: showcase-ring-spin 18s linear infinite;
}

@media (prefers-reduced-motion: reduce) { .showcase-ring { animation: none; } }

@keyframes showcase-ring-spin { to { transform: rotate(360deg); } }

.showcase-booth {
  position: relative;
  width: 70%;
  transform: scaleX(1);
  transform-origin: center center;
  transition: transform 0.05s linear;
}

.showcase-hint {
  margin-top: 1.5rem;
  text-align: center;
  font-size: 0.76rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(242,239,233,0.38);
}

.hotspot-panel {
  background: var(--ink);
  border-left: 2px solid var(--gold);
  padding: 1.7rem 1.9rem;
  margin-top: 1.3rem;
  display: none;
}

.hotspot-panel.is-active { display: block; }
.hotspot-panel h4 { font-family: var(--font-display); font-style: italic; color: var(--gold); font-size: 1.2rem; margin-bottom: 0.45rem; }
.hotspot-panel p { font-size: 0.9rem; }

.showcase-features { display: flex; flex-direction: column; gap: 1px; margin-top: var(--space-sm); background: var(--line-soft); }

.showcase-feature-btn {
  text-align: left;
  padding: 1.05rem 1.3rem;
  background: var(--black-deep);
  font-size: 0.92rem;
  color: rgba(242,239,233,0.75);
  transition: all var(--dur-fast);
  border-left: 2px solid transparent;
}

.showcase-feature-btn.is-active, .showcase-feature-btn:hover {
  border-left-color: var(--gold);
  background: var(--ink);
  color: var(--white);
}

/* ==========================================================================
   CHARGING STATION
   ========================================================================== */

.charge-section { background: var(--black); }

.charge-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-lg); align-items: center; }

@media (max-width: 980px) { .charge-grid { grid-template-columns: 1fr; } }

.charge-visual {
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--ink);
  position: relative;
  clip-path: polygon(0 0, 100% 0, 100% 94%, 94% 100%, 0 100%);
}

.charge-visual img { width: 100%; height: 100%; object-fit: cover; }

.charge-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; margin-top: var(--space-md); background: var(--line-soft); }

.charge-stat { background: var(--black); padding: 1.5rem; }

.charge-stat-num { font-family: var(--font-display); font-style: italic; font-size: 2.2rem; color: var(--gold); }
.charge-stat-label { font-size: 0.82rem; color: rgba(242,239,233,0.55); margin-top: 0.35rem; }

/* ==========================================================================
   TESTIMONIALS — angular floating panels, no rounded corners
   ========================================================================== */

.testimonials-section { background: var(--black-deep); }

.testimonial-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.8rem; }

@media (max-width: 980px) { .testimonial-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .testimonial-grid { grid-template-columns: 1fr; } }

.testimonial-card {
  background: var(--ink);
  padding: 2.1rem 1.9rem;
  position: relative;
  border-top: 2px solid var(--gold-dim);
}

.testimonial-card:nth-child(2) { margin-top: 1.8rem; border-top-color: var(--gold); }
.testimonial-card:nth-child(3) { margin-top: -1rem; }
@media (max-width: 980px) { .testimonial-card:nth-child(2), .testimonial-card:nth-child(3) { margin-top: 0; } }

.testimonial-quote-mark { font-family: var(--font-display); font-style: italic; font-size: 3.2rem; color: var(--gold); line-height: 1; opacity: 0.45; }

.testimonial-card p.quote { font-size: 0.97rem; color: rgba(242,239,233,0.85); margin: 0.6rem 0 1.5rem; font-style: italic; }

.testimonial-author { display: flex; align-items: center; gap: 0.85rem; }
.testimonial-avatar { width: 36px; height: 36px; background: var(--gold-dim); flex-shrink: 0; transform: rotate(45deg); }
.testimonial-name { font-size: 0.88rem; color: var(--white); font-weight: 600; }
.testimonial-role { font-size: 0.75rem; color: rgba(242,239,233,0.48); }

/* ==========================================================================
   SOCIAL — Instagram / TikTok
   ========================================================================== */

.social-section { background: var(--black); }

.social-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line-soft); }

@media (max-width: 900px) { .social-grid { grid-template-columns: repeat(2, 1fr); } }

.social-tile { position: relative; aspect-ratio: 1/1; background: var(--ink); overflow: hidden; }

.social-tile img, .social-tile video { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-med) var(--ease-stage); }
.social-tile:hover img, .social-tile:hover video { transform: scale(1.08) rotate(1deg); }

.social-tile-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.8));
  display: flex; align-items: flex-end;
  padding: 1rem;
  opacity: 0;
  transition: opacity var(--dur-fast);
}

.social-tile:hover .social-tile-overlay { opacity: 1; }
.social-tile-overlay span { font-size: 0.78rem; color: var(--white); }

.social-cta { text-align: center; margin-top: var(--space-md); }

/* ==========================================================================
   BOOKING FUNNEL — angular form panel, viewfinder corners
   ========================================================================== */

.booking-section { background: var(--black-deep); position: relative; }

.booking-grid { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: var(--space-2xl); }

@media (max-width: 980px) { .booking-grid { grid-template-columns: 1fr; gap: var(--space-lg); } }

.booking-info-item { display: flex; gap: 1rem; margin-bottom: 1.7rem; }
.booking-info-icon { width: 20px; height: 20px; color: var(--gold); flex-shrink: 0; margin-top: 3px; }
.booking-info-item h4 { font-size: 0.95rem; color: var(--white); margin-bottom: 0.25rem; }
.booking-info-item p { font-size: 0.88rem; }

.booking-form {
  background: var(--ink);
  padding: clamp(1.7rem, 3vw, 2.9rem);
  position: relative;
  clip-path: polygon(0 0, calc(100% - 24px) 0, 100% 24px, 100% 100%, 0 100%);
}

.booking-form::before, .booking-form::after {
  content: '';
  position: absolute;
  width: 16px; height: 16px;
  border: 1px solid var(--gold);
  opacity: 0.7;
}
.booking-form::before { top: 12px; left: 12px; border-right: none; border-bottom: none; }
.booking-form::after { bottom: 12px; right: 12px; border-left: none; border-top: none; }

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
@media (max-width: 560px) { .form-row { grid-template-columns: 1fr; } }

.form-field { margin-bottom: 1.3rem; }

.form-field label {
  display: block;
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(242,239,233,0.5);
  margin-bottom: 0.55rem;
}

.form-field input, .form-field select, .form-field textarea {
  width: 100%;
  background: var(--black-deep);
  border: 1px solid var(--line-soft);
  border-radius: 0;
  padding: 0.85rem 1rem;
  color: var(--off-white);
  font-family: var(--font-body);
  font-size: 0.95rem;
  transition: border-color var(--dur-fast);
}

.form-field input:focus, .form-field select:focus, .form-field textarea:focus { border-color: var(--gold); outline: none; }
.form-field textarea { resize: vertical; min-height: 100px; }

.form-submit { width: 100%; justify-content: center; margin-top: 0.4rem; }

.form-success { display: none; text-align: center; padding: 2.5rem 1rem; }
.form-success.is-active { display: block; }

.form-success-icon {
  width: 52px; height: 52px;
  margin: 0 auto 1.3rem;
  border: 1px solid var(--gold);
  display: flex; align-items: center; justify-content: center;
  color: var(--gold);
  transform: rotate(45deg);
  animation: success-ring 0.5s var(--ease-stage);
}

.form-success-icon svg { transform: rotate(-45deg); }

@keyframes success-ring { 0% { transform: rotate(45deg) scale(0.5); opacity: 0; } 100% { transform: rotate(45deg) scale(1); opacity: 1; } }

.form-success h3 { font-size: 1.45rem; margin-bottom: 0.65rem; }
.form-success p { font-size: 0.92rem; }

/* ==========================================================================
   FAQ — angular plus/minus instead of circle accordion icon
   ========================================================================== */

.faq-section { background: var(--black); }

.faq-list { max-width: 760px; margin: 0 auto; }

.faq-item { border-bottom: 1px solid var(--line-soft); }

.faq-question {
  width: 100%;
  display: flex; justify-content: space-between; align-items: center;
  padding: 1.7rem 0;
  text-align: left;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.2rem;
  color: var(--off-white);
}

.faq-question:hover { color: var(--gold); }

.faq-icon { width: 16px; height: 16px; flex-shrink: 0; margin-left: 1rem; position: relative; transition: transform var(--dur-fast) var(--ease-stage); }
.faq-icon::before, .faq-icon::after { content: ''; position: absolute; background: var(--gold); }
.faq-icon::before { top: 50%; left: 0; width: 100%; height: 1px; transform: translateY(-50%); }
.faq-icon::after { left: 50%; top: 0; height: 100%; width: 1px; transform: translateX(-50%); transition: transform var(--dur-fast); }

.faq-item.is-open .faq-icon { transform: rotate(45deg); }
.faq-item.is-open .faq-question { color: var(--gold); }

.faq-answer { max-height: 0; overflow: hidden; transition: max-height var(--dur-med) var(--ease-stage); }
.faq-answer-inner { padding-bottom: 1.7rem; }
.faq-answer p { font-size: 0.95rem; }

/* ==========================================================================
   PAGE HERO (inner pages)
   ========================================================================== */

.page-hero {
  position: relative;
  padding: 11rem 0 5rem;
  background: var(--black-deep);
  text-align: center;
  overflow: hidden;
}

.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(115deg, transparent 35%, rgba(200,155,60,0.05) 50%, transparent 65%);
  pointer-events: none;
}

.page-hero .eyebrow { justify-content: center; }
.page-hero h1 { margin-bottom: 1rem; }
.page-hero .lede { margin: 0 auto; }

.breadcrumb {
  display: flex; justify-content: center; gap: 0.6rem;
  font-size: 0.8rem;
  color: rgba(242,239,233,0.45);
  margin-bottom: 1.2rem;
}

.breadcrumb a:hover { color: var(--gold); }

/* ==========================================================================
   PORTFOLIO
   ========================================================================== */

.portfolio-section { background: var(--black); }

.portfolio-filters { display: flex; justify-content: center; gap: 0.7rem; flex-wrap: wrap; margin-bottom: var(--space-lg); }

.filter-btn {
  padding: 0.65rem 1.4rem;
  border: 1px solid var(--line-soft);
  font-size: 0.76rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(242,239,233,0.58);
  transition: all var(--dur-fast);
  clip-path: polygon(8px 0, 100% 0, calc(100% - 8px) 100%, 0 100%);
}

.filter-btn:hover { border-color: var(--gold); color: var(--gold); }
.filter-btn.is-active { background: var(--gold); border-color: var(--gold); color: var(--black); }

.masonry-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line-soft); grid-auto-flow: dense; }

@media (max-width: 900px) { .masonry-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .masonry-grid { grid-template-columns: 1fr; } }

.masonry-item { position: relative; overflow: hidden; cursor: pointer; background: var(--ink); aspect-ratio: 1/1; }
.masonry-item.tall { aspect-ratio: 1/1.3; }
.masonry-item.wide { aspect-ratio: 1.6/1; grid-column: span 2; }

@media (max-width: 560px) { .masonry-item.wide { grid-column: span 1; } }

.masonry-item img, .masonry-item video { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-med) var(--ease-stage); }
.masonry-item:hover img, .masonry-item:hover video { transform: scale(1.08); }

.masonry-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 45%, rgba(0,0,0,0.85));
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 1.2rem;
  opacity: 0;
  transition: opacity var(--dur-fast);
}

.masonry-item:hover .masonry-overlay { opacity: 1; }
.masonry-overlay .tag { font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold); margin-bottom: 0.3rem; }
.masonry-overlay .title { font-size: 0.95rem; color: var(--white); font-family: var(--font-display); font-style: italic; }

.lightbox {
  position: fixed; inset: 0; z-index: 500;
  background: rgba(4,4,4,0.97);
  display: none; align-items: center; justify-content: center;
  padding: 2rem;
}

.lightbox.is-open { display: flex; }
.lightbox-content { max-width: 900px; max-height: 85vh; }
.lightbox-content img, .lightbox-content video { width: 100%; height: 100%; object-fit: contain; max-height: 85vh; }

.lightbox-close {
  position: absolute; top: 2rem; right: 2rem;
  font-size: 0.8rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold);
}

/* ==========================================================================
   BLOG
   ========================================================================== */

.blog-section { background: var(--black); }

.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line-soft); }

@media (max-width: 980px) { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .blog-grid { grid-template-columns: 1fr; } }

.blog-card { background: var(--black); transition: background var(--dur-fast); }
.blog-card:hover { background: var(--ink); }

.blog-card-image { aspect-ratio: 16/10; overflow: hidden; background: var(--black-deep); }
.blog-card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-med); }
.blog-card:hover .blog-card-image img { transform: scale(1.05); }

.blog-card-body { padding: 1.7rem 1.6rem; }
.blog-card-tag { font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold); margin-bottom: 0.65rem; display: block; }
.blog-card h3 { font-size: 1.28rem; margin-bottom: 0.65rem; line-height: 1.2; }
.blog-card p { font-size: 0.88rem; }
.blog-card-meta { font-size: 0.74rem; color: rgba(242,239,233,0.38); margin-top: 1.1rem; }

/* Article */
.article-section { background: var(--black); }
.article-body { max-width: var(--container-narrow); margin: 0 auto; }

.article-meta { display: flex; gap: 1.2rem; font-size: 0.8rem; color: rgba(242,239,233,0.42); justify-content: center; margin-bottom: 1rem; }

.article-cover { aspect-ratio: 16/8; overflow: hidden; background: var(--ink); margin: var(--space-lg) 0; clip-path: polygon(0 0, 100% 0, 100% 96%, 96% 100%, 0 100%); }
.article-cover img { width: 100%; height: 100%; object-fit: cover; }

.article-content { max-width: 720px; margin: 0 auto; }
.article-content h2 { font-size: 1.85rem; margin: var(--space-md) 0 1rem; }
.article-content h3 { font-size: 1.32rem; margin: var(--space-sm) 0 0.8rem; }
.article-content p { margin-bottom: 1.2rem; font-size: 1.02rem; }
.article-content ul, .article-content ol { margin: 0 0 1.2rem 1.4rem; color: rgba(242,239,233,0.78); }
.article-content li { margin-bottom: 0.5rem; }
.article-content a { color: var(--gold); border-bottom: 1px solid rgba(200,155,60,0.35); }
.article-content a:hover { border-color: var(--gold); }

.article-cta {
  background: var(--ink);
  padding: 2.3rem;
  text-align: center;
  margin: var(--space-lg) 0;
  border-left: 2px solid var(--gold);
}

.article-cta h3 { margin-bottom: 0.6rem; }
.article-cta p { margin-bottom: 1.4rem; }

.article-tags { display: flex; gap: 0.6rem; flex-wrap: wrap; margin-top: var(--space-md); }
.article-tag {
  font-size: 0.74rem; padding: 0.45rem 1rem;
  border: 1px solid var(--line);
  color: rgba(242,239,233,0.55);
  clip-path: polygon(6px 0, 100% 0, calc(100% - 6px) 100%, 0 100%);
}
