/* style.css — layout och tema för Nstrdamus-formuläret */

/* Reset & box-sizing */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
html, body {
  height: 100%;
}
body {
  font-family: 'Cinzel Decorative', serif;
  color: #FFD97A;
  background: url('../assets/bgrrr9.webp') center/cover no-repeat;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 1rem;
  background-position: center 90%;
}

.header {
  text-align: center;
  margin-top: 0.5rem;
}
.header h1 {
  font-size: 2rem;
  margin-bottom: 0.5rem;
}
.header p.intro {
  font-family: 'Open Sans', serif;
  font-size: 1rem;
  color: #FFF;
  max-width: 450px;
  margin: 0 auto;
}

.form-container {
  background: rgba(0,0,0,0.6);
  border: 1px solid rgba(255,217,122,0.5);
  border-radius: 12px;
  width: 100%;
  max-width: 500px;
  padding: 1rem;
  backdrop-filter: blur(2px);
  margin: 0 auto 0.5rem;
}

form {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

label {
  font-size: 0.9rem;
  color: #FFD97A;
  margin: 0.5; /* Minska vertikal avstånd runt etikett */
}

textarea {
  width: 100%;
  padding: 0.75rem;
  border: 1px solid #FFD97A;
  border-radius: 6px;
  background: rgba(0,0,0,0.4);
  color: #FFF;
  font-family: inherit;
  resize: vertical;
  margin-top: 0.5; /* Minska utrymmet ovanför textarea */
  margin-bottom: 0.5;
}

.textarea-wrapper {
  position: relative;
}

/* Ta bort nedräknarens margin så den inte påverkar flödet */
.char-count {
  position: absolute;
  bottom: 8px;
  right: 12px;
  margin: 0;
  font-size: 0.8rem;
  color: #EEE;
}

/* Ge reveal‑input mer luft nedåt */
#revealDate {
  margin-bottom: 0.4rem; /* justera värdet efter smak */
}

span.char-count {
  font-size: 0.8rem;
  color: #EEE;
  text-align: right;
  display: block;
}

input[type="datetime-local"]::-webkit-calendar-picker-indicator {
  filter: invert(1);
}

input {
  width: 100%;
  padding: 0.75rem;
  border: 1px solid #FFD97A;
  border-radius: 6px;
  background: rgba(0,0,0,0.4);
  color: #FFF;
  font-family: inherit;
}

button {
  padding: 0.75rem;
  font-size: 1.1rem;
  background: #FFD97A;
  color: #1a021f;
  border: none;
  margin-top: 0.7rem;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.2s;
}

button:hover {
  background: #e0c05a;
}

/* ----- Share‑knappar (egna regler) ----- */
.share-buttons button {
  /* Mörk bakgrund och vit text */
  background: #1a021f;
  color: #ce7f20;

  /* Synlig kant i samma färg som bakgrunden */
  border: 1px solid #ce7f20;

  /* Lite plattare look än standard‑knappen */
  padding: 0.5rem 1rem;
  font-size: 0.9rem;
  border-radius: 4px;

  cursor: pointer;
  transition: background 0.2s, border-color 0.2s;
}

.share-buttons button:hover {
  /* Ljusare ton på hover */
  background: #2b1732;     /* testa gärna justera ljushet här */
  border-color: #ce7f20;
}


@media (max-width: 480px) {
  /* Krymp rubriken */
  .header h1 {
    font-size: 1.5rem;
  }
  /* Minska padding i container */
  .form-container {
    padding: 1rem;
  }
  /* Tätare status‑text */
  .form-status {
    font-size: 0.8rem;
    margin-top: 0.3rem;
  }
  /* Om du vill krympa intro‑texten också: */
  .header p.intro {
    font-size: 0.8rem;
  }
    .share-text {
    font-size: 0.8rem; /* eller t.ex. 0.8rem för ännu mindre text */
  }
}


/* Återställ styling efter autofill i Chrome */
input:-webkit-autofill,
input:-webkit-autofill:focus,
input:-webkit-autofill:hover {
  -webkit-text-fill-color: #FFF !important;
  -webkit-box-shadow: 0 0 0px 1000px rgba(0,0,0,0.4) inset !important;
  background-clip: content-box !important;
}

