/*
Theme Name: LiveHistory
Theme URI: https://livehistory.gr
Description: Custom theme για το LiveHistory.gr — αρχειακό website των Εκδόσεων «Το Δόντι». Πιστή μεταφορά του εγκεκριμένου σχεδίου (ink / κόκκινο / χαρτί), με Source Serif 4 · Archivo · Space Mono.
Author: Dimitris Karaiskos
Version: 0.1.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: livehistory
*/

  :root{
    --ink:#1a1a1a;
    --red:#b32b2f;
    --red-dark:#8f2225;
    --paper:#f7f4ec;
    --paper-dim:#efe9d8;
    --line:#d8d0b8;
    --warm-grey:#5c5650;
    --serif:'Source Serif 4', Georgia, serif;
    --sans:'Archivo', Helvetica, Arial, sans-serif;
    --mono:'Space Mono', monospace;
  }

  *{margin:0;padding:0;box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    background:var(--paper);
    color:var(--ink);
    font-family:var(--sans);
    line-height:1.5;
    -webkit-font-smoothing:antialiased;
  }

  a{color:inherit;text-decoration:none;}
  img{max-width:100%;display:block;}

  .wrap{max-width:1180px;margin:0 auto;padding:0 32px;}

  :focus-visible{outline:3px solid var(--red);outline-offset:2px;}
  footer :focus-visible,
  .search-strip :focus-visible,
  .submenu :focus-visible{outline-color:var(--paper);}

  .skip-link{
    position:absolute;
    left:-9999px;
    top:auto;
    background:var(--red);
    color:#fff;
    font-family:var(--sans);
    font-weight:700;
    font-size:14px;
    padding:12px 22px;
    z-index:100;
  }
  .skip-link:focus{
    left:16px;
    top:16px;
  }

  .visually-hidden{
    position:absolute;
    width:1px;height:1px;
    padding:0;margin:-1px;
    overflow:hidden;
    clip:rect(0,0,0,0);
    white-space:nowrap;
    border:0;
  }

  @media (prefers-reduced-motion: reduce){
    *{animation-duration:0.01ms !important; transition-duration:0.01ms !important;}
    html{scroll-behavior:auto;}
  }

  /* ===== TOP BAR ===== */
  .topbar{
    background:var(--paper);
    border-bottom:2px solid var(--ink);
    position:sticky;
    top:0;
    z-index:50;
  }
  .topbar-inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:14px 32px;
    max-width:1180px;
    margin:0 auto;
    gap:24px;
  }
  .logo-block{display:flex;align-items:center;gap:0;}
  .logo-img{height:38px;width:auto;}

  nav.main-nav{display:flex;align-items:center;gap:2px;}
  nav.main-nav > .nav-item{position:relative;}
  nav.main-nav a.top-link{
    display:block;
    font-family:var(--sans);
    font-weight:600;
    font-size:13.5px;
    letter-spacing:.04em;
    text-transform:uppercase;
    color:var(--ink);
    padding:10px 14px;
    border-radius:2px;
  }
  nav.main-nav a.top-link:hover{color:var(--red);}

  .nav-item.has-sub:hover .submenu,
  .nav-item.has-sub:focus-within .submenu{
    display:block;
  }
  .submenu{
    display:none;
    position:absolute;
    top:100%;
    left:0;
    background:var(--ink);
    min-width:200px;
    box-shadow:0 10px 24px rgba(0,0,0,.25);
    padding:6px 0;
  }
  .submenu a{
    display:block;
    font-family:var(--mono);
    font-size:12.5px;
    letter-spacing:.03em;
    color:var(--paper);
    padding:10px 18px;
    border-bottom:1px solid rgba(247,244,236,.12);
  }
  .submenu a:last-child{border-bottom:none;}
  .submenu a:hover{background:var(--red);color:#fff;}

  .search-btn{
    display:flex;
    align-items:center;
    gap:6px;
    font-family:var(--mono);
    font-size:12.5px;
    text-transform:uppercase;
    letter-spacing:.04em;
    border:1.5px solid var(--ink);
    padding:8px 14px;
    border-radius:2px;
    background:none;
    cursor:pointer;
    color:var(--ink);
  }
  .search-btn:hover{background:var(--ink);color:var(--paper);}

  .lang-btn{
    display:flex;
    align-items:center;
    gap:6px;
    font-family:var(--mono);
    font-size:12.5px;
    font-weight:700;
    letter-spacing:.04em;
    border:1.5px solid var(--ink);
    padding:7px 12px;
    border-radius:2px;
    background:none;
    cursor:pointer;
    color:var(--ink);
  }
  .lang-btn .lang-flag{font-size:15px;line-height:1;}
  .lang-btn:hover{background:var(--ink);color:var(--paper);}
  .lang-btn[aria-pressed="true"]{background:var(--red);border-color:var(--red);color:#fff;}

  .burger{display:none;background:none;border:none;cursor:pointer;padding:6px;}
  .burger span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;}

  /* ===== HERO ===== */
  .hero{
    position:relative;
    border-bottom:2px solid var(--ink);
    overflow:hidden;
    background:
      repeating-linear-gradient(
        135deg,
        var(--paper) 0px, var(--paper) 60px,
        var(--paper-dim) 60px, var(--paper-dim) 61px
      );
  }
  .hero-inner{
    max-width:1180px;
    margin:0 auto;
    padding:88px 32px 80px;
    position:relative;
  }
  .eyebrow{
    font-family:var(--mono);
    font-size:13px;
    letter-spacing:.12em;
    text-transform:uppercase;
    color:var(--red-dark);
    display:flex;
    align-items:center;
    gap:10px;
    margin-bottom:22px;
  }
  .eyebrow::before{
    content:'';
    width:10px;height:10px;
    background:var(--red);
    border-radius:50%;
    display:inline-block;
  }
  h1.hero-title{
    font-family:var(--serif);
    font-weight:700;
    font-size:clamp(40px, 6vw, 72px);
    line-height:1.04;
    max-width:820px;
    letter-spacing:-0.01em;
  }
  h1.hero-title em{
    font-style:italic;
    color:var(--red);
    font-weight:500;
  }
  .hero-sub{
    font-family:var(--sans);
    font-size:18px;
    color:var(--warm-grey);
    max-width:560px;
    margin-top:24px;
  }
  .hero-cta{
    display:flex;
    gap:14px;
    margin-top:38px;
    flex-wrap:wrap;
  }
  .btn{
    font-family:var(--sans);
    font-weight:700;
    font-size:14.5px;
    letter-spacing:.02em;
    padding:14px 26px;
    border-radius:2px;
    display:inline-flex;
    align-items:center;
    gap:8px;
    cursor:pointer;
    border:2px solid var(--ink);
  }
  .btn-primary{background:var(--red);border-color:var(--red);color:#fff;}
  .btn-primary:hover{background:var(--red-dark);border-color:var(--red-dark);}
  .btn-secondary{background:transparent;color:var(--ink);}
  .btn-secondary:hover{background:var(--ink);color:var(--paper);}

  .hero-frame{
    margin-top:56px;
    border:2px solid var(--ink);
    background:var(--ink);
    aspect-ratio:16/6.2;
    position:relative;
    overflow:hidden;
  }
  .hero-frame img{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
  }
  .hero-frame .film-grain{
    position:absolute;inset:0;
    background:
      linear-gradient(120deg, #2a2a2a 0%, #161616 45%, #2f2f2f 100%);
  }
  .hero-frame .play-mark{
    position:absolute;
    top:50%;left:50%;
    transform:translate(-50%,-50%);
    width:74px;height:74px;
    border-radius:50%;
    background:var(--red);
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .hero-frame .play-mark::after{
    content:'';
    border-style:solid;
    border-width:13px 0 13px 20px;
    border-color:transparent transparent transparent #fff;
    margin-left:4px;
  }
  .hero-frame .frame-caption{
    position:absolute;
    bottom:14px;left:18px;
    font-family:var(--mono);
    color:var(--paper);
    font-size:12px;
    letter-spacing:.05em;
    opacity:.75;
  }
  .hero-frame .frame-caption-r{
    position:absolute;
    bottom:14px;right:18px;
    font-family:var(--mono);
    color:var(--paper);
    font-size:12px;
    letter-spacing:.05em;
    opacity:.75;
  }

  /* ===== SECTION GENERIC ===== */
  section{padding:84px 0;border-bottom:2px solid var(--ink);}
  section:last-of-type{border-bottom:none;}
  .section-head{
    display:flex;
    justify-content:space-between;
    align-items:flex-end;
    gap:24px;
    margin-bottom:44px;
    flex-wrap:wrap;
  }
  .section-label{
    font-family:var(--mono);
    font-size:12.5px;
    letter-spacing:.1em;
    text-transform:uppercase;
    color:var(--red-dark);
    margin-bottom:10px;
    display:block;
  }
  h2.section-title{
    font-family:var(--serif);
    font-weight:700;
    font-size:clamp(28px,3.4vw,40px);
    letter-spacing:-0.01em;
  }
  .section-note{
    font-family:var(--sans);
    color:var(--warm-grey);
    font-size:15px;
    max-width:340px;
  }

  /* ===== ABOUT ===== */
  .about{background:var(--paper-dim);}
  .about-grid{
    display:grid;
    grid-template-columns:1.1fr 0.9fr;
    gap:64px;
    align-items:start;
  }
  .about-text p{
    font-family:var(--sans);
    font-size:16.5px;
    color:var(--ink);
    margin-bottom:18px;
    max-width:520px;
  }
  .about-text p.lede{
    font-family:var(--serif);
    font-size:21px;
    font-style:italic;
    color:var(--warm-grey);
    line-height:1.45;
  }
  .about-photo{border:2px solid var(--ink);background:var(--paper);}
  .about-photo img{
    width:100%;
    aspect-ratio:4/5;
    object-fit:cover;
    display:block;
  }
  .about-photo figcaption{
    font-family:var(--mono);
    font-size:11.5px;
    letter-spacing:.05em;
    text-transform:uppercase;
    color:var(--warm-grey);
    padding:12px 16px;
    border-top:2px solid var(--ink);
  }

  /* ===== SERVICES ===== */
  .services-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:1px;
    border:2px solid var(--ink);
    background:var(--ink);
  }
  .service-card{
    background:var(--paper);
    padding:34px 28px;
  }
  .service-num{
    font-family:var(--mono);
    color:var(--red);
    font-size:13px;
    margin-bottom:18px;
    display:block;
  }
  .service-card h3{
    font-family:var(--serif);
    font-weight:600;
    font-size:21px;
    margin-bottom:12px;
  }
  .service-card p{
    font-size:14.5px;
    color:var(--warm-grey);
  }

  /* ===== ARCHIVE ===== */
  .archive-tabs{
    display:flex;
    gap:0;
    margin-bottom:0;
    flex-wrap:wrap;
  }
  .archive-tab{
    font-family:var(--mono);
    font-size:13px;
    letter-spacing:.05em;
    text-transform:uppercase;
    padding:12px 22px;
    border:2px solid var(--ink);
    border-bottom:none;
    background:var(--paper-dim);
    color:var(--warm-grey);
    cursor:pointer;
    margin-right:-2px;
    position:relative;
    top:2px;
  }
  .archive-tab.active{
    background:var(--ink);
    color:var(--paper);
    top:0;
  }
  .archive-panel{
    border:2px solid var(--ink);
    padding:40px 32px;
    background:var(--paper);
  }
  .archive-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:24px;
  }
  .archive-item{border:1.5px solid var(--line);}
  .archive-thumb{
    aspect-ratio:4/3;
    background:linear-gradient(135deg,#cfc6a8,#9c9272);
    position:relative;
    overflow:hidden;
  }
  .archive-thumb::after{
    content:'';
    position:absolute;inset:0;
    background:repeating-linear-gradient(0deg, rgba(0,0,0,.05) 0 2px, transparent 2px 4px);
  }
  .archive-thumb img{
    width:100%;
    height:100%;
    object-fit:cover;
    position:relative;
    z-index:1;
  }
  .archive-thumb:has(img)::after{display:none;}
  .archive-tag{
    position:absolute;
    top:10px;left:10px;
    font-family:var(--mono);
    font-size:10.5px;
    background:var(--ink);
    color:var(--paper);
    padding:3px 8px;
    z-index:2;
  }
  .archive-meta{padding:14px 16px;}
  .archive-meta .am-title{
    font-family:var(--serif);
    font-weight:600;
    font-size:16px;
    margin-bottom:4px;
  }
  .archive-meta .am-sub{
    font-family:var(--mono);
    font-size:11.5px;
    color:var(--warm-grey);
    letter-spacing:.03em;
  }
  .archive-panel[hidden]{display:none;}

  /* Archive items that are links (video/text/spotify) */
  .archive-item-link{
    display:block;
    color:var(--ink);
    transition:transform .15s ease, box-shadow .15s ease;
  }
  .archive-item-link:hover{
    transform:translateY(-2px);
    box-shadow:0 6px 16px rgba(0,0,0,.12);
  }
  .archive-item-link:hover .am-title{color:var(--red-dark);}

  /* Video thumbnails with play icon overlay */
  .archive-thumb-video{background:var(--ink);}
  .video-play-icon{
    position:absolute;
    top:50%;left:50%;
    transform:translate(-50%,-50%);
    width:52px;height:52px;
    border-radius:50%;
    background:var(--red);
    z-index:2;
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .video-play-icon::after{
    content:'';
    border-style:solid;
    border-width:10px 0 10px 16px;
    border-color:transparent transparent transparent #fff;
    margin-left:3px;
  }

  /* Audio item with native player */
  .archive-item-audio .archive-meta{padding:14px 16px 18px;}
  .archive-item-audio audio{
    width:100%;
    margin-top:10px;
    accent-color:var(--red);
  }

  /* ===== SEARCH STRIP ===== */
  .search-strip{
    background:var(--ink);
    color:var(--paper);
  }
  .search-strip .section-label{color:#e8a3a5;}
  .search-strip h2.section-title{color:var(--paper);}
  .search-box{
    display:flex;
    border:2px solid var(--paper);
    max-width:680px;
  }
  .search-box input{
    flex:1;
    background:transparent;
    border:none;
    color:var(--paper);
    font-family:var(--sans);
    font-size:16px;
    padding:18px 20px;
  }
  .search-box input::placeholder{color:#9b958a;}
  .search-box button{
    background:var(--red);
    border:none;
    color:#fff;
    font-family:var(--sans);
    font-weight:700;
    font-size:14px;
    letter-spacing:.03em;
    padding:0 28px;
    cursor:pointer;
  }
  .search-box button:hover{background:var(--red-dark);}
  .search-tags{
    display:flex;
    gap:10px;
    margin-top:22px;
    flex-wrap:wrap;
  }
  .search-tags span{
    font-family:var(--mono);
    font-size:12px;
    border:1px solid #5c5650;
    color:#cfc9bd;
    padding:6px 12px;
  }

  /* ===== CONTACT ===== */
  .contact-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:64px;
  }
  .contact-list{list-style:none;}
  .contact-list li{
    padding:18px 0;
    border-bottom:1px solid var(--line);
    display:flex;
    gap:16px;
  }
  .contact-list li:first-child{padding-top:0;}
  .contact-list .c-label{
    font-family:var(--mono);
    font-size:11.5px;
    letter-spacing:.08em;
    text-transform:uppercase;
    color:var(--red-dark);
    width:120px;
    flex-shrink:0;
    padding-top:3px;
  }
  .contact-list .c-value{
    font-family:var(--sans);
    font-size:17px;
  }
  .contact-form{display:flex;flex-direction:column;gap:14px;}
  .contact-form input,
  .contact-form textarea{
    border:2px solid var(--ink);
    background:var(--paper);
    font-family:var(--sans);
    font-size:15px;
    padding:14px 16px;
    color:var(--ink);
  }
  .contact-form textarea{resize:vertical;min-height:110px;}
  .contact-form label{
    font-family:var(--mono);
    font-size:11.5px;
    letter-spacing:.06em;
    text-transform:uppercase;
    color:var(--warm-grey);
    margin-bottom:2px;
    display:block;
  }
  .field{display:flex;flex-direction:column;gap:6px;}

  /* ===== FOOTER ===== */
  footer{
    background:var(--ink);
    color:var(--paper);
    padding:44px 0 28px;
  }
  .footer-inner{
    display:flex;
    justify-content:space-between;
    align-items:center;
    flex-wrap:wrap;
    gap:18px;
  }
  .footer-logo{font-family:var(--serif);font-weight:700;font-size:18px;}
  .footer-logo span{color:var(--red);}
  footer .footer-meta{
    font-family:var(--mono);
    font-size:12px;
    color:#9b958a;
    letter-spacing:.03em;
  }
  .footer-link{
    color:var(--paper);
    text-decoration:underline;
    text-decoration-color:#9b958a;
    text-underline-offset:3px;
  }
  .footer-link:hover{color:#fff;text-decoration-color:var(--red);}
  .draft-banner{
    background:var(--red);
    color:#fff;
    text-align:center;
    font-family:var(--mono);
    font-size:12.5px;
    letter-spacing:.05em;
    text-transform:uppercase;
    padding:9px 0;
  }

  /* ===== RESPONSIVE ===== */
  @media (max-width:900px){
    .about-grid,.contact-grid{grid-template-columns:1fr;gap:40px;}
    .services-grid{grid-template-columns:1fr;}
    .archive-grid{grid-template-columns:repeat(2,1fr);}
  }
  @media (max-width:760px){
    nav.main-nav{display:none;}
    .burger{display:block;}
    .search-btn span{display:none;}
    .archive-grid{grid-template-columns:1fr;}
    .archive-tabs{gap:6px;}
    .archive-tab{padding:10px 14px;font-size:11.5px;}
    h1.hero-title{font-size:38px;}
    .hero-inner{padding:54px 20px 50px;}
    .wrap,.topbar-inner{padding:0 20px;}
    section{padding:56px 0;}
    .hero-frame .frame-caption-r{display:none;}
  }

  nav.main-nav.mobile-open{
    display:flex;
    flex-direction:column;
    position:absolute;
    top:100%;left:0;right:0;
    background:var(--paper);
    border-bottom:2px solid var(--ink);
    padding:8px 0;
  }
  nav.main-nav.mobile-open .nav-item{width:100%;}
  nav.main-nav.mobile-open a.top-link{padding:14px 32px;}
  nav.main-nav.mobile-open .submenu{
    display:block;
    position:static;
    box-shadow:none;
    padding:0 0 8px;
  }
  nav.main-nav.mobile-open .submenu a{padding:10px 48px;font-size:13px;}
