/* ============================================================
   VALENCIA POKER CLUB — SHARED STYLESHEET
   Design system: light/white base, sage + clay accents,
   Archivo (display) / Work Sans (body) / Space Mono (utility)
   ============================================================ */

:root{
  --paper:      #FAFAF8;
  --paper-2:    #FFFFFF;
  --ink:        #15151A;
  --muted:      #6B6862;
  --felt:       #5C6F5E;   /* primary accent — quiet nod to the table */
  --felt-deep:  #44544A;
  --chip:       #B4685B;   /* secondary accent — quiet nod to the chips */
  --line:       #E4E1DA;
  --line-2:     #D8D4CB;
  --crest-orange: #F2A33C; /* sampled from the real club logo — used sparingly */

  --display: 'Archivo', sans-serif;
  --body:    'Work Sans', sans-serif;
  --mono:    'Space Mono', monospace;

  --maxw: 1320px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:16px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
img,svg{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
::selection{background:var(--felt);color:var(--paper);}
:focus-visible{outline:2px solid var(--felt);outline-offset:3px;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;}
@media (max-width:640px){ .wrap{padding:0 20px;} }

.eyebrow{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--muted);
}

/* ============ MARQUEE TOP BAR ============ */
.topbar{
  background:var(--ink);
  color:var(--paper);
  overflow:hidden;
  white-space:nowrap;
  height:34px;
  display:flex;
  align-items:center;
}
.marquee{
  display:inline-flex;
  gap:48px;
  padding-left:48px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  animation:scroll 30s linear infinite;
}
.marquee span{display:inline-flex;align-items:center;gap:10px;}
@keyframes scroll{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}
@media (prefers-reduced-motion:reduce){
  .marquee{animation:none;}
}

/* ============ NAV ============ */
header.site{
  position:sticky;top:0;z-index:50;
  background:rgba(250,250,248,.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 0;
}
.brand{display:flex;align-items:center;gap:11px;}
.brand-mark{
  width:42px;height:42px;flex-shrink:0;border-radius:9px;
  object-fit:cover;
}
.brand-word{
  font-family:var(--display);font-weight:800;
  font-size:16px;letter-spacing:.03em;text-transform:uppercase;
  line-height:1.15;
}
.brand-word small{
  display:block;font-family:var(--mono);font-weight:400;font-size:10px;
  letter-spacing:.1em;color:var(--muted);text-transform:uppercase;
}
.nav-links{display:flex;gap:28px;align-items:center;}
.nav-links a{
  font-family:var(--mono);font-size:11.5px;letter-spacing:.07em;
  text-transform:uppercase;color:var(--ink);position:relative;
}
.nav-links a.active{color:var(--felt);}
.nav-links a::after{
  content:'';position:absolute;left:0;right:0;bottom:-6px;height:1px;
  background:var(--felt);transform:scaleX(0);transition:transform .25s ease;
}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1);}
.nav-ig{
  font-family:var(--mono);font-size:11.5px;letter-spacing:.05em;
  border:1px solid var(--ink);padding:8px 14px;border-radius:999px;
  display:flex;align-items:center;gap:7px;white-space:nowrap;
  transition:background .2s ease,color .2s ease;
}
.nav-ig:hover{background:var(--ink);color:var(--paper);}
.lang-switch{
  display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11.5px;
  letter-spacing:.05em;
}
.lang-switch a{color:var(--muted);padding:4px 2px;}
.lang-switch a.active{color:var(--ink);font-weight:700;border-bottom:1px solid var(--felt);}
.lang-switch a:hover{color:var(--ink);}
.lang-switch .sep{color:var(--line-2);}
@media (max-width:480px){ .lang-switch{display:none;} }
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:6px;}
.nav-toggle span{display:block;width:22px;height:1.5px;background:var(--ink);margin:5px 0;}
@media (max-width:860px){
  .nav-links{display:none;}
  .nav-toggle{display:block;}
}
@media (max-width:480px){
  .nav-ig{display:none;}
  .brand-word{font-size:14px;}
}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:13px;letter-spacing:.06em;text-transform:uppercase;
  background:var(--ink);color:var(--paper);
  padding:15px 26px;border-radius:999px;border:1px solid var(--ink);
  transition:background .2s ease,color .2s ease,transform .15s ease;
  cursor:pointer;
}
.btn:hover{background:var(--felt);border-color:var(--felt);transform:translateY(-1px);}
.btn.ghost{background:transparent;color:var(--ink);}
.btn.ghost:hover{background:var(--ink);color:var(--paper);}