/* Behåll din semitransparenta bakgrund även vid autofyll */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
textarea:-webkit-autofill {
  background-color: rgba(0, 0, 0, 0.4) !important;
  -webkit-box-shadow: 0 0 0px 1000px rgba(0, 0, 0, 0.4) inset !important;
  -webkit-text-fill-color: #FFF !important;
  transition: background-color 5000s ease-in-out 0s !important;
}

/* Ta bort browserns egna focus‑outline och behåll din kantfärg */
input:focus,
textarea:focus {
  outline: none;
  border-color: #FFD97A;
  background: rgba(0,0,0,0.4);
  box-shadow: 0 0 0 2px rgba(255,217,122,0.6);
}

.form-status {
  margin-top: 0.5rem;
  font-size: 0.9rem;
  color: var(--text-alt);
  min-height: 1.2em;
  text-align: center;
}



/* Se till att canvas bara blir 1200 px brett max, centrerat och krymper snyggt på små skärmar */
canvas {
  /* Displaystorlek = ritbufferns storlek, om det finns plats */
  width: 1200px;
  /* Men aldrig bredare än förälderns bredd */
  max-width: 100%;
  /* Behåll proportionerna */
  height: auto;

  /* Centrera i din flex‐container */
  align-self: center;
}
.canvas-container {
  /* Reservera exakt samma proportioner som rit­buffern */
  width: 100%;
  max-width: 600px;        /* eller valfri max-bredd */
  aspect-ratio: 1200 / 630;
  position: relative;
  margin: 0 auto;
  background: rgba(0,0,0,0.1); /* valfritt: visa en svag bakgrund under laddning */
}

.canvas-container canvas {
  /* Säkerställ att canvas fyller containern helt */
  width: 100%;
  height: 100%;
  display: none;           /* göm tills den är ritad */
}

.spinner {
  /* Enkel CSS‑spinner i mitten */
  position: absolute;
  top: 50%; left: 50%;
  width: 48px; height: 48px;
  margin: -24px 0 0 -24px;
  border: 6px solid rgba(255, 217, 122, 0.3);
  border-top-color: #FFD97A;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

/* Själva snurr-animationen */
@keyframes spin {
  to { transform: rotate(360deg); }
}

/* Confirm‑sidan: titel uppe, canvas+knappar nere */
body.confirm-page {
  display: flex;
  flex-direction: column;
  justify-content: flex-start; /* börja högst upp */
  align-items: center;
  height: 100vh;
 background-size: auto 140%;
background-position: center 80%;
}


.share-container {
  background: rgba(0,0,0,0.6);
  border: 1px solid rgba(0,0,0,0.5);
  border-radius: 12px;
  width: 100%;
  max-width: 600px;
  padding: 1rem;
  backdrop-filter: blur(2px);
  margin: auto 1rem 0.2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.1rem;
  margin-top: auto;
}

/* Reveal‑sidans ”container” 
.reveal-container {
  background: rgba(0,0,0,0.6);
  border: 1px solid rgba(0,0,0,0.5);
  border-radius: 12px;
  width: 100%;
  padding: 1rem;
  backdrop-filter: blur(2px);
  margin: 2rem auto;  /* justera marginal om du vill 
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}*/



.share-text {
  text-align: center;
  color: #FFF;
  font-family: 'Open Sans', serif;
  font-size: 1rem;
  margin-bottom: 0.1rem;
}

/* Make confirm‑page text match index */
body.confirm-page,
body.confirm-page .header h1 {
  font-family: 'Cinzel Decorative', serif;
  font-size: 2rem;                 /* matcha index‑rubriken */
  color: #FFD97A;
}

/* Gör reveal‑bilden responsiv */
.share-image img {
  display: block;      /* ta bort inline‑beteendet */
  max-width: 100%;     /* aldrig bredare än sin container */
  height: auto;        /* behåll proportionerna */
  margin: 0 auto;      /* centrerad om container är smalare */
}

/* Gör reveal‐sidan till en fullhöjd‑flex, men allokera utrymmet upptill */
body.reveal-page {
  display: flex;
  flex-direction: column;
  justify-content: flex-start; /* <-- ändrat från space-between */
  height: 100vh;
  padding: 1rem;               /* om du vill behålla ditt padding */
}


/* Skjut ner allt under header till botten */
body.reveal-page .reveal-container {
  background: rgba(0,0,0,0.6);
  border: 1px solid rgba(0,0,0,0.5);
  border-radius: 12px;

  /* skjut ner containern till botten */
  margin-top: auto;

  /* centrera horisontellt */
  margin-left: auto;
  margin-right: auto;

  /* breddbegränsning */
  width: 100%;
  max-width: 1200px;

  /* padding & backdrop som tidigare */
  padding: 1rem;
  backdrop-filter: blur(2px);

  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}



/* Reservera plats för knapparna */
.share-buttons {
  display: flex;              /* behåll flex-layouten även när osynliga */
  gap: 0.5rem;
  min-height: 3rem;           /* justera så det motsvarar knapphöjden */
  visibility: hidden;         /* göm initialt */
  align-items: center;
  justify-content: center;
}

.upload-status {
  display: flex;
  align-items: center;
  gap: 0.1rem;
  margin-top: 0.1rem;      /* luft ovanför */
  visibility: hidden;    /* gömd initialt */
}

.upload-status .spinner {
  width: 1.5rem;
  height: 1.5rem;
  border-width: 4px;     /* mindre spinner än canvas‑varianten */
}

.upload-status.active {
  visibility: visible;
}


/* När vi är klara ger vi klassen .active för att visa dem */
.share-buttons.active {
  visibility: visible;
}

/* När spinnern används i upload-status, låt den vara statisk och inline */
.upload-status .spinner {
  position: static;   /* ta bort absolute */
  margin: 0;          /* inga offset‑värden */
  top: auto;          /* återställ eventuella top/left */
  left: auto;
}

/* Dölj den gamla status‑raden på confirm-sidan */
body.confirm-page #status {
  display: none;
}

