/*
Theme Name: ExchangeTraffic Directory
Theme URI: https://exchangetraffic.net
Author: Naveed
Author URI: https://exchangetraffic.net
Description: A premium web directory theme. List sites by category with no signup needed. Built for crypto, AI, online earning and coding niches. Frontend submit form, admin approval, 120 plus categories, fast and fully responsive.
Version: 1.6.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: exchangetraffic
Tags: directory, listings, business, responsive, custom-menu
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root{
  --ink:#141b2e;          /* deep slate header and dark text */
  --ink-soft:#2a3349;
  --paper:#ffffff;        /* content surface */
  --canvas:#f4f6fb;       /* page background, section bands */
  --line:#e6e9f2;         /* hairline borders */
  --line-soft:#eef1f8;
  --muted:#6b7488;        /* secondary text */
  --muted-2:#9aa1b3;
  --brand:#16b364;        /* go green, primary action */
  --brand-dark:#0e8a4c;
  --brand-soft:#e7f8ef;
  --gold:#f2b537;         /* premium highlight accent */
  --danger:#e5484d;
  --shadow-sm:0 1px 2px rgba(20,27,46,.06), 0 1px 3px rgba(20,27,46,.05);
  --shadow-md:0 6px 18px rgba(20,27,46,.08);
  --shadow-lg:0 18px 40px rgba(20,27,46,.14);
  --radius:12px;
  --radius-lg:18px;
  --radius-pill:999px;
  --wrap:1200px;
  --font-display:'Sora',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --font-body:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}

/* ============================================================
   BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--canvas);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.2;margin:0 0 .5em}
p{margin:0 0 1em}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 20px}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-weight:600;font-size:15px;
  padding:11px 20px;border-radius:var(--radius-pill);
  border:0;cursor:pointer;transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 6px 16px rgba(22,179,100,.32)}
.btn-primary:hover{background:var(--brand-dark);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.25)}
.btn-ghost:hover{background:rgba(255,255,255,.1)}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:16px;top:16px;background:#fff;padding:10px 16px;border-radius:8px;z-index:9999}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{background:var(--ink);position:sticky;top:0;z-index:200;box-shadow:0 1px 0 rgba(255,255,255,.04)}
.header-bar{display:flex;align-items:center;justify-content:space-between;height:70px;gap:18px}
.brand{display:flex;align-items:center;gap:10px;color:#fff}
.brand-mark{
  width:38px;height:38px;border-radius:10px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--brand),#0bd07e);color:#08130c;font-weight:800;font-family:var(--font-display);font-size:18px;
}
.brand-name{font-family:var(--font-display);font-weight:800;font-size:21px;letter-spacing:-.02em}
.brand-name span{color:var(--brand)}
.header-nav{display:flex;align-items:center;gap:26px;margin-left:auto}
.header-nav a{color:#cdd3e0;font-size:15px;font-weight:500;transition:color .15s}
.header-nav a:hover{color:#fff}
.header-actions{display:flex;align-items:center;gap:12px}
.nav-toggle{display:none;background:transparent;border:0;color:#fff;cursor:pointer;padding:6px}
.nav-toggle svg{width:26px;height:26px}

/* mobile submit bar (hidden on desktop) */
.mobile-submit{display:none;background:var(--paper);border-bottom:1px solid var(--line);padding:10px 0}
.mobile-submit .btn{width:100%;justify-content:center}

/* ============================================================
   HERO / SEARCH
   ============================================================ */