/* ============ HERO (shared shape, content differs per page) ============ */
.hero{ position:relative; padding:80px 0 60px; overflow:hidden; }
.hero-grid{ display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:center; }
@media (max-width:900px){ .hero-grid{grid-template-columns:1fr;gap:36px;} }
.hero h1{
  font-family:var(--display);font-weight:800;
  font-size:clamp(36px,5.6vw,68px);
  line-height:1.0;letter-spacing:-.01em;
  text-transform:uppercase;margin:16px 0 20px;
}
.hero h1 em{ font-style:normal;color:var(--felt); }
.hero p.lede{ font-size:18px;color:var(--muted);max-width:440px;margin:0 0 28px; }
.hero-art{
  position:relative;aspect-ratio:4/5;border-radius:18px;
  background:linear-gradient(160deg,var(--felt) 0%,var(--felt-deep) 55%, #2f3a33 100%);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.hero-art svg{width:54%;opacity:.92;}
.hero-art .tag{
  position:absolute;bottom:18px;left:18px;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--paper);background:rgba(0,0,0,.18);padding:7px 12px;border-radius:999px;
}

/* ============ SIMPLE PAGE HEADER (for non-home pages) ============ */
.page-head{
  padding:54px 0 36px;border-bottom:1px solid var(--line);
}
.page-head h1{
  font-family:var(--display);font-weight:800;font-size:clamp(32px,4.6vw,52px);
  text-transform:uppercase;letter-spacing:-.01em;margin:14px 0 12px;line-height:1.03;
}
.page-head p{font-size:17px;color:var(--muted);max-width:560px;margin:0;}

/* ============ INTRO / TEXT BAND ============ */
.intro{ border-top:1px solid var(--line);border-bottom:1px solid var(--line); padding:50px 0; }
.intro-grid{ display:grid;grid-template-columns:.4fr .6fr;gap:48px; }
@media (max-width:760px){ .intro-grid{grid-template-columns:1fr;gap:18px;} }
.intro h2{
  font-family:var(--display);font-weight:700;font-size:15px;
  letter-spacing:.1em;text-transform:uppercase;margin:0;
}
.intro p{ font-size:19px;max-width:640px;margin:0 0 16px;color:var(--ink); }
.intro p:last-child{margin-bottom:0;}
.intro p strong{color:var(--felt);font-weight:600;}

/* ============ GENERIC CONTENT SECTION ============ */
.section{ padding:56px 0; }
.section.bordered{ border-top:1px solid var(--line); }
.section-head{
  display:flex;align-items:baseline;justify-content:space-between;
  padding-bottom:28px;gap:16px;flex-wrap:wrap;
}
.section-head h2{
  font-family:var(--display);font-weight:800;font-size:clamp(24px,3vw,36px);
  text-transform:uppercase;margin:0;letter-spacing:-.01em;
}

/* ============ CARD GRID (generic 3-col) ============ */
.grid3{ display:grid;grid-template-columns:repeat(3,1fr);gap:28px; }
@media (max-width:900px){ .grid3{grid-template-columns:repeat(2,1fr);gap:20px;} }
@media (max-width:560px){ .grid3{grid-template-columns:1fr;} }

.card{ display:flex;flex-direction:column; }
.card-art{
  aspect-ratio:1/1.18;border-radius:14px;background:var(--paper-2);
  border:1px solid var(--line);display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;margin-bottom:16px;
  transition:border-color .2s ease;
}
.card:hover .card-art{border-color:var(--line-2);}
.card-art svg{width:38%;color:var(--ink);opacity:.82;transition:transform .35s ease;}
.card:hover .card-art svg{transform:scale(1.06);}
.card-art .swatch{ position:absolute;top:14px;left:14px;width:10px;height:10px;border-radius:50%; }
.card-info{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;}
.card-name{ font-family:var(--body);font-weight:600;font-size:15px; text-transform:uppercase;letter-spacing:.02em; }
.card-sub{font-size:13px;color:var(--muted);margin-top:3px;}
.card-price{font-family:var(--mono);font-size:14px;white-space:nowrap;}

/* ---- product photo cards (Shop) ---- */
.card-art.photo{ aspect-ratio:2/3;background:var(--paper-2); }
.card-art.photo img{
  width:100%;height:100%;object-fit:cover;object-position:top center;
  transition:transform .35s ease;
}
.card:hover .card-art.photo img{transform:scale(1.035);}

/* ---- shop policy notice ---- */
.shop-policy{
  border:1px solid var(--line);border-radius:14px;background:var(--paper-2);
  padding:22px 26px;margin-bottom:32px;display:flex;gap:16px;align-items:flex-start;
}
.shop-policy .dot{
  width:8px;height:8px;border-radius:50%;background:var(--chip);
  margin-top:7px;flex-shrink:0;
}
.shop-policy p{margin:0;font-size:14.5px;line-height:1.6;color:var(--ink);}
.shop-policy p strong{color:var(--felt-deep);}
.shop-policy p+p{margin-top:6px;color:var(--muted);}

/* ============ INFO CARD (about / members benefits) ============ */
.info-card{
  border:1px solid var(--line);border-radius:14px;padding:28px;background:var(--paper-2);
}
.info-card .num{ font-family:var(--mono);font-size:12px;color:var(--felt);letter-spacing:.08em; }
.info-card h3{
  font-family:var(--display);font-weight:800;font-size:19px;text-transform:uppercase;
  margin:10px 0 10px;letter-spacing:-.005em;
}
.info-card p{font-size:14.5px;color:var(--muted);margin:0;}

/* ============ FEATURE BAND ============ */
.feature{ background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line); padding:60px 0; }
.feature-grid{ display:grid;grid-template-columns:.85fr 1.15fr;gap:54px;align-items:center; }
@media (max-width:860px){ .feature-grid{grid-template-columns:1fr;gap:30px;} }
.feature-art{
  aspect-ratio:4/5;border-radius:16px;background:linear-gradient(155deg,#efece4,#e3ded2);
  display:flex;align-items:center;justify-content:center;border:1px solid var(--line);
  overflow:hidden;
}
.feature-art svg{width:34%;color:var(--chip);}
.feature-art.photo img{width:100%;height:100%;object-fit:cover;object-position:top center;}
.feature-copy .eyebrow{margin-bottom:14px;display:block;}
.feature-copy h3{
  font-family:var(--display);font-weight:800;font-size:clamp(24px,3.2vw,38px);
  text-transform:uppercase;line-height:1.05;margin:0 0 16px;
}
.feature-copy p{font-size:16.5px;color:var(--muted);max-width:480px;margin:0 0 26px;}
.feature-meta{font-family:var(--mono);font-size:15px;margin-bottom:22px;display:block;}

/* ============ CALLOUT BAND (next tournament etc.) ============ */
.callout{
  border:1px solid var(--line-2);border-radius:18px;
  background:linear-gradient(155deg,#eef2ef,#e7ece8);
  padding:40px;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;
}
.callout .eyebrow{color:var(--felt-deep);}
.callout h3{
  font-family:var(--display);font-weight:800;font-size:clamp(22px,3vw,32px);
  text-transform:uppercase;margin:10px 0 6px;
}
.callout p{margin:0;color:var(--felt-deep);opacity:.85;font-size:15px;}

/* ============ NEWS LIST ============ */
.news-item{
  display:grid;grid-template-columns:140px 1fr auto;gap:24px;align-items:baseline;
  padding:26px 0;border-bottom:1px solid var(--line);
}
@media (max-width:700px){ .news-item{grid-template-columns:1fr;gap:6px;} }
.news-date{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.05em;}
.news-title{font-family:var(--display);font-weight:700;font-size:19px;text-transform:uppercase;margin:0 0 6px;}
.news-excerpt{font-size:14.5px;color:var(--muted);margin:0;max-width:560px;}
.news-tag{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--felt-deep);background:#eef2ef;padding:5px 10px;border-radius:999px;white-space:nowrap;
}

/* ============ BENEFIT LIST (members) ============ */
.benefit{ display:flex;gap:16px;padding:20px 0;border-bottom:1px solid var(--line); }
.benefit .mark{
  width:28px;height:28px;border-radius:50%;border:1.4px solid var(--felt);color:var(--felt);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--mono);font-size:12px;
}
.benefit h4{font-family:var(--body);font-weight:600;font-size:15.5px;margin:0 0 4px;text-transform:uppercase;letter-spacing:.01em;}
.benefit p{font-size:14.5px;color:var(--muted);margin:0;}

