/* © 2026 ABBDisplay — Advertising Business Board Display. All rights reserved. */

    /* TV BOARD SPECIFIC */
    .tv-board { max-width: 1440px; width:100%; margin: 0 auto; background: #0a0800; border: 2px solid #c9a84c; border-radius: 14px; overflow: hidden; box-shadow: 0 4px 40px rgba(201,168,76,0.15); }

    /* RESPONSIVE */
    @media (max-width: 1024px) {
      .tv-side-panel { width:160px; min-width:160px; }
    }
    @media (max-width: 768px) {
      .tv-side-panel { display:none !important; }
      .tv-board { border-radius:0; border-left:none; border-right:none; }
      .tv-body { padding:0; }
      .tv-qr-code { display:none !important; }
    }

    /* TOP BAR */
    .tv-topbar { display:flex; align-items:center; justify-content:space-between; padding:12px 20px; background:#0f0c04; border-bottom:1px solid #2a2208; }
    .tv-topbar-title { font-family:'Cinzel',serif; font-size:19px; font-weight:500; color:#c9a84c; letter-spacing:0.1em; text-transform:uppercase; }
    .tv-topbar-sub { font-size:12px; color:rgba(255,255,255,0.7); letter-spacing:0.08em; text-transform:uppercase; margin-top:2px; }
    .tv-clock { text-align:right; }
    .tv-clock-time { font-family:'Cinzel',serif; font-size:19px; color:#c9a84c; letter-spacing:0.08em; }
    .tv-clock-date { font-size:13px; color:#ffffff; margin-top:2px; }

    /* SEARCH */
    .tv-cat-section .tv-search-wrap { margin-bottom:16px; }
    .tv-search-wrap { padding:10px 16px; background:#f5f2ea; border-bottom:1px solid #e0d8c0; display:flex; align-items:center; gap:8px; position:relative; }
    .tv-search-wrap i { color:#000000; font-size:16px; flex-shrink:0; }
    .tv-search-input { flex:1; background:#ffffff; border:1px solid #d8d0b8; border-radius:6px; padding:7px 12px; font-size:13px; color:#000000; font-family:'Raleway',sans-serif; outline:none; }
    .tv-search-input::placeholder { color:#000000; }
    .tv-search-clear { background:none; border:none; color:#8a7040; cursor:pointer; font-size:16px; display:none; }
    .tv-search-clear.visible { display:block; }
    .tv-search-results { display:none; position:absolute; left:0; right:0; top:100%; z-index:200; background:#ffffff; border:1px solid #e0d8c0; border-radius:0 0 8px 8px; max-height:260px; overflow-y:auto; box-shadow:0 4px 20px rgba(0,0,0,0.1); }
    .tv-search-results.open { display:block; }
    .tv-sr-item { display:flex; align-items:center; gap:10px; padding:10px 16px; border-bottom:0.5px solid #f0ede4; cursor:pointer; transition:background 0.15s; }
    .tv-sr-item:hover { background:#f5f3ee; }
    .tv-sr-logo { width:32px; height:32px; border-radius:6px; background:#f0ede4; border:0.5px solid #e0d8c0; display:flex; align-items:center; justify-content:center; overflow:hidden; flex-shrink:0; }
    .tv-sr-logo img { width:100%; height:100%; object-fit:contain; }
    .tv-sr-init { font-family:'Cinzel',serif; font-size:10px; color:#8a7040; }
    .tv-sr-name { font-size:13px; font-weight:500; color:#1a1400; }
    .tv-sr-cat  { font-size:11px; color:#8a7a50; margin-top:1px; }
    .tv-sr-none { padding:14px 16px; font-size:13px; color:#8a7a50; }

    /* MAIN SLIDE AREA */
    .tv-slide-area { position:relative; overflow:hidden; height:540px; }
    .tv-slide { display:none; height:540px; position:relative; flex-direction:column; }
    .tv-slide.active { display:flex; }
    .tv-slide-overlay { position:absolute; inset:0; z-index:1; }
    .tv-slide-deco { position:absolute; top:0; right:0; width:200px; height:200px; opacity:0.08; z-index:1; pointer-events:none; }
    .tv-slide-inner { position:relative; z-index:2; display:flex; flex-direction:column; justify-content:flex-end; height:540px; }
    .tv-slide-top { display:flex; align-items:center; justify-content:space-between; padding:0; }
    .tv-cat-pill { font-size:12px; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; padding:5px 14px; border-radius:20px; border:0.5px solid transparent; }
    .tv-tier-badge { font-size:9px; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; padding:3px 10px; border-radius:20px; display:flex; align-items:center; gap:4px; }
    .tv-slide-counter { font-size:10px; color:rgba(255,255,255,0.5); font-family:'Cinzel',serif; }

    /* LOGO / VIDEO AREA */
    .tv-media-wrap { display:flex; justify-content:center; padding:0; position:relative; }
    .tv-logo-box { width:100%; max-width:960px; height:400px; border-radius:12px; border:none; background:transparent; display:flex; align-items:center; justify-content:center; overflow:visible; margin:0 auto; }
    .tv-logo-box img { max-width:100%; max-height:100%; width:auto; height:auto; object-fit:contain; display:block; margin:0 auto; }
    .tv-initials { font-family:'Cinzel',serif; font-size:56px; font-weight:500; }

    /* VIDEO PLAYER */
    .tv-video-wrap { position:relative; width:100%; margin:0 auto; overflow:hidden; background:#000; border-radius:12px; }
    .tv-video { width:100%; height:auto; display:block; background:#000; }
    .tv-fullscreen-btn { position:absolute; bottom:8px; right:8px; background:rgba(0,0,0,0.6); border:none; border-radius:6px; padding:5px 8px; color:#ffffff; cursor:pointer; font-size:14px; z-index:10; }
    .tv-fullscreen-btn:hover { background:rgba(0,0,0,0.85); }

    /* SLIDE CARD */
    .tv-slide-card { background:rgba(15,12,4,0.92); border-top:1px solid #2a2208; padding:12px 20px 16px; }
    .tv-biz-name { font-family:'Cinzel',serif; font-size:20px; font-weight:500; color:#f0d98a; margin-bottom:4px; line-height:1.2; }
    .tv-biz-tag  { font-size:12px; color:rgba(255,255,255,0.85); margin-bottom:10px; line-height:1.6; }
    .tv-pills { display:flex; flex-wrap:wrap; gap:6px; }
    .tv-pill { font-size:13px; padding:6px 14px; border-radius:20px; background:#1a1400; border:0.5px solid rgba(255,255,255,0.18); color:#ffffff; display:flex; align-items:center; gap:5px; }
    .tv-pill i { font-size:11px; color:#c9a84c; }
    .tv-pill.social-fb  { color:#1877f2; border-color:#1877f244; }
    .tv-pill.social-ig  { color:#e1306c; border-color:#e1306c44; }
    .tv-pill.social-wa  { color:#25d366; border-color:#25d36644; }
    .tv-pill.social-tt  { color:#ff0050; border-color:#ff005044; }

    /* PROGRESS / COUNTDOWN */
    .tv-progress-wrap { background:#0a0800; height:10px; position:relative; display:flex; align-items:center; }
    .tv-progress-bar { height:100%; background:linear-gradient(90deg,#c9a84c,#f0d98a); width:0%; transition:none; position:absolute; top:0; left:0; }
    .tv-countdown { position:absolute; right:12px; top:50%; transform:translateY(-50%); font-size:20px; font-weight:700; color:#1a1400; font-family:'Cinzel',serif; letter-spacing:0.05em; z-index:2; }

    /* CONTROLS BAR */
    /* old controls removed */
    .tv-pause-btn { display:flex; align-items:center; justify-content:center; gap:6px; background:#1a1400; border:1px solid #c9a84c; border-radius:8px; padding:7px 16px; font-size:12px; color:#c9a84c; cursor:pointer; font-family:'Raleway',sans-serif; font-weight:500; transition:background 0.2s; width:110px; }
    .tv-pause-btn:hover { background:#2a2208; }
    .tv-now-playing { font-size:15px; color:#1a1400; font-family:'Raleway',sans-serif; display:flex; align-items:center; gap:5px; }
    .tv-now-dot { width:6px; height:6px; border-radius:50%; background:#c9a84c; animation:pulse 1.5s ease-in-out infinite; }
    @keyframes pulse { 0%,100%{opacity:1;} 50%{opacity:0.3;} }

    /* TICKER */
    .tv-ticker-wrap { border-top:1px solid #2a2208; border-bottom:1px solid #2a2208; background:#0d0b03; overflow:hidden; position:relative; height:36px; }
    .tv-ticker-label { position:absolute; left:0; top:0; bottom:0; z-index:3; background:#c9a84c; display:flex; align-items:center; padding:0 14px; font-family:'Cinzel',serif; font-size:11px; font-weight:800; letter-spacing:0.1em; text-transform:uppercase; color:#000000; white-space:nowrap; gap:6px; }
    .tv-ticker-label::after { content:''; position:absolute; right:-12px; top:0; bottom:0; width:12px; background:linear-gradient(90deg,#c9a84c,transparent); }
    .tv-ticker-track { display:flex; align-items:center; white-space:nowrap; animation:tvTickScroll 40s linear infinite; padding-left:115px; height:36px; }
    .tv-ticker-track:hover { animation-play-state:paused; }
    .tv-ticker-item { display:inline-flex; align-items:center; gap:8px; padding:0 18px; border-right:0.5px solid #2a2208; height:36px; cursor:pointer; }
    .tv-ticker-item:hover { background:#1a1400; }
    .tv-t-name { font-size:12px; color:#f0d98a; font-weight:600; }
    .tv-t-cat  { font-size:9px; color:#ffffff; }
    .tv-t-sep  { color:#3a2f0e; padding:0 6px; font-size:10px; }
    @keyframes tvTickScroll { 0%{transform:translateX(0);} 100%{transform:translateX(-50%);} }

    /* CATEGORY GRID */
    .tv-cat-section { padding:14px 16px 16px; background:#ffffff; border-top:1px solid #e0d8c0; }
    .tv-cat-label-row { font-family:'Cinzel',serif; font-size:13px; font-weight:700; color:#000000; letter-spacing:0.1em; text-transform:uppercase; margin-bottom:10px; display:flex; align-items:center; gap:6px; }
    .tv-cat-label-row::after { content:''; flex:1; height:1px; background:linear-gradient(90deg,#d0c8a8,transparent); }
    .tv-cat-grid { display:grid; grid-template-columns:repeat(6,minmax(0,1fr)); gap:6px; }
    .tv-cat-card { background:#ffffff; border:1px solid #e0d8c0; border-radius:8px; padding:8px 6px; display:flex; align-items:center; gap:6px; overflow:hidden; position:relative; min-height:58px; cursor:pointer; transition:border-color 0.2s, box-shadow 0.2s; }
    .tv-cat-card:hover { border-color:#c9a84c; box-shadow:0 2px 10px rgba(201,168,76,0.15); }
    .tv-cat-logo { width:42px; height:42px; border-radius:8px; display:flex; align-items:center; justify-content:center; overflow:hidden; flex-shrink:0; }
    .tv-cat-logo img { width:100%; height:100%; object-fit:contain; }
    .tv-cat-init { font-family:'Cinzel',serif; font-size:14px; font-weight:700; }
    .tv-cat-info { flex:1; min-width:0; overflow: hidden; }
    .tv-cat-name-label { font-size:12px; font-weight:700; letter-spacing:0.03em; text-transform:uppercase; margin-bottom:3px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; display:block; width:100%; }
    .tv-cat-biz-name { font-family:'Cinzel',serif; font-size:15px; font-weight:500; color:#000000; line-height:1.2; margin-bottom:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; display:block; max-width:100%; }
    .tv-cat-count { font-size:12px; color:#000000; font-weight:500; }

    /* FOOTER */
    .tv-footer { display:flex; align-items:center; justify-content:space-between; padding:12px 20px; background:#f5f2ea; border-top:1px solid #e0d8c0; }
    .tv-footer-brand { font-family:'Cinzel',serif; font-size:11px; font-weight:700; color:#000000; letter-spacing:0.05em; text-transform:uppercase; }
    .tv-footer-contact { font-size:12px; font-weight:600; color:#000000; text-decoration:none; display:flex; align-items:center; gap:5px; transition:color 0.2s; }
    .tv-footer-contact:hover { color:#c9a84c; }

    /* BUSINESS MODAL */
    .tv-modal { display:none; position:fixed; inset:0; z-index:999; background:rgba(0,0,0,0.82); backdrop-filter:blur(4px); align-items:center; justify-content:center; padding:1rem; }
    .tv-modal-box { background:#0f0c04; border:1px solid #c9a84c55; border-radius:14px; max-width:480px; width:100%; position:relative; overflow:hidden; box-shadow:0 0 60px rgba(201,168,76,0.15); }
    .tv-modal-gold-line { height:2px; background:linear-gradient(90deg,transparent,#c9a84c,transparent); }
    .tv-modal-close { position:absolute; top:12px; right:14px; background:none; border:0.5px solid #3a2f0e; border-radius:6px; padding:4px 8px; color:#8a7040; cursor:pointer; font-size:14px; z-index:2; }
    .tv-modal-body { padding:1.5rem; }
    .tv-modal-footer { padding:10px 1.5rem; display:flex; justify-content:space-between; align-items:center; border-top:1px solid #2a2208; }

    /* CATEGORY DRAWER */
    .tv-drawer { display:none; position:fixed; inset:0; z-index:998; background:rgba(0,0,0,0.75); backdrop-filter:blur(4px); align-items:flex-end; justify-content:center; }
    .tv-drawer-box { background:#ffffff; border:1px solid #e0d8c0; border-radius:14px 14px 0 0; max-width:600px; width:100%; max-height:70vh; display:flex; flex-direction:column; box-shadow:0 -4px 40px rgba(0,0,0,0.15); }
    .tv-drawer-handle { display:flex; justify-content:center; padding:10px 0 0; }
    .tv-drawer-bar { width:36px; height:3px; background:#d0c8a8; border-radius:2px; }
    .tv-drawer-header { display:flex; align-items:center; justify-content:space-between; padding:12px 20px; border-bottom:1px solid #e0d8c0; }
    .tv-drawer-cat-label { font-size:9px; color:#8a7a50; letter-spacing:0.1em; text-transform:uppercase; margin-bottom:3px; }
    .tv-drawer-title { font-family:'Cinzel',serif; font-size:16px; font-weight:500; letter-spacing:0.04em; color:#1a1400; }
    .tv-drawer-close { background:none; border:1px solid #e0d8c0; border-radius:6px; padding:5px 10px; color:#8a7040; cursor:pointer; font-size:14px; }
    .tv-drawer-list { overflow-y:auto; padding:8px 16px 20px; flex:1; }
    .tv-drawer-item { display:flex; align-items:center; gap:12px; padding:10px 12px; border-radius:10px; border:1px solid #e0d8c0; background:#fafaf8; cursor:pointer; margin-bottom:6px; transition:border-color 0.2s, box-shadow 0.2s; }
    .tv-drawer-item:hover { border-color:#c9a84c; box-shadow:0 2px 8px rgba(201,168,76,0.1); }

    /* BODY */
    .tv-body { background:#f0ede4; padding:0; }

    /* CONTENT ROW */
    .tv-content-row { display:flex; align-items:stretch; gap:0; position:relative; }
    .tv-slide-wrap { flex:1; min-width:0; display:flex; flex-direction:column; }

    /* SIDE PANELS */
    .tv-side-panel { width:240px; min-width:240px; flex-shrink:0; display:none; position:relative; overflow:hidden; background:#0a0800; height:540px; }
    .tv-side-panel-left { border-right:1px solid rgba(201,168,76,0.15); }
    .tv-side-panel-right { border-left:1px solid rgba(201,168,76,0.15); }
    .tv-panel-inner { width:100%; height:100%; display:flex; align-items:center; justify-content:center; position:absolute; inset:0; }
    .tv-panel-inner img { width:100%; height:100%; object-fit:cover; object-position:center; display:block; }
    .tv-panel-placeholder { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; padding:1rem; text-align:center; }
    .tv-panel-icon { width:40px; height:40px; border-radius:50%; border:1px solid rgba(201,168,76,0.3); display:flex; align-items:center; justify-content:center; color:rgba(201,168,76,0.4); font-size:18px; }
    .tv-panel-text { font-size:9px; color:rgba(201,168,76,0.3); letter-spacing:0.1em; text-transform:uppercase; font-family:'Cinzel',serif; line-height:1.5; }

    /* CONTROLS */
    .tv-controls { display:flex; align-items:center; justify-content:space-between; padding:10px 20px; background:#ffffff; border-top:1px solid #e0d8c0; position:relative; }
    .tv-controls-btns { display:flex; align-items:center; gap:12px; position:absolute; left:50%; transform:translateX(-50%); }
    .tv-countdown-wrap { flex:1; display:flex; justify-content:flex-end; }
    .tv-controls-btns { display:flex; align-items:center; gap:12px; justify-content:center; }
    .tv-mute-btn { display:flex; align-items:center; justify-content:center; gap:6px; background:transparent; border:1px solid #c9a84c; border-radius:8px; padding:7px 16px; font-size:12px; color:#1a1400; cursor:pointer; font-family:'Raleway',sans-serif; font-weight:600; width:120px; }
    .tv-mute-btn:hover { background:#f9f5ed; }
    .tv-mute-btn.muted { border-color:#c9a84c; color:#8a6a20; }
    .tv-countdown-wrap { flex:1; display:flex; justify-content:flex-end; }
    .tv-countdown-num { font-family:'Cinzel',serif; font-size:26px; font-weight:800; color:#c9a84c; }

    /* MODAL */
    .tv-modal-logo { width:100%; height:220px; border-radius:10px; border:none; background:transparent; display:flex; align-items:center; justify-content:center; overflow:hidden; margin-bottom:1rem; }
    .tv-modal-info { margin-bottom:1.25rem; }
    .tv-modal-cat { font-size:9px; font-weight:600; letter-spacing:0.12em; text-transform:uppercase; margin-bottom:5px; padding:3px 10px; border-radius:20px; display:inline-block; }
    .tv-modal-name { font-family:'Cinzel',serif; font-size:20px; font-weight:500; color:#f0d98a; line-height:1.2; }
    .tv-modal-tag { font-size:13px; color:rgba(255,255,255,0.75); line-height:1.7; margin-bottom:1.25rem; padding-bottom:1.25rem; border-bottom:0.5px solid #2a2208; }
    .tv-modal-details { display:flex; flex-direction:column; gap:10px; }
    .tv-modal-footer-brand { font-size:10px; color:#c9a84c; font-family:'Cinzel',serif; letter-spacing:0.06em; }
    .tv-modal-footer-link { font-size:12px; color:#f0d98a; font-weight:500; text-decoration:none; display:flex; align-items:center; gap:4px; }