/* Busy state for the submit button */
#submit-btn[aria-busy="true"] {
  position: relative;
  pointer-events: none;   /* inga klick medan den jobbar */
  opacity: 0.7;           /* lite uttonad */
}

/* Liten spinner till höger i knappen */
#submit-btn[aria-busy="true"]::after {
  content: "";
  width: 1em;
  height: 1em;
  border: 2px solid currentColor;
  border-top-color: transparent;
  border-radius: 50%;
  animation: nstr-spin 0.8s linear infinite;
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
}

/* Disabled-stil (om du också använder disabled-attributet) */
#submit-btn:disabled {
  cursor: not-allowed;
}

/* Spinner-animation */
@keyframes nstr-spin {
  to { transform: translateY(-50%) rotate(360deg); }
}

/* Respekt för användare som stängt av animeringar */
@media (prefers-reduced-motion: reduce) {
  #submit-btn[aria-busy="true"]::after {
    animation: none;
    border-top-color: currentColor; /* enkel cirkel utan snurr */
  }
}

/* Matcha confirm-sidans knappfont på delningssidan */
.reveal-page .share-buttons a {
  font-family: 'Open Sans', sans-serif;  /* samma som knapparna på confirm */
  text-decoration: none;                  /* ingen underline på länkar */
  display: inline-block;
}

/* Ge länkarna exakt samma look som knapparna */
.reveal-page .share-buttons a {
  background: #1a021f;
  color: #ce7f20;
  border: 1px solid #ce7f20;
  padding: 0.5rem 1rem;
  font-size: 0.9rem;
  border-radius: 4px;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s;
  line-height: 1.1;
}
.reveal-page .share-buttons a:hover {
  background: #2b1732;
  border-color: #ce7f20;
}
.reveal-page .share-buttons a:focus-visible {
  outline: 2px solid #ce7f20;
  outline-offset: 2px;
}
/* Share links on the reveal page: match confirm-page button font */
.reveal-page .share-buttons a {
  font-family: 'Open Sans', sans-serif;  /* <- viktig rad */
  font-weight: 400;
  letter-spacing: 0.2px;                 /* liten optisk matchning */
  text-decoration: none;                  /* ingen underline */
  display: inline-block;
  line-height: 1.1;
}