/* ============ PASSWORD GATE ============ */
.gate-wrap{
  min-height:70vh;display:flex;align-items:center;justify-content:center;padding:60px 20px;
}
.gate-card{
  max-width:380px;width:100%;text-align:center;background:var(--paper-2);
  border:1px solid var(--line);border-radius:18px;padding:40px 32px;
}
.gate-card img{width:64px;height:64px;border-radius:14px;margin:0 auto 18px;}
.gate-card h1{
  font-family:var(--display);font-weight:800;font-size:20px;text-transform:uppercase;
  margin:0 0 8px;
}
.gate-card p{font-size:14px;color:var(--muted);margin:0 0 24px;}
.gate-card input[type="password"]{
  width:100%;font-family:var(--mono);font-size:14px;padding:13px 16px;
  border:1px solid var(--line-2);border-radius:999px;margin-bottom:14px;
  background:var(--paper);color:var(--ink);text-align:center;
}
.gate-card input[type="password"]:focus{outline:2px solid var(--felt);outline-offset:2px;}
.gate-error{color:var(--chip);font-size:13px;margin-top:12px;display:none;}
footer{padding:50px 0 36px;}
.footer-top{
  display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:32px;
  padding-bottom:32px;border-bottom:1px solid var(--line);margin-bottom:24px;
}
.footer-cols{display:flex;gap:60px;flex-wrap:wrap;}
.footer-col h4{
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);margin:0 0 14px;
}
.footer-col a{display:block;font-size:14px;margin-bottom:9px;}
.footer-col a:hover{color:var(--felt);}
.footer-bottom{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
  font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.04em;
}