.hero{background:linear-gradient(180deg,var(--ink) 0%,#1b2440 100%);color:#fff;padding:54px 0 60px;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(600px 240px at 80% -20%,rgba(22,179,100,.22),transparent 70%);pointer-events:none}
.hero-inner{position:relative;z-index:1;max-width:760px}
.hero .eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);color:#d6dcea;font-size:13px;font-weight:600;padding:6px 14px;border-radius:var(--radius-pill);margin-bottom:18px}
.hero .eyebrow b{color:var(--brand)}
.hero h1{font-size:42px;letter-spacing:-.03em;margin-bottom:14px}
.hero p{color:#b9c0d2;font-size:18px;max-width:560px;margin-bottom:26px}
.hero-search{display:flex;gap:10px;max-width:560px;background:#fff;border-radius:var(--radius-pill);padding:7px 7px 7px 20px;box-shadow:var(--shadow-lg)}
.hero-search input{flex:1;border:0;outline:0;font-size:16px;font-family:var(--font-body);color:var(--ink);background:transparent}
.hero-search input::placeholder{color:var(--muted-2)}
.hero-stats{display:flex;gap:30px;margin-top:28px;flex-wrap:wrap}
.hero-stats div{display:flex;flex-direction:column}
.hero-stats b{font-family:var(--font-display);font-size:24px;color:#fff}
.hero-stats span{font-size:13px;color:#9aa3ba;text-transform:uppercase;letter-spacing:.06em}

/* ============================================================
   AD SLOTS
   ============================================================ */
.ad-slot{margin:26px auto;max-width:var(--wrap);padding:0 20px}
.ad-box{
  background:var(--paper);border:1px dashed var(--line);border-radius:var(--radius);
  min-height:90px;display:grid;place-items:center;color:var(--muted-2);font-size:13px;
  font-family:var(--font-display);letter-spacing:.04em;text-transform:uppercase;
}
.ad-inline{margin:30px 0}
.ad-zone{margin:0 auto;text-align:center;max-width:100%;overflow:hidden}
.ad-zone img{display:inline-block}
.sidebar .ad-box{min-height:250px}

/* ============================================================
   CATEGORY SECTIONS (main page)
   ============================================================ */
.sections{padding:36px 0 50px}
.cat-section{margin-bottom:42px}
.cat-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:18px;padding-bottom:12px;border-bottom:2px solid var(--line)}
.cat-head .title-wrap{display:flex;align-items:center;gap:12px}
.cat-dot{width:10px;height:10px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 4px var(--brand-soft)}
.cat-head h2{font-size:22px;letter-spacing:-.02em;margin:0}
.cat-head .count{font-size:13px;font-weight:600;color:var(--muted);background:var(--canvas);padding:3px 10px;border-radius:var(--radius-pill)}
.see-more{font-family:var(--font-display);font-weight:600;font-size:14px;color:var(--brand-dark);display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.see-more svg{width:16px;height:16px;transition:transform .15s}
.see-more:hover svg{transform:translateX(3px)}

/* listing grid */
.listing-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}

/* premium listing card */
.listing-card{
  display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);
  border-radius:16px;padding:20px 18px;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease;
  position:relative;overflow:hidden;
}
.listing-card::before{
  content:"";position:absolute;left:0;top:0;height:3px;width:100%;
  background:linear-gradient(90deg,var(--brand),#0bd07e);
  transform:scaleX(0);transform-origin:left;transition:transform .3s ease;
}
.listing-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:#cfe9da}
.listing-card:hover::before{transform:scaleX(1)}
.lc-top{display:flex;gap:13px;align-items:center;margin-bottom:13px}
.listing-fav{
  flex:0 0 50px;width:50px;height:50px;border-radius:13px;background:var(--canvas);
  border:1px solid var(--line);display:grid;place-items:center;overflow:hidden;box-shadow:inset 0 0 0 3px #fff;
}
.listing-fav img{width:30px;height:30px;object-fit:contain}
.listing-fav svg{width:26px;height:26px;color:var(--muted-2)}
.lc-head{min-width:0}
.lc-head h3{font-size:16.5px;margin:0 0 2px;letter-spacing:-.01em;line-height:1.25}
.lc-head h3 a{transition:color .15s}
.lc-head h3 a:hover{color:var(--brand-dark)}
.listing-url{font-size:12px;color:var(--brand-dark);font-weight:600;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.listing-desc{font-size:14px;color:var(--muted);margin:0 0 18px;line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}
.lc-foot{display:flex;justify-content:center;margin-top:auto}
.read-more{
  display:inline-flex;align-items:center;gap:7px;font-family:var(--font-display);font-weight:600;font-size:13.5px;
  color:var(--brand-dark);background:transparent;border:1.5px solid var(--brand);
  padding:9px 24px;border-radius:var(--radius-pill);transition:all .2s ease;
}
.read-more svg{width:15px;height:15px;transition:transform .2s ease}
.read-more:hover{background:var(--brand);color:#fff;box-shadow:0 8px 18px rgba(22,179,100,.28)}
.read-more:hover svg{transform:translateX(4px)}
.listing-badge{position:absolute;top:0;right:14px;font-size:10px;font-weight:700;color:var(--gold);background:#fff7e6;padding:4px 9px;border-radius:0 0 8px 8px;text-transform:uppercase;letter-spacing:.05em;z-index:2}


.empty-cat{grid-column:1/-1;text-align:center;color:var(--muted-2);font-size:14px;padding:24px;background:var(--paper);border:1px dashed var(--line);border-radius:var(--radius)}

/* ============================================================
   ARCHIVE / CATEGORY PAGE
   ============================================================ */
.page-head{background:var(--ink);color:#fff;padding:40px 0}
.page-head .crumb{font-size:13px;color:#9aa3ba;margin-bottom:8px}
.page-head .crumb a{color:#cdd3e0}
.page-head h1{font-size:32px;letter-spacing:-.02em;margin:0}
.page-head p{color:#b9c0d2;margin:8px 0 0;max-width:620px}
.archive-wrap{padding:36px 0 60px}
.archive-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.load-more-wrap{text-align:center;margin-top:34px}
#load-more-btn[disabled]{opacity:.5;cursor:default;transform:none}
.cat-chips{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 30px}
.cat-chip{font-size:13px;font-weight:600;color:var(--ink-soft);background:var(--paper);border:1px solid var(--line);padding:7px 14px;border-radius:var(--radius-pill);transition:all .15s}
.cat-chip:hover,.cat-chip.active{background:var(--brand);color:#fff;border-color:var(--brand)}

/* ============================================================
   SINGLE LISTING
   ============================================================ */
.single-layout{display:grid;grid-template-columns:1fr 320px;gap:34px;padding:36px 0 60px;align-items:start}
.single-main{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.single-cover{width:100%;aspect-ratio:16/7;object-fit:cover;background:var(--canvas)}
.single-pad{padding:30px}
.single-head{display:flex;gap:18px;align-items:center;margin-bottom:18px}
.single-fav{flex:0 0 64px;width:64px;height:64px;border-radius:14px;background:var(--canvas);border:1px solid var(--line);display:grid;place-items:center;overflow:hidden}
.single-fav img{width:40px;height:40px;object-fit:contain}
.single-fav svg{width:34px;height:34px;color:var(--muted-2)}
.single-title h1{font-size:28px;margin:0 0 4px;letter-spacing:-.02em}
.single-meta{display:flex;flex-wrap:wrap;gap:14px;font-size:13px;color:var(--muted);margin-bottom:4px}
.single-meta span{display:inline-flex;align-items:center;gap:5px}
.single-meta svg{width:15px;height:15px}
.visit-row{display:flex;gap:12px;flex-wrap:wrap;margin:22px 0}
.visit-btn{background:var(--brand);color:#fff;font-family:var(--font-display);font-weight:600;padding:13px 26px;border-radius:var(--radius-pill);display:inline-flex;align-items:center;gap:8px;box-shadow:0 6px 16px rgba(22,179,100,.3);transition:transform .15s,background .15s}
.visit-btn:hover{background:var(--brand-dark);transform:translateY(-2px)}
.visit-btn svg{width:17px;height:17px}
.single-desc{font-size:16px;color:#3a4254;line-height:1.75}
.single-desc h2{position:relative;font-family:var(--font-display);font-size:22px;color:var(--ink);margin:30px 0 12px;padding-left:16px;letter-spacing:-.01em}
.single-desc h2::before{content:"";position:absolute;left:0;top:5px;bottom:5px;width:5px;border-radius:4px;background:linear-gradient(180deg,var(--brand),#0bd07e)}
.single-desc h2:first-child{margin-top:0}
.single-desc h3{position:relative;font-family:var(--font-display);font-size:17px;color:var(--ink);margin:22px 0 8px;padding-left:16px}
.single-desc h3::before{content:"";position:absolute;left:1px;top:9px;width:8px;height:8px;border-radius:50%;background:var(--brand)}
.single-desc p{margin:0 0 14px}
.single-desc ul,.single-desc ol{margin:0 0 16px;padding-left:22px}
.single-desc li{margin-bottom:7px}
.single-desc strong{color:var(--ink);font-weight:600}
.single-desc a{color:var(--brand-dark);text-decoration:underline}

/* like / dislike */
.vote-box{display:flex;flex-direction:column;align-items:center;gap:14px;margin:32px auto 8px;padding:24px;background:var(--canvas);border:1px solid var(--line);border-radius:16px;max-width:440px}
.vote-box .vq{font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--ink)}
.vote-btns{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.vote-btn{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--line);border-radius:var(--radius-pill);padding:10px 22px;cursor:pointer;font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--ink-soft);transition:all .18s ease}
.vote-btn svg{width:18px;height:18px}
.vote-btn .cnt{font-variant-numeric:tabular-nums}
.vote-btn.like:hover,.vote-btn.like.active{border-color:var(--brand);color:var(--brand-dark);background:var(--brand-soft)}
.vote-btn.dislike:hover,.vote-btn.dislike.active{border-color:var(--danger);color:var(--danger);background:#fdecec}
.vote-btn:disabled{cursor:default}
.vote-btn.like.active svg{fill:var(--brand-soft)}
.single-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:24px 0}
.single-gallery img{border-radius:10px;border:1px solid var(--line);aspect-ratio:4/3;object-fit:cover;cursor:zoom-in}
.single-tags{display:flex;flex-wrap:wrap;gap:8px;margin:22px 0 6px}
.single-tags a{font-size:13px;color:var(--ink-soft);background:var(--canvas);border:1px solid var(--line);padding:5px 12px;border-radius:var(--radius-pill)}
.single-tags a:hover{background:var(--brand-soft);color:var(--brand-dark)}

/* sidebar */
.sidebar{display:flex;flex-direction:column;gap:22px;position:sticky;top:90px}
.widget{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.widget h3{font-size:15px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink);margin:0 0 14px;padding-bottom:10px;border-bottom:1px solid var(--line)}
.mini-list{display:flex;flex-direction:column;gap:12px}
.mini-item{display:flex;gap:11px;align-items:center}
.mini-fav{flex:0 0 36px;width:36px;height:36px;border-radius:9px;background:var(--canvas);border:1px solid var(--line);display:grid;place-items:center;overflow:hidden}
.mini-fav img{width:22px;height:22px;object-fit:contain}
.mini-fav svg{width:18px;height:18px;color:var(--muted-2)}
.mini-item .mt{font-size:14px;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.mini-item .mv{font-size:12px;color:var(--muted-2)}

/* ============================================================
   SUBMIT MODAL
   ============================================================ */
.modal-overlay{position:fixed;inset:0;background:rgba(15,20,35,.6);backdrop-filter:blur(3px);z-index:1000;display:none;align-items:flex-start;justify-content:center;padding:30px 16px;overflow-y:auto}
.modal-overlay.open{display:flex}
.modal{background:var(--paper);width:100%;max-width:600px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:pop .25s ease;margin:auto 0}
@keyframes pop{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--line)}
.modal-head h2{font-size:20px;margin:0}
.modal-head p{font-size:13px;color:var(--muted);margin:3px 0 0}
.modal-close{background:var(--canvas);border:0;width:34px;height:34px;border-radius:9px;cursor:pointer;font-size:18px;color:var(--muted);display:grid;place-items:center}
.modal-close:hover{background:#fde8e8;color:var(--danger)}
.modal-body{padding:24px;max-height:70vh;overflow-y:auto}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:6px}
.field .hint{font-weight:400;color:var(--muted-2);font-size:12px}
.field input[type=text],.field input[type=url],.field textarea,.field select{
  width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:10px;font-family:var(--font-body);font-size:15px;color:var(--ink);background:#fff;transition:border-color .15s,box-shadow .15s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:0;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
.field textarea{resize:vertical;min-height:90px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.file-drop{border:1.5px dashed var(--line);border-radius:10px;padding:14px;text-align:center;font-size:13px;color:var(--muted);cursor:pointer;transition:border-color .15s,background .15s}
.file-drop:hover{border-color:var(--brand);background:var(--brand-soft)}
.file-drop b{color:var(--brand-dark)}
.thumbs{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.thumbs .th{position:relative;width:64px;height:64px;border-radius:8px;overflow:hidden;border:1px solid var(--line)}
.thumbs .th img{width:100%;height:100%;object-fit:cover}
.thumbs .th button{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;border:0;cursor:pointer;font-size:11px;line-height:1;display:grid;place-items:center}
.modal-foot{padding:18px 24px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:10px}
.form-msg{padding:12px 14px;border-radius:9px;font-size:14px;margin-bottom:14px;display:none}
.form-msg.ok{display:block;background:var(--brand-soft);color:var(--brand-dark)}
.form-msg.err{display:block;background:#fde8e8;color:var(--danger)}
.tag-help{font-size:12px;color:var(--muted-2);margin-top:4px}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--ink);color:#aeb6c8;padding:50px 0 26px;margin-top:30px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px}
.footer-grid h4{color:#fff;font-size:15px;margin:0 0 14px}
.footer-grid .brand{margin-bottom:14px}
.footer-grid p{font-size:14px;line-height:1.7}
.footer-links{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}
.footer-links a{font-size:14px;color:#aeb6c8;transition:color .15s}
.footer-links a:hover{color:var(--brand)}
.footer-bottom{margin-top:36px;padding-top:20px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;color:#7e879c}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:980px){
  .single-layout{grid-template-columns:1fr}
  .sidebar{position:static;flex-direction:row;flex-wrap:wrap}
  .sidebar .widget{flex:1 1 280px}
  .archive-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .header-nav{position:absolute;top:70px;left:0;right:0;background:var(--ink);flex-direction:column;align-items:stretch;gap:0;padding:8px 0;display:none;border-top:1px solid rgba(255,255,255,.08)}
  .header-nav.open{display:flex}
  .header-nav a{padding:13px 20px}
  .header-actions .submit-desktop{display:none}
  .nav-toggle{display:block}
  .mobile-submit{display:block}
  .hero h1{font-size:32px}
  .hero p{font-size:16px}
  .listing-grid{grid-template-columns:1fr}
  .archive-grid{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .single-gallery{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .hero-stats{gap:20px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;scroll-behavior:auto}
}
