/* giftex — Tema navideño cálido (mobile-first)
   Objetivos:
   - Tipografías grandes y legibles
   - Targets táctiles grandes (niños / adultos mayores)
   - Apariencia cálida + festiva sin “ruido”
   - Responsive: móvil vertical → tableta horizontal → PC
*/

@font-face {
  font-family: 'FuturaHandwritten';
  src: url('/assets/fonts/FuturaHandwritten.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'GillesHandwriting';
  src: url('/assets/fonts/GillesHandwriting.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}


@font-face {
  font-family: 'Tomodachy';
  src: url('/assets/fonts/Tomodachy.otf') format('opentype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Rhigen';
  src: url('/assets/fonts/Rhigen.otf') format('opentype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'MountainsOfChristmas';
  src: url('/assets/fonts/MountainsofChristmas-Regular.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'ChristmasSounds';
  src: url('/assets/fonts/ChristmasSounds.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

:root{
  --bg: #fff7ef;           /* crema cálida */
  --bg2:#fff1e3;           /* variante */
  --card:#ffffff;
  --text:#1b1b1b;
  --muted:#2E4057;

  --red:#b51f2e;           /* rojo navidad */
  --green:#1f6b4f;         /* verde pino */
  --gold:#caa03e;          /* dorado */
  --ink:#2b2b2b;

  --border: rgba(0,0,0,.10);
  --shadow: 0 8px 24px rgba(30, 20, 10, .12);

  --radius: 18px;
  --radius2: 22px;

  --tap: 54px;             /* mínimo target táctil */
  --fs: 23px;              /* base móvil */
  --fs-lg: 25px;           /* accesibilidad */
  --line: 1.5;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: 'Tomodachy', 'ChristmasSounds', system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: var(--fs);
  /*font-weight: bold;*/
  line-height: var(--line);
  letter-spacing: 1.5px;
  color: var(--text);
  background:
    radial-gradient(1200px 800px at 10% 0%, rgba(202,160,62,.20), transparent 55%),
    radial-gradient(900px 600px at 90% 5%, rgba(181,31,46,.16), transparent 55%),
    radial-gradient(1000px 700px at 70% 100%, rgba(31,107,79,.18), transparent 60%),
    linear-gradient(180deg, var(--bg), var(--bg2));
}

a{color:inherit}
a:focus, button:focus, input:focus, select:focus, textarea:focus{
  outline: 3px solid rgba(202,160,62,.55);
  outline-offset: 2px;
  border-radius: 10px;
}

.container{
  max-width: 960px;
  margin: 0 auto;
  padding: 18px 14px 40px;
}

/* Encabezado / navegación */
.topnav{
  position: sticky;
  top: 0;
  z-index: 10;
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  padding: 12px 10px;
  margin: 0 -14px 14px;
  backdrop-filter: blur(8px);
  background: rgba(255,255,255,.65);
  border-bottom: 1px solid var(--border);
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight: 800;
}

.brand-badge{
  width: 38px;
  height: 38px;
  border-radius: 999px;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.9), rgba(255,255,255,0) 55%),
              linear-gradient(135deg, var(--red), #e24b43);
  box-shadow: 0 6px 16px rgba(181,31,46,.25);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-size: 18px;
}

.muted{opacity:.78;color:var(--muted)}

/* Tarjetas */
.card{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius2);
  padding: 16px;
  margin: 14px 0;
  box-shadow: var(--shadow);
}

.card h1{
  font-family: 'MountainsOfChristmas', 'ChristmasSounds', serif;    
  font-size: 30px; 
  color: #BD0003;
  margin: 0 0 10px;
}

.card h1 strong{
  font-weight: 900;
  color: var(--green);

  text-shadow:
    0 1px 0 rgba(202,160,62,.55),   /* luz dorada arriba */
    0 2px 2px rgba(0,0,0,.18);      /* sombra suave abajo */
  letter-spacing: 1.8px;
}

.card h2{font-size: 22px; margin: 0 0 10px}

.hr{
  height:1px;
  background: var(--border);
  margin: 12px 0;
}

/* Controles */
input, select, textarea, button{
  font-family: inherit; 
  font-size: var(--fs);
  letter-spacing: 1.5px;
  border-radius: 20px;
  border: 1px solid rgba(0,0,0,.18);
  padding: 12px 14px;
}

input, select, textarea{
  width: 100%;
  background: rgba(255,255,255,.92);
}

textarea{min-height: 120px}

button, .btn{
  min-height: var(--tap);
  cursor: pointer;
  font-weight: 800;
  border: 0;
  color: #fff;
  background: linear-gradient(135deg, var(--green), #2e8b63);
  box-shadow: 0 10px 18px rgba(31,107,79,.20);
  transition: transform .05s ease, filter .12s ease;
}

button:hover, .btn:hover{filter: brightness(1.03)}
button:active, .btn:active{transform: translateY(1px)}

.btn-secondary{
  background: linear-gradient(135deg, var(--red), #e24b43);
  box-shadow: 0 10px 18px rgba(181,31,46,.18);
}

.btn-ghost{
  background: rgba(255,255,255,.8);
  color: var(--ink);
  border: 1px solid var(--border);
  box-shadow: none;
}

/* Layout helpers */
.row{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
}
.row > *{flex: 1; min-width: 220px}

.grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr)); /* móvil: 2 columnas */
  gap: 12px;
}
.grid .card{margin:0}

img{
    max-width:100%; 
    height:auto; 
    border-radius: 16px
}

.profile-photo-wrapper {
  display: flex;
  justify-content: center;
  margin: 1rem 0;
}

.profile-photo {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  margin: 0 auto;
}

/* Movil horizontal */
@media (min-width: 576px) {
  .profile-photo {
    max-width: 60vw;
  }
}

/* Tablet horizontal */
@media (min-width: 900px) {
  .profile-photo {
    max-width: 50vw;
  }
}

/* Desktop */
@media (min-width: 1200px) {
  .profile-photo {
    max-width: min(40vw, 360px);
  }
}

.avatar{
  width: 54px;
  height: 54px;
  border-radius: 999px;
  object-fit: cover;
  border: 2px solid rgba(202,160,62,.35);
  box-shadow: 0 8px 18px rgba(0,0,0,.10);
}

.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(202,160,62,.14);
  border: 1px solid rgba(202,160,62,.25);
  font-weight: 700;
}

/* Enlaces tipo “nav” */
.navlink{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 10px 12px;
  border-radius: 999px;
  text-decoration:none;
  background: rgba(255,255,255,.75);
  border: 1px solid var(--border);
}
.navlink:hover{filter: brightness(1.02)}

/* Accesibilidad extra */
.big{
  font-size: var(--fs-lg);
}
small{font-size: 18px; color: var(--muted)}

/* Tablet horizontal (≥ 900px) */
@media (min-width: 900px){
  :root{ --fs: 23px; }
  .container{max-width: 1100px; padding: 22px 18px 56px;}
  .grid{grid-template-columns: repeat(3, minmax(0, 1fr));}
  .card{padding: 18px}
  .card h1{
      font-size: 35px;
      font-family: 'MountainsOfChristmas', 'ChristmasSounds', serif; 
      color: #BD0003;
   }
}

/* PC (≥ 1200px) */
@media (min-width: 1200px){
  .grid{grid-template-columns: repeat(4, minmax(0, 1fr));}
  .topnav{margin: 0 -18px 18px; padding: 14px 14px;}
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  *{transition:none!important; scroll-behavior:auto!important}
}


/* Ideas como tarjetas */
.ideas-grid{
  display:grid;
  grid-template-columns: 1fr; /* móvil: 1 por fila para legibilidad */
  gap: 12px;
}

.idea-card{
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(0,0,0,.10);
  border-radius: var(--radius2);
  padding: 14px;
  box-shadow: 0 10px 20px rgba(20, 12, 6, .10);
}

.idea-top{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
}

.idea-title strong{
  font-size: 20px;
}

.idea-meta{
  display:flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 8px;
}

.idea-photo{
  margin-top: 12px;
}

.upload-row{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items:center;
  margin-top: 10px;
}
.upload-row input[type="file"]{
  min-height: var(--tap);
  padding: 10px;
  background: rgba(255,255,255,.85);
}

/* Tablet: 2 columnas de ideas */
@media (min-width: 900px){
  .ideas-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}

/* PC: 3 columnas de ideas */
@media (min-width: 1200px){
  .ideas-grid{ grid-template-columns: repeat(3, minmax(0,1fr)); }
}




/* Prioridad: pequeña estrella dorada (SVG) */
.star-icon{
  width: 18px;
  height: 18px;
  fill: var(--gold);
  opacity: .9;
  filter: drop-shadow(0 2px 2px rgba(0,0,0,.10));
}

.idea-titleline{
  display:flex;
  gap: 10px;
  align-items:center;
}

.idea-actions{
  display:flex;
  gap: 8px;
  flex-wrap: nowrap;
  align-items:center;
  justify-content:flex-end;
}
.idea-actions form{margin:0}

.icon-btn{
  min-height: 44px;
  min-width: 44px;
  padding: 10px;
  font-size: 18px;
  line-height: 1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.icon-btn svg{width:18px;height:18px}

.icon-btn-danger{
  background: rgba(255,255,255,.8);
  color: var(--ink);
  border: 1px solid rgba(181,31,46,.25);
}

/* File input con estética del tema */
.upload-row input[type="file"]{
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.18);
  background: rgba(255,255,255,.92);
  padding: 10px;
  min-height: var(--tap);
}

.upload-row input[type="file"]::file-selector-button{
  border: 0;
  border-radius: 12px;
  padding: 10px 12px;
  margin-right: 10px;
  font-weight: 800;
  color: #fff;
  background: linear-gradient(135deg, var(--green), #2e8b63);
  box-shadow: 0 10px 18px rgba(31,107,79,.20);
  cursor: pointer;
}

.upload-row input[type="file"]::-webkit-file-upload-button{
  border: 0;
  border-radius: 12px;
  padding: 10px 12px;
  margin-right: 10px;
  font-weight: 800;
  color: #fff;
  background: linear-gradient(135deg, var(--green), #2e8b63);
  box-shadow: 0 10px 18px rgba(31,107,79,.20);
  cursor: pointer;
}


/* File input: ocultar control nativo y usar botón/label */
.file-input-hidden{
  position:absolute;
  left:-9999px;
  width:1px;
  height:1px;
  overflow:hidden;
}

.file-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height: var(--tap);
  padding: 10px 14px;
  border-radius: 16px;
  font-weight: 900;
  text-decoration:none;
  cursor:pointer;
  user-select:none;

  border: 1px solid rgba(0,0,0,.18);
  background: rgba(255,255,255,.92);
  color: var(--ink);
  box-shadow: 0 10px 18px rgba(0,0,0,.08);
}

.file-btn:hover{ transform: translateY(-1px); }
.file-btn:active{ transform: translateY(0); }

.file-row{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}
