

  :root{
    --bg-void:#0a0908;
    --bg-panel:#131210;
    --bg-card:#1a1814;
    --gold:#c9a227;
    --gold-bright:#e0b93a;
    --gold-pale:#e9d9a4;
    --bronze:#6f5817;
    --ink:#f3ecd9;
    --ink-muted:#b3a988;
    --ink-faint:#7a7363;
    --line:rgba(201,162,39,0.22);
    --radius: 2px;
    --maxw: 1240px;
    --ease: cubic-bezier(.22,.61,.36,1);
  }

  *{box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  @media (prefers-reduced-motion: reduce){
    html{scroll-behavior:auto;}
    *{animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important;}
  }

  body{
    margin:0;
    background:var(--bg-void);
    color:var(--ink);
    font-family:'Space Grotesk', sans-serif;
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
  }

  ::selection{ background:var(--gold); color:#0a0908; }
  a{ color:inherit; text-decoration:none; }
  :focus-visible{ outline:2px solid var(--gold-bright); outline-offset:3px; }
  img,canvas{ display:block; max-width:100%; }
  button{ font-family:inherit; }

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

  .eyebrow{
    font-size:12.5px; letter-spacing:0.28em; text-transform:uppercase;
    color:var(--gold); font-weight:600; display:flex; align-items:center; gap:14px;
  }
  .eyebrow::before{ content:''; width:28px; height:1px; background:var(--gold); display:inline-block; }

  h1,h2,h3{ font-family:'Cormorant Garamond', serif; font-weight:600; margin:0; color:var(--ink); }

  .btn{
    font-size:14px; font-weight:600; letter-spacing:0.04em;
    padding:15px 30px; border-radius:var(--radius); cursor:pointer;
    border:1px solid transparent; display:inline-flex; align-items:center; gap:10px;
    transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease);
    white-space:nowrap;
  }
  .btn-primary{ background:linear-gradient(135deg, var(--gold-bright), var(--gold) 60%, var(--bronze)); color:#13110c; }
  .btn-primary:hover{ transform:translateY(-2px); box-shadow:0 14px 30px -10px rgba(201,162,39,0.55); }
  .btn-ghost{ background:transparent; border-color:var(--line); color:var(--ink); }
  .btn-ghost:hover{ border-color:var(--gold); color:var(--gold-pale); }
  .btn:active{ transform:translateY(0) scale(0.98); }
  .btn[disabled]{ opacity:0.55; cursor:not-allowed; transform:none !important; }

  /* ---------- HEADER ---------- */
  header{ position:fixed; top:0; left:0; right:0; z-index:200; background:rgba(10,9,8,0.72); backdrop-filter:blur(10px); border-bottom:1px solid var(--line); }
  .nav{ display:flex; align-items:center; justify-content:space-between; height:78px; }
  .brand{ font-family:'Cormorant Garamond', serif; font-size:clamp(22px, 2.4vw, 28px); letter-spacing:0.02em; display:flex; align-items:center; gap:12px; line-height:1.05; }
  .brand .mark{
    width:38px; height:38px; border:1px solid var(--gold); border-radius:50%;
    display:flex; align-items:center; justify-content:center; font-size:17px; color:var(--gold);
    user-select:none; flex-shrink:0;
  }
  .brand small{ display:block; font-family:'Space Grotesk',sans-serif; font-size:10px; letter-spacing:0.16em; color:var(--ink-faint); text-transform:uppercase; margin-top:2px; }
  .navlinks{ display:flex; gap:38px; font-size:13.5px; letter-spacing:0.03em; }
  .navlinks a{ color:var(--ink-muted); position:relative; padding:4px 0; transition:color .25s; }
  .navlinks a:hover, .navlinks a:focus-visible{ color:var(--gold-pale); }
  .navlinks a::after{ content:''; position:absolute; left:0; right:0; bottom:-2px; height:1px; background:var(--gold); transform:scaleX(0); transition:transform .3s var(--ease); }
  .navlinks a:hover::after{ transform:scaleX(1); }
  .nav-right{ display:flex; align-items:center; gap:18px; }
  .burger{ display:none; width:34px; height:34px; background:none; border:none; cursor:pointer; flex-direction:column; justify-content:center; gap:6px; }
  .burger span{ height:1px; background:var(--gold-pale); display:block; transition:.3s; }
  .burger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .burger.open span:nth-child(2){ opacity:0; }
  .burger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

  .mobile-menu{ display:none; position:fixed; inset:78px 0 0 0; background:rgba(10,9,8,0.98); z-index:190; flex-direction:column; padding:40px 32px; gap:26px; }
  .mobile-menu.show{ display:flex; }
  .mobile-menu a{ font-family:'Cormorant Garamond', serif; font-size:28px; color:var(--ink); border-bottom:1px solid var(--line); padding-bottom:14px; }

  @media (max-width: 880px){
    .navlinks{ display:none; }
    .burger{ display:flex; }
    .nav-right .btn{ display:none; }
  }

  /* ---------- HERO ---------- */
  .hero{ position:relative; min-height:100vh; display:flex; align-items:center; overflow:hidden; padding-top:78px; }
  #dust-canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:0; opacity:0.8; }
  .hero::before{
    content:''; position:absolute; inset:0;
    background: radial-gradient(ellipse 80% 60% at 25% 30%, rgba(201,162,39,0.10), transparent 60%),
                linear-gradient(180deg, rgba(10,9,8,0.2), var(--bg-void) 92%);
    z-index:1; pointer-events:none;
  }
  .hero-inner{ position:relative; z-index:2; width:100%; display:grid; grid-template-columns:1fr 90px; gap:40px; align-items:end; padding-bottom:90px; }
  .hero-text{ max-width:760px; }
  .hero-text .eyebrow{ margin-bottom:26px; }
  .lema{ font-size:clamp(40px, 6.4vw, 84px); font-style:normal; font-weight:500; line-height:1.08; letter-spacing:-0.01em; }
  .lema em{ font-style:normal; color:var(--gold-pale); }
  @supports (background-clip:text) or (-webkit-background-clip:text){
    .lema em{
      background:linear-gradient(90deg, var(--gold-bright), var(--gold-pale));
      -webkit-background-clip:text; background-clip:text; color:transparent;
    }
  }
  .hero-sub{ margin-top:26px; font-size:16.5px; color:var(--ink-muted); max-width:540px; font-weight:400; }
  .hero-cta{ display:flex; gap:16px; margin-top:42px; flex-wrap:wrap; }
  .hero-rail{ display:flex; flex-direction:column; align-items:center; justify-content:flex-end; height:100%; gap:14px; }
  .hero-rail .line{ width:1px; flex:1; background:linear-gradient(180deg, transparent, var(--gold), transparent); min-height:80px; }
  .hero-rail span{ font-size:10.5px; letter-spacing:0.3em; color:var(--ink-faint); writing-mode:vertical-rl; text-transform:uppercase; }
  @media (max-width:720px){
    .hero-inner{ grid-template-columns:1fr; padding-bottom:60px; }
    .hero-rail{ display:none; }
  }

  /* ---------- SECTION SHELL ---------- */
  section{ position:relative; padding:120px 0; }
  .panel{ background:var(--bg-panel); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
  .section-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:40px; margin-bottom:64px; flex-wrap:wrap; }
  .section-head h2{ font-size:clamp(30px,4vw,46px); margin-top:16px; max-width:600px; }
  .section-head p{ max-width:380px; color:var(--ink-muted); font-size:14.5px; margin-top:16px; }

  .reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
  .reveal.in{ opacity:1; transform:translateY(0); }

  /* ---------- SERVICES ---------- */
  .grid-services{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
  .service-card{ background:var(--bg-card); padding:38px 32px; transition:background .35s; position:relative; }
  .service-card:hover{ background:#201d16; }
  .service-card .icon{ width:38px; height:38px; color:var(--gold); margin-bottom:22px; }
  .service-card .icon svg{ width:100%; height:100%; }
  .service-card h3{ font-size:21px; font-weight:600; margin-bottom:10px; letter-spacing:0.01em; }
  .service-card p{ font-size:13.8px; color:var(--ink-muted); margin:0; }
  @media (max-width:880px){ .grid-services{ grid-template-columns:repeat(2,1fr); } }
  @media (max-width:560px){ .grid-services{ grid-template-columns:1fr; } }

  /* ---------- MISSION ---------- */
  .mission{ display:grid; grid-template-columns:1.1fr 0.9fr; gap:70px; align-items:center; }
  .mission-text p{ color:var(--ink-muted); font-size:16px; margin-top:20px; }
  .mission-text .pull{ font-family:'Cormorant Garamond', serif; font-style:italic; font-size:24px; color:var(--gold-pale); margin-top:28px; border-left:1px solid var(--gold); padding-left:22px; }
  .mission-glyph{ font-family:'Cormorant Garamond', serif; font-size:380px; line-height:0.7; color:transparent; -webkit-text-stroke:1px var(--line); text-align:center; user-select:none; pointer-events:none; }
  @media (max-width:880px){
    .mission{ grid-template-columns:1fr; }
    .mission-glyph{ display:none; }
  }

  /* ---------- COLABORADORES ---------- */
  .collab-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:36px; }
  .collab-card{ text-align:center; }
  .collab-avatar{
    width:96px; height:96px; border-radius:50%; overflow:hidden; margin:0 auto 16px;
    border:1px solid var(--line); background:var(--bg-card);
    display:flex; align-items:center; justify-content:center;
    font-family:'Cormorant Garamond', serif; font-size:34px; color:var(--gold);
  }
  .collab-avatar img{ width:100%; height:100%; object-fit:contain; background:#fff; }
  .collab-card h4{ font-size:17px; font-family:'Cormorant Garamond', serif; font-weight:600; margin:0 0 4px; color:var(--ink); }
  .collab-card p{ font-size:13px; color:var(--ink-muted); margin:0; }
  .collab-card a{ font-size:12px; color:var(--gold-pale); text-decoration:underline; margin-top:8px; display:inline-block; }
  @media (max-width:880px){ .collab-grid{ grid-template-columns:repeat(2,1fr); } }
  @media (max-width:560px){ .collab-grid{ grid-template-columns:1fr; } }

  .collab-empty{ grid-column:1/-1; text-align:center; padding:60px 20px; color:var(--ink-muted); font-size:14.5px; border:1px dashed var(--line); }

  /* ---------- CABECERA DE PÁGINA (p.ej. colaboradores.html) ---------- */
  .page-header{ padding:168px 0 80px; border-bottom:1px solid var(--line); }
  .page-header .section-head{ margin-bottom:0; }

  /* ---------- COLABORA CON NOSOTROS (cierre de página) ---------- */
  .collab-cta{ background:var(--bg-panel); border-top:1px solid var(--line); text-align:center; padding:90px 0; }
  .collab-cta h2{ font-size:clamp(28px,3.4vw,38px); max-width:640px; margin:16px auto 0; }
  .collab-cta p{ color:var(--ink-muted); max-width:480px; margin:18px auto 30px; font-size:15px; }

  /* ---------- TRANSPARENCIA (CIF / dirección / antigüedad) ---------- */
  .trust{ background:var(--gold-pale); border-top:1px solid var(--gold); border-bottom:1px solid var(--gold); padding:56px 0; }
  .trust-inner{ display:flex; align-items:center; gap:48px; }
  .trust-seal{
    width:78px; height:78px; border-radius:50%; flex-shrink:0; display:none;
    align-items:center; justify-content:center; border:1px solid rgba(10,9,8,0.35);
    font-family:'Cormorant Garamond', serif; font-size:32px; color:rgba(10,9,8,0.55);
  }
  .trust-grid{ flex:1; display:grid; grid-template-columns:repeat(4,1fr); gap:32px; }
  .trust-item{ display:flex; flex-direction:column; gap:6px; }
  .trust-label{ font-size:10.5px; letter-spacing:0.16em; text-transform:uppercase; color:rgba(10,9,8,0.55); font-weight:600; }
  .trust-value{ font-size:15.5px; color:var(--bg-void); font-weight:600; }
  @media (min-width:720px){ .trust-seal{ display:flex; } }
  @media (max-width:880px){ .trust-grid{ grid-template-columns:repeat(2,1fr); } }
  @media (max-width:560px){ .trust-grid{ grid-template-columns:1fr; } .trust-inner{ gap:28px; } }

  /* ---------- CUSTOM SECTIONS (creadas desde el admin) ---------- */
  .custom-section{ padding:90px 0; border-top:1px solid var(--line); }
  .custom-section .wrap{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
  .custom-section .copy h2{ font-size:clamp(28px,3.6vw,40px); margin-top:14px; }
  .custom-section .copy p{ color:var(--ink-muted); margin-top:18px; font-size:15.5px; white-space:pre-wrap; }
  .custom-section .media{ display:flex; flex-direction:column; gap:14px; }
  .custom-section .media img{ width:100%; border:1px solid var(--line); }
  .custom-section .media video{ width:100%; border:1px solid var(--line); background:#000; }
  .custom-section .media iframe{ width:100%; aspect-ratio:16/9; border:1px solid var(--line); }
  .custom-section .media a{ color:var(--gold-pale); text-decoration:underline; font-size:14px; }
  .custom-section:only-child, .custom-section:last-of-type{ }
  @media (max-width:880px){ .custom-section .wrap{ grid-template-columns:1fr; } }

  /* ---------- PROYECTO ---------- */
  .proyecto{ background:var(--bg-panel); border-top:1px solid var(--line); }
  .proyecto-grid{ display:grid; grid-template-columns:1fr 1fr; gap:70px; align-items:start; }
  .proyecto-copy h2{ font-size:clamp(32px,4.4vw,50px); margin-top:16px; }
  .proyecto-copy p{ color:var(--ink-muted); margin-top:22px; font-size:16px; max-width:480px; }
  .steps{ margin-top:46px; display:flex; flex-direction:column; gap:26px; }
  .step{ display:flex; gap:20px; align-items:flex-start; }
  .step .num{ font-family:'Cormorant Garamond', serif; font-style:italic; font-size:30px; color:var(--gold); width:42px; flex-shrink:0; }
  .step .txt h4{ margin:0 0 4px 0; font-size:15.5px; font-weight:600; color:var(--ink); }
  .step .txt p{ margin:0; font-size:13.8px; color:var(--ink-muted); max-width:380px; }

  .donate-card{ background:var(--bg-card); border:1px solid var(--line); padding:42px; position:relative; }
  .donate-card::before{ content:''; position:absolute; top:-1px; left:-1px; right:-1px; height:3px; background:linear-gradient(90deg, var(--bronze), var(--gold-bright), var(--bronze)); }
  .donate-head{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:8px; }
  .donate-head h3{ font-size:24px; }
  .donate-sub{ font-size:13.5px; color:var(--ink-muted); margin-bottom:30px; }
  .field{ margin-bottom:20px; }
  .field label{ display:block; font-size:11.5px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:9px; }
  .field input, .field textarea, .field select{
    width:100%; background:#0e0d0a; border:1px solid var(--line); color:var(--ink);
    padding:13px 14px; font-family:'Space Grotesk', sans-serif; font-size:14.5px; border-radius:var(--radius);
    transition:border-color .25s; resize:none;
  }
  .field input:focus, .field textarea:focus, .field select:focus{ border-color:var(--gold); outline:none; }
  .charcount{ font-size:11px; color:var(--ink-faint); text-align:right; margin-top:6px; }
  .qty-row{ display:flex; align-items:center; justify-content:space-between; background:#0e0d0a; border:1px solid var(--line); padding:14px 16px; border-radius:var(--radius); }
  .qty-label{ font-size:13px; color:var(--ink-muted); }
  .qty-controls{ display:flex; align-items:center; gap:14px; }
  .qty-btn{ width:28px; height:28px; border:1px solid var(--line); background:transparent; color:var(--gold-pale); cursor:pointer; font-size:16px; line-height:1; border-radius:50%; display:flex; align-items:center; justify-content:center; transition:border-color .2s, color .2s; }
  .qty-btn:hover{ border-color:var(--gold); color:var(--gold); }
  .qty-num{ font-family:'Cormorant Garamond', serif; font-size:21px; min-width:18px; text-align:center; }
  .total-row{ display:flex; justify-content:space-between; align-items:baseline; margin-top:24px; margin-bottom:26px; border-top:1px solid var(--line); padding-top:20px; }
  .total-row .lbl{ font-size:13px; color:var(--ink-muted); letter-spacing:0.05em; }
  .total-row .amt{ font-family:'Cormorant Garamond', serif; font-size:32px; color:var(--gold-pale); }
  .donate-card .btn-primary{ width:100%; justify-content:center; }
  .form-note{ font-size:11.5px; color:var(--ink-faint); margin-top:16px; text-align:center; }
  .success-panel{ display:none; text-align:center; padding:20px 0; }
  .success-panel.show{ display:block; }
  .donate-form.hide{ display:none; }
  .success-panel .ref{ font-family:'Cormorant Garamond', serif; font-style:italic; font-size:30px; color:var(--gold-pale); margin:18px 0 10px; }
  .success-panel p{ color:var(--ink-muted); font-size:13.8px; max-width:340px; margin:0 auto 22px; }
  .success-icon{ width:56px;height:56px;margin:0 auto 18px; color:var(--gold); }
  @media (max-width:920px){ .proyecto-grid{ grid-template-columns:1fr; } }

  /* ---------- CONTACT STRIP ---------- */
  .contact-strip{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:24px; padding:60px 0; border-top:1px solid var(--line); }
  .contact-strip h3{ font-size:30px; max-width:480px; }
  .contact-strip a.btn{ flex-shrink:0; }

  /* ---------- FOOTER ---------- */
  footer{ background:#070605; border-top:1px solid var(--line); padding:80px 0 0; }
  .footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:50px; padding-bottom:60px; }
  .footer-brand .brand{ margin-bottom:16px; }
  .footer-brand p{ color:var(--ink-faint); font-size:13.5px; max-width:280px; }
  .footer-col h4{ font-size:11.5px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ink-faint); margin:0 0 18px 0; }
  .footer-col ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:12px; }
  .footer-col a, .footer-col button{ background:none; border:none; padding:0; text-align:left; color:var(--ink-muted); font-size:13.8px; cursor:pointer; font-family:'Space Grotesk', sans-serif; transition:color .2s; }
  .footer-col a:hover, .footer-col button:hover{ color:var(--gold-pale); }
  .footer-bottom{ border-top:1px solid var(--line); padding:26px 0; display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px; font-size:12px; color:var(--ink-faint); }
  .social-row{ display:flex; gap:12px; margin-top:18px; flex-wrap:wrap; }
  .social-row a{ width:36px; height:36px; border:1px solid var(--line); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--ink-muted); transition:border-color .2s, color .2s; }
  .social-row a:hover{ border-color:var(--gold); color:var(--gold-pale); }
  .social-row svg{ width:16px; height:16px; }
  @media (max-width:880px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
  @media (max-width:560px){
    .footer-grid{ grid-template-columns:1fr; }
    .contact-strip{ flex-direction:column; align-items:flex-start; }
  }

  /* ---------- MODAL (genérico: legal + login admin) ---------- */
  .modal-backdrop{ position:fixed; inset:0; z-index:500; background:rgba(7,6,5,0.82); backdrop-filter:blur(4px); display:none; align-items:center; justify-content:center; padding:24px; }
  .modal-backdrop.show{ display:flex; }
  .modal{ background:var(--bg-panel); border:1px solid var(--line); max-width:640px; width:100%; max-height:80vh; overflow-y:auto; padding:44px; position:relative; }
  .modal h2{ font-size:28px; margin-bottom:6px; }
  .modal .updated{ font-size:11.5px; color:var(--ink-faint); margin-bottom:26px; display:block; }
  .modal h3{ font-size:16px; color:var(--gold-pale); margin:26px 0 8px; font-family:'Space Grotesk',sans-serif; font-weight:600; }
  .modal p, .modal li{ font-size:14px; color:var(--ink-muted); line-height:1.75; }
  .modal ul{ padding-left:20px; }
  .modal-close{ position:absolute; top:24px; right:24px; width:32px; height:32px; border:1px solid var(--line); background:none; color:var(--ink-muted); cursor:pointer; border-radius:50%; font-size:16px; transition:border-color .2s, color .2s; }
  .modal-close:hover{ border-color:var(--gold); color:var(--gold); }
  .admin-msg{ font-size:12.5px; margin-top:10px; min-height:16px; }
  .admin-msg.err{ color:#d96b6b; }
  .admin-msg.ok{ color:var(--gold-pale); }

  /* ---------- COOKIE BANNER ---------- */
  .cookie-banner{ position:fixed; bottom:-200px; left:24px; right:24px; max-width:560px; background:var(--bg-card); border:1px solid var(--line); box-shadow:0 24px 60px -20px rgba(0,0,0,0.6); padding:26px 30px; z-index:400; transition:bottom .6s var(--ease); }
  .cookie-banner.show{ bottom:24px; }
  .cookie-banner p{ font-size:13px; color:var(--ink-muted); margin:0 0 18px 0; }
  .cookie-banner .row{ display:flex; gap:12px; flex-wrap:wrap; }
  .cookie-banner .btn{ padding:11px 20px; font-size:12.5px; }

  /* ---------- ADMIN (oculto hasta iniciar sesión) ---------- */
  body.admin-mode [data-edit]{ outline:1px dashed rgba(201,162,39,0.4); outline-offset:4px; cursor:text; border-radius:2px; }
  body.admin-mode [data-edit]:focus{ outline:1px dashed var(--gold-bright); background:rgba(201,162,39,0.06); }

  .admin-fab{
    position:fixed; bottom:26px; right:26px; width:54px; height:54px; border-radius:50%;
    background:linear-gradient(135deg, var(--gold-bright), var(--bronze)); border:none; color:#13110c; cursor:pointer;
    display:none; align-items:center; justify-content:center; box-shadow:0 16px 34px -10px rgba(201,162,39,0.6); z-index:300;
  }
  .admin-fab.show{ display:flex; }
  .admin-fab svg{ width:22px; height:22px; }

  .save-bar{ position:fixed; left:0; right:0; bottom:0; background:#0e0d0a; border-top:1px solid var(--gold); padding:16px 32px; display:none; align-items:center; justify-content:space-between; z-index:310; gap:20px; flex-wrap:wrap; }
  .save-bar.show{ display:flex; }
  .save-bar span{ font-size:13px; color:var(--ink-muted); }

  .admin-panel{ position:fixed; top:0; right:-440px; bottom:0; width:420px; max-width:92vw; background:var(--bg-panel); border-left:1px solid var(--line); z-index:350; overflow-y:auto; padding:30px 28px 60px; transition:right .4s var(--ease); }
  .admin-panel.show{ right:0; }
  .admin-panel h3{ font-size:20px; margin-bottom:4px; }
  .admin-panel .tag{ font-size:11px; color:var(--ink-faint); letter-spacing:.12em; text-transform:uppercase; margin-bottom:20px; display:block; }
  .admin-tabs{ display:flex; gap:8px; margin-bottom:26px; flex-wrap:wrap; }
  .admin-tab{ font-size:12px; padding:8px 14px; border:1px solid var(--line); background:transparent; color:var(--ink-muted); cursor:pointer; border-radius:20px; }
  .admin-tab.active{ border-color:var(--gold); color:var(--gold-pale); }
  .admin-section{ display:none; }
  .admin-section.active{ display:block; }
  .admin-close-panel{ position:absolute; top:24px; right:24px; background:none; border:1px solid var(--line); color:var(--ink-muted); width:30px; height:30px; border-radius:50%; cursor:pointer; }
  .mini-list{ display:flex; flex-direction:column; gap:10px; margin-top:18px; }
  .mini-item{ border:1px solid var(--line); padding:12px 14px; border-radius:2px; display:flex; justify-content:space-between; align-items:center; gap:10px; }
  .mini-item .info{ font-size:13px; color:var(--ink-muted); overflow:hidden; min-width:0; }
  .mini-item .info strong{ color:var(--ink); display:block; font-size:13.5px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
  .mini-item .info span{ display:block; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
  .mini-item .actions{ display:flex; gap:8px; flex-shrink:0; }
  .mini-btn{ font-size:11px; border:1px solid var(--line); background:none; color:var(--ink-muted); padding:6px 10px; cursor:pointer; border-radius:2px; }
  .mini-btn:hover{ border-color:var(--gold); color:var(--gold-pale); }
  .admin-helptext{ font-size:13px; color:var(--ink-muted); line-height:1.7; }

  /* ---------- WHATSAPP FLOTANTE ---------- */
  .whatsapp-fab{
    position:fixed; bottom:26px; left:26px; width:58px; height:58px; border-radius:50%;
    background:linear-gradient(135deg, var(--gold-bright), var(--gold) 55%, var(--bronze));
    color:#13110c; display:flex; align-items:center; justify-content:center;
    box-shadow:0 16px 34px -10px rgba(201,162,39,0.55); z-index:250;
    transition:transform .3s var(--ease), box-shadow .3s var(--ease);
  }
  .whatsapp-fab:hover{ transform:translateY(-3px) scale(1.04); box-shadow:0 20px 40px -10px rgba(201,162,39,0.7); }
  .whatsapp-fab svg{ width:26px; height:26px; }
  .whatsapp-fab::before{
    content:''; position:absolute; inset:-6px; border-radius:50%; border:1px solid rgba(201,162,39,0.4);
    animation:wa-pulse 2.6s ease-out infinite;
  }
  @keyframes wa-pulse{
    0%{ transform:scale(0.9); opacity:0.7; }
    70%{ transform:scale(1.35); opacity:0; }
    100%{ opacity:0; }
  }
  @media (prefers-reduced-motion: reduce){ .whatsapp-fab::before{ animation:none; } }
  @media (max-width:560px){ .whatsapp-fab{ width:52px; height:52px; bottom:20px; left:20px; } }
  body.admin-mode .whatsapp-fab{ display:none; }

  /* ---------- SUBIDA DE ARCHIVOS (en formularios del admin) ---------- */
  .upload-row{ display:flex; gap:8px; }
  .upload-row input{ flex:1; }
  .upload-btn{
    flex-shrink:0; font-size:11.5px; border:1px solid var(--line); background:none; color:var(--gold-pale);
    padding:0 16px; cursor:pointer; border-radius:var(--radius); white-space:nowrap;
  }
  .upload-btn:hover{ border-color:var(--gold); }
  .upload-status{ display:block; font-size:11.5px; color:var(--ink-faint); margin-top:6px; min-height:14px; }
  .upload-zone{
    border:1px dashed var(--line); border-radius:var(--radius); padding:10px;
    transition:border-color .2s, background .2s;
  }
  .upload-zone.drag-over{ border-color:var(--gold); background:rgba(201,162,39,0.08); }
  .upload-hint{ display:block; font-size:11px; color:var(--ink-faint); margin-top:8px; }

  #payment-element{ background:#0e0d0a; border:1px solid var(--line); border-radius:var(--radius); padding:14px; min-height:44px; }

  .sr-only{ position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); }
