/* ==========================================================================
   Teachers Pet - Certificate Design Templates (Classic, Modern, Playful)
   ========================================================================== */

/* 
   These styles apply to the certificates in the preview and print views.
   They rely on CSS custom properties (--cert-primary, --cert-secondary, etc.) 
   which are dynamically set on the parent element via JavaScript.
*/

/* Core Certificate Wrapper Container */
.cert-wrapper {
  background-color: var(--cert-bg, #ffffff);
  color: var(--cert-text, #1f2937);
  box-sizing: border-box;
  padding: 24px;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  font-family: 'Inter', sans-serif;
  user-select: none;
  overflow: hidden;
}

/* Sizing constraints for full vs half page layouts */
.layout-full .cert-wrapper {
  width: 100%;
  height: 100%;
}

.layout-half .cert-wrapper {
  width: 100%;
  height: calc(50% - 15px); /* Fit top/bottom on A4 portrait, subtracting cutting line */
}

/* --------------------------------------------------------------------------
   TEMPLATE 1: CLASSIC (Traditional Diploma Style)
   -------------------------------------------------------------------------- */
.template-classic {
  --border-primary: var(--cert-primary, #1e3a8a);
  --border-secondary: var(--cert-secondary, #d97706);
}

.template-classic .cert-border-outer {
  border: 12px double var(--border-primary);
  height: 100%;
  padding: 8px;
  display: flex;
  flex-direction: column;
  position: relative;
}

.template-classic .cert-border-inner {
  border: 2px solid var(--border-secondary);
  height: 100%;
  padding: 30px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  text-align: center;
  position: relative;
}

/* Ornamental corners for Classic template */
.template-classic .cert-border-inner::before,
.template-classic .cert-border-inner::after,
.template-classic .cert-border-outer::before,
.template-classic .cert-border-outer::after {
  content: "✦";
  position: absolute;
  font-size: 14px;
  color: var(--border-secondary);
}
.template-classic .cert-border-inner::before { top: 6px; left: 8px; }
.template-classic .cert-border-inner::after { top: 6px; right: 8px; }
.template-classic .cert-border-outer::before { bottom: 6px; left: 8px; }
.template-classic .cert-border-outer::after { bottom: 6px; right: 8px; }

/* Layout Elements for Classic */
.template-classic .cert-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.template-classic .cert-logo {
  height: 50px;
  max-width: 120px;
  object-fit: contain;
}

.template-classic .cert-school-name {
  font-family: 'Cinzel', serif;
  font-size: 0.95rem;
  font-weight: 800;
  letter-spacing: 2px;
  color: var(--cert-primary, #1e3a8a);
  text-transform: uppercase;
}

.template-classic .cert-school-slogan {
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-size: 0.75rem;
  color: #64748b;
}

.template-classic .cert-award-title {
  font-family: 'Cinzel', serif;
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--cert-secondary, #d97706);
  margin-top: 15px;
  margin-bottom: 5px;
  text-transform: uppercase;
}

.template-classic .cert-presented-to {
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-size: 1rem;
  color: #4b5563;
  margin: 8px 0;
}

.template-classic .cert-student-name {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--cert-primary, #1e3a8a);
  margin: 10px 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  padding-bottom: 5px;
  display: inline-block;
  min-width: 300px;
}

.template-classic .cert-description {
  font-family: 'Inter', sans-serif;
  font-size: 0.85rem;
  color: #374151;
  max-width: 580px;
  line-height: 1.6;
}

.template-classic .cert-footer {
  display: flex;
  justify-content: space-between;
  width: 100%;
  max-width: 600px;
  margin-top: 20px;
}

.template-classic .cert-date-block,
.template-classic .cert-signature-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 220px;
}

.template-classic .cert-value {
  font-size: 0.85rem;
  font-weight: 600;
  padding-bottom: 4px;
  border-bottom: 1px solid #94a3b8;
  width: 100%;
  text-align: center;
  height: 24px;
}

.template-classic .cert-signature {
  font-family: 'Great Vibes', cursive;
  font-size: 1.5rem;
  line-height: 1;
  color: #1f2937;
}

.template-classic .cert-label {
  font-size: 0.65rem;
  text-transform: uppercase;
  color: #64748b;
  margin-top: 4px;
  font-weight: 700;
  letter-spacing: 1px;
}


/* --------------------------------------------------------------------------
   TEMPLATE 2: MODERN (Minimalist Asymmetric Tech Style)
   -------------------------------------------------------------------------- */
.template-modern {
  --line-primary: var(--cert-primary, #0f172a);
  --line-secondary: var(--cert-secondary, #14b8a6);
}

.template-modern .cert-border-outer {
  border: 4px solid var(--line-primary);
  height: 100%;
  padding: 12px;
  display: flex;
  flex-direction: column;
  position: relative;
}

.template-modern .cert-border-inner {
  border: 1px solid rgba(0, 0, 0, 0.08);
  height: 100%;
  padding: 30px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
}

/* Geometric corner tabs for Modern look */
.template-modern .cert-border-outer::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 40px; height: 40px;
  background: linear-gradient(135deg, var(--line-secondary) 50%, transparent 50%);
}
.template-modern .cert-border-outer::after {
  content: "";
  position: absolute;
  bottom: 0; right: 0;
  width: 40px; height: 40px;
  background: linear-gradient(315deg, var(--line-secondary) 50%, transparent 50%);
}

/* Modern Layout Header (Left alignment) */
.template-modern .cert-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  border-bottom: 2px solid var(--line-primary);
  padding-bottom: 15px;
}

.template-modern .cert-logo {
  height: 44px;
  max-width: 100px;
  object-fit: contain;
}

.template-modern .cert-school-info {
  text-align: right;
}

.template-modern .cert-school-name {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.9rem;
  font-weight: 800;
  color: var(--line-primary);
  letter-spacing: 0.5px;
}

.template-modern .cert-school-slogan {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.65rem;
  font-weight: 500;
  color: #64748b;
}

.template-modern .cert-body {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  margin-top: 15px;
}

.template-modern .cert-award-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 1.8rem;
  font-weight: 800;
  color: var(--line-primary);
  margin-bottom: 5px;
  letter-spacing: -0.5px;
}

.template-modern .cert-presented-to {
  font-family: 'Inter', sans-serif;
  font-size: 0.8rem;
  color: #64748b;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 1.5px;
  margin: 5px 0;
}

.template-modern .cert-student-name {
  font-size: 2.3rem;
  font-weight: 800;
  color: var(--line-secondary);
  margin: 8px 0;
  display: block;
}

.template-modern .cert-description {
  font-family: 'Inter', sans-serif;
  font-size: 0.8rem;
  color: #4b5563;
  max-width: 540px;
  line-height: 1.5;
}

.template-modern .cert-footer {
  display: flex;
  justify-content: space-between;
  width: 100%;
  margin-top: 20px;
}

.template-modern .cert-date-block,
.template-modern .cert-signature-block {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  width: 200px;
}

.template-modern .cert-value {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.8rem;
  font-weight: 700;
  padding-bottom: 4px;
  border-bottom: 2px solid var(--line-primary);
  width: 100%;
  text-align: left;
  height: 24px;
}

.template-modern .cert-signature {
  font-family: 'Alex Brush', cursive;
  font-size: 1.6rem;
  line-height: 0.9;
  color: var(--line-primary);
}

.template-modern .cert-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.6rem;
  font-weight: 600;
  color: #94a3b8;
  margin-top: 4px;
  letter-spacing: 0.5px;
}


/* --------------------------------------------------------------------------
   TEMPLATE 3: PLAYFUL (Dotted stars and cute badges)
   -------------------------------------------------------------------------- */
.template-playful {
  --color-primary-play: var(--cert-primary, #ef4444);
  --color-secondary-play: var(--cert-secondary, #3b82f6);
}

.template-playful .cert-border-outer {
  border: 6px dashed var(--color-secondary-play);
  border-radius: 16px;
  height: 100%;
  padding: 8px;
  display: flex;
  flex-direction: column;
}

.template-playful .cert-border-inner {
  border: 2px dotted var(--color-primary-play);
  border-radius: 10px;
  height: 100%;
  padding: 30px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  text-align: center;
  position: relative;
  background: radial-gradient(circle at 5% 5%, rgba(245, 158, 11, 0.05) 0%, transparent 15%),
              radial-gradient(circle at 95% 95%, rgba(59, 130, 246, 0.05) 0%, transparent 15%);
}

/* Playful stars scattered around borders */
.template-playful .cert-border-inner::before,
.template-playful .cert-border-inner::after {
  content: "⭐";
  position: absolute;
  font-size: 18px;
}
.template-playful .cert-border-inner::before { top: 12px; left: 12px; }
.template-playful .cert-border-inner::after { bottom: 12px; right: 12px; }

/* Decorative star vectors using CSS border trick */
.template-playful .cert-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.template-playful .cert-logo {
  height: 48px;
  max-width: 100px;
  object-fit: contain;
  margin-bottom: 2px;
}

.template-playful .cert-school-name {
  font-family: 'Fredoka', sans-serif;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-secondary-play);
  letter-spacing: 0.5px;
}

.template-playful .cert-school-slogan {
  font-family: 'Fredoka', sans-serif;
  font-size: 0.7rem;
  color: #64748b;
}

.template-playful .cert-body {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 10px;
}

.template-playful .cert-award-title {
  font-family: 'Fredoka', sans-serif;
  font-size: 2.1rem;
  font-weight: 800;
  color: var(--color-primary-play);
  text-shadow: 1px 1px 0 rgba(0, 0, 0, 0.05);
}

.template-playful .cert-presented-to {
  font-family: 'Fredoka', sans-serif;
  font-size: 0.85rem;
  color: #64748b;
  margin: 6px 0;
}

.template-playful .cert-student-name {
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--color-secondary-play);
  margin: 8px 0;
  display: inline-block;
  position: relative;
}

.template-playful .cert-description {
  font-family: 'Fredoka', sans-serif;
  font-size: 0.8rem;
  color: #4b5563;
  max-width: 520px;
  line-height: 1.5;
}

.template-playful .cert-footer {
  display: flex;
  justify-content: space-between;
  width: 100%;
  max-width: 580px;
  margin-top: 15px;
}

.template-playful .cert-date-block,
.template-playful .cert-signature-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 200px;
}

.template-playful .cert-value {
  font-family: 'Fredoka', sans-serif;
  font-size: 0.8rem;
  font-weight: 600;
  padding-bottom: 2px;
  border-bottom: 2px dashed var(--color-primary-play);
  width: 100%;
  text-align: center;
  height: 24px;
}

.template-playful .cert-signature {
  font-family: 'Alex Brush', cursive;
  font-size: 1.6rem;
  line-height: 0.9;
  color: #1f2937;
}

.template-playful .cert-label {
  font-family: 'Fredoka', sans-serif;
  font-size: 0.65rem;
  font-weight: 600;
  color: #94a3b8;
  margin-top: 4px;
}


/* ==========================================================================
   DYNAMIC FONTS OVERRIDES
   ========================================================================== */
/* These classes are set dynamically on cert-student-name and cert-award-title */

/* Elegant Options */
.font-elegant-playfair { font-family: 'Playfair Display', serif !important; }
.font-elegant-cinzel { font-family: 'Cinzel', serif !important; }
.font-elegant-greatvibes { font-family: 'Great Vibes', cursive !important; }
.font-elegant-alexbrush { font-family: 'Alex Brush', cursive !important; }
.font-elegant-montserrat { font-family: 'Montserrat', sans-serif !important; }

/* Edgy Options */
.font-edgy-specialelite { font-family: 'Special Elite', monospace !important; }
.font-edgy-bungee { font-family: 'Bungee', sans-serif !important; }
.font-edgy-permanentmarker { font-family: 'Permanent Marker', cursive !important; }
.font-edgy-fredoka { font-family: 'Fredoka', sans-serif !important; }
.font-edgy-orbitron { font-family: 'Orbitron', sans-serif !important; }
.font-edgy-sedgwick { font-family: 'Sedgwick Ave Display', cursive !important; }
.font-edgy-chewy { font-family: 'Chewy', cursive !important; }

/* Sport Options */
.font-sport-teko { font-family: 'Teko', sans-serif !important; }
.font-sport-rubikmono { font-family: 'Rubik Mono One', sans-serif !important; }

/* Signature Handwriting Options */
.font-sig-caveat { font-family: 'Caveat', cursive !important; }
.font-sig-reenie { font-family: 'Reenie Beanie', cursive !important; }
.font-sig-delafield { font-family: 'Mrs Saint Delafield', cursive !important; }
.font-sig-alexbrush { font-family: 'Alex Brush', cursive !important; }
.font-sig-greatvibes { font-family: 'Great Vibes', cursive !important; }

/* --------------------------------------------------------------------------
   TEMPLATE 4: ATHLETIC (Collegiate Varsity / Sports Style)
   -------------------------------------------------------------------------- */
.template-athletic {
  --color-primary-sport: var(--cert-primary, #1e3a8a);
  --color-secondary-sport: var(--cert-secondary, #b45309);
}

.template-athletic .cert-border-outer {
  border: 10px solid var(--color-primary-sport);
  height: 100%;
  padding: 4px;
  display: flex;
  flex-direction: column;
  position: relative;
}

.template-athletic .cert-border-inner {
  border: 4px solid var(--color-secondary-sport);
  height: 100%;
  padding: 30px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  text-align: center;
  position: relative;
}

.template-athletic .cert-border-inner::before,
.template-athletic .cert-border-inner::after {
  content: "★";
  position: absolute;
  font-size: 24px;
  color: var(--color-secondary-sport);
}
.template-athletic .cert-border-inner::before { top: 10px; left: 15px; }
.template-athletic .cert-border-inner::after { bottom: 10px; right: 15px; }

.template-athletic .cert-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.template-athletic .cert-logo {
  height: 55px;
  max-width: 110px;
  object-fit: contain;
}

.template-athletic .cert-school-name {
  font-family: 'Rubik Mono One', sans-serif;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--color-primary-sport);
  letter-spacing: 1px;
}

.template-athletic .cert-school-slogan {
  font-family: 'Teko', sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: 2px;
  color: #4b5563;
  text-transform: uppercase;
}

.template-athletic .cert-award-title {
  font-family: 'Rubik Mono One', sans-serif;
  font-size: 1.8rem;
  color: var(--color-secondary-sport);
  margin-top: 10px;
}

.template-athletic .cert-presented-to {
  font-family: 'Teko', sans-serif;
  font-size: 1.2rem;
  letter-spacing: 1px;
  color: #64748b;
  text-transform: uppercase;
  margin: 5px 0;
}

.template-athletic .cert-student-name {
  font-family: 'Teko', sans-serif;
  font-size: 3rem;
  font-weight: 700;
  color: var(--color-primary-sport);
  margin: 5px 0;
  letter-spacing: 1px;
  display: inline-block;
  border-bottom: 3px solid var(--color-secondary-sport);
}

.template-athletic .cert-description {
  font-family: 'Inter', sans-serif;
  font-size: 0.85rem;
  color: #374151;
  max-width: 540px;
  line-height: 1.5;
}

.template-athletic .cert-footer {
  display: flex;
  justify-content: space-between;
  width: 100%;
  max-width: 580px;
  margin-top: 15px;
}

.template-athletic .cert-date-block,
.template-athletic .cert-signature-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 200px;
}

.template-athletic .cert-value {
  font-family: 'Teko', sans-serif;
  font-size: 1.2rem;
  font-weight: 700;
  padding-bottom: 2px;
  border-bottom: 2px solid var(--color-primary-sport);
  width: 100%;
  text-align: center;
  height: 24px;
}

.template-athletic .cert-signature {
  font-family: 'Caveat', cursive;
  font-size: 1.6rem;
  line-height: 0.9;
  color: #1f2937;
}

.template-athletic .cert-label {
  font-family: 'Inter', sans-serif;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  color: #94a3b8;
  margin-top: 4px;
}

/* --------------------------------------------------------------------------
   TEMPLATE 5: BUBBLE (Primary School Cute / Playful Bubble style)
   -------------------------------------------------------------------------- */
.template-bubble {
  --color-primary-bubble: var(--cert-primary, #ec4899);
  --color-secondary-bubble: var(--cert-secondary, #06b6d4);
}

.template-bubble .cert-border-outer {
  border: 12px solid var(--color-primary-bubble);
  border-radius: 40px;
  height: 100%;
  padding: 6px;
  display: flex;
  flex-direction: column;
  position: relative;
  background-color: var(--cert-bg, #ffffff);
}

.template-bubble .cert-border-inner {
  border: 4px dashed var(--color-secondary-bubble);
  border-radius: 30px;
  height: 100%;
  padding: 30px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  text-align: center;
  position: relative;
  background-color: transparent;
}

.template-bubble .cert-border-inner::before,
.template-bubble .cert-border-inner::after {
  content: "🎈";
  position: absolute;
  font-size: 24px;
}
.template-bubble .cert-border-inner::before { top: 12px; left: 15px; }
.template-bubble .cert-border-inner::after { bottom: 12px; right: 15px; }

.template-bubble .cert-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.template-bubble .cert-logo {
  height: 55px;
  max-width: 110px;
  object-fit: contain;
}

.template-bubble .cert-school-name {
  font-family: 'Fredoka', sans-serif;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-primary-bubble);
  letter-spacing: 0.5px;
}

.template-bubble .cert-school-slogan {
  font-family: 'Fredoka', sans-serif;
  font-size: 0.75rem;
  color: #64748b;
  font-style: italic;
}

.template-bubble .cert-award-title {
  font-family: 'Chewy', cursive;
  font-size: 2.2rem;
  color: var(--color-secondary-bubble);
  margin-top: 10px;
}

.template-bubble .cert-presented-to {
  font-family: 'Fredoka', sans-serif;
  font-size: 0.85rem;
  color: #64748b;
  margin: 5px 0;
}

.template-bubble .cert-student-name {
  font-family: 'Chewy', cursive;
  font-size: 2.6rem;
  color: var(--color-primary-bubble);
  margin: 5px 0;
  display: inline-block;
  background: radial-gradient(circle, rgba(6, 182, 212, 0.08) 0%, transparent 80%);
  padding: 2px 15px;
  border-radius: 20px;
}

.template-bubble .cert-description {
  font-family: 'Fredoka', sans-serif;
  font-size: 0.85rem;
  color: #4b5563;
  max-width: 520px;
  line-height: 1.5;
}

.template-bubble .cert-footer {
  display: flex;
  justify-content: space-between;
  width: 100%;
  max-width: 580px;
  margin-top: 15px;
}

.template-bubble .cert-date-block,
.template-bubble .cert-signature-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 200px;
}

.template-bubble .cert-value {
  font-family: 'Fredoka', sans-serif;
  font-size: 0.85rem;
  font-weight: 600;
  padding-bottom: 2px;
  border-bottom: 3px dotted var(--color-secondary-bubble);
  width: 100%;
  text-align: center;
  height: 24px;
}

.template-bubble .cert-signature {
  font-family: 'Reenie Beanie', cursive;
  font-size: 1.8rem;
  line-height: 0.9;
  color: #1f2937;
}

.template-bubble .cert-label {
  font-family: 'Fredoka', sans-serif;
  font-size: 0.65rem;
  font-weight: 600;
  color: #94a3b8;
  margin-top: 4px;
}

/* --------------------------------------------------------------------------
   TEMPLATE 6: VINTAGE (Victorian/Ornate Flourished Style)
   -------------------------------------------------------------------------- */
.template-vintage {
  --color-primary-vintage: var(--cert-primary, #7f1d1d);
  --color-secondary-vintage: var(--cert-secondary, #ca8a04);
}

.template-vintage .cert-border-outer {
  border: 12px double var(--color-primary-vintage);
  height: 100%;
  padding: 8px;
  display: flex;
  flex-direction: column;
  position: relative;
  background-color: var(--cert-bg, #ffffff);
}

.template-vintage .cert-border-inner {
  border: 2px solid var(--color-secondary-vintage);
  height: 100%;
  padding: 30px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  text-align: center;
  position: relative;
}

.template-vintage .cert-border-inner::before,
.template-vintage .cert-border-inner::after {
  content: "⚜";
  position: absolute;
  font-size: 26px;
  color: var(--color-secondary-vintage);
  opacity: 0.85;
}
.template-vintage .cert-border-inner::before { top: 8px; left: 12px; }
.template-vintage .cert-border-inner::after { bottom: 8px; right: 12px; }

.template-vintage .cert-school-name {
  font-family: 'Cinzel', serif;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--color-primary-vintage);
  text-transform: uppercase;
  letter-spacing: 2px;
}

.template-vintage .cert-school-slogan {
  font-family: 'Playfair Display', serif;
  font-size: 0.75rem;
  color: #4b5563;
  font-style: italic;
  margin-top: 2px;
}

.template-vintage .cert-award-title {
  font-family: 'Cinzel', serif;
  font-size: 2.1rem;
  font-weight: 700;
  color: var(--color-primary-vintage);
  letter-spacing: 1px;
}

.template-vintage .cert-presented-to {
  font-family: 'Playfair Display', serif;
  font-size: 0.85rem;
  font-style: italic;
  color: #6b7280;
}

.template-vintage .cert-student-name {
  font-family: 'Great Vibes', cursive;
  font-size: 3.2rem;
  color: var(--color-primary-vintage);
  border-bottom: 1px solid rgba(202, 138, 4, 0.3);
  padding: 0 20px;
}

.template-vintage .cert-description {
  font-family: 'Playfair Display', serif;
  font-size: 0.85rem;
  color: #374151;
  max-width: 520px;
  line-height: 1.5;
}

.template-vintage .cert-value {
  font-family: 'Playfair Display', serif;
  font-size: 0.85rem;
  border-bottom: 2px solid var(--color-secondary-vintage);
  width: 100%;
  text-align: center;
  height: 24px;
}

.template-vintage .cert-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.6rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #9ca3af;
}

/* --------------------------------------------------------------------------
   TEMPLATE 7: GEOMETRIC (Art Deco / Geometric Frame Style)
   -------------------------------------------------------------------------- */
.template-geometric {
  --color-primary-geom: var(--cert-primary, #0f172a);
  --color-secondary-geom: var(--cert-secondary, #d97706);
}

.template-geometric .cert-border-outer {
  border: 4px solid var(--color-primary-geom);
  height: 100%;
  padding: 10px;
  display: flex;
  flex-direction: column;
  position: relative;
  background-color: var(--cert-bg, #ffffff);
}

.template-geometric .cert-border-inner {
  border: 1px solid var(--color-primary-geom);
  height: 100%;
  padding: 30px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  text-align: center;
  position: relative;
}

/* Geometric corners */
.template-geometric .cert-border-inner::before,
.template-geometric .cert-border-inner::after {
  content: "◆";
  position: absolute;
  font-size: 16px;
  color: var(--color-secondary-geom);
}
.template-geometric .cert-border-inner::before { top: -9px; left: -9px; background: var(--cert-bg, #ffffff); padding: 0 4px; }
.template-geometric .cert-border-inner::after { bottom: -9px; right: -9px; background: var(--cert-bg, #ffffff); padding: 0 4px; }

.template-geometric .cert-school-name {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--color-primary-geom);
  letter-spacing: 2px;
  text-transform: uppercase;
}

.template-geometric .cert-school-slogan {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.7rem;
  color: #64748b;
  letter-spacing: 1px;
}

.template-geometric .cert-award-title {
  font-family: 'Cinzel', serif;
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--color-primary-geom);
  border-top: 2px solid var(--color-secondary-geom);
  border-bottom: 2px solid var(--color-secondary-geom);
  padding: 6px 30px;
  letter-spacing: 2px;
}

.template-geometric .cert-presented-to {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: #64748b;
}

.template-geometric .cert-student-name {
  font-family: 'Playfair Display', serif;
  font-size: 2.8rem;
  font-weight: 700;
  color: var(--color-primary-geom);
  letter-spacing: 1px;
}

.template-geometric .cert-description {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.8rem;
  color: #334155;
  max-width: 520px;
  line-height: 1.6;
}

.template-geometric .cert-value {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.8rem;
  font-weight: 500;
  border-bottom: 2px solid var(--color-primary-geom);
  width: 100%;
  text-align: center;
  height: 24px;
}

.template-geometric .cert-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #94a3b8;
}

/* --------------------------------------------------------------------------
   TEMPLATE 8: MINIMALIST (Clean / Sleek Hairline Style)
   -------------------------------------------------------------------------- */
.template-minimalist {
  --color-primary-min: var(--cert-primary, #111827);
  --color-secondary-min: var(--cert-secondary, #6b7280);
}

.template-minimalist .cert-border-outer {
  border: 1px solid var(--color-primary-min);
  height: 100%;
  padding: 24px;
  display: flex;
  flex-direction: column;
  position: relative;
  background-color: var(--cert-bg, #ffffff);
}

.template-minimalist .cert-border-inner {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  text-align: center;
  position: relative;
  border: none;
  padding: 10px;
}

.template-minimalist .cert-school-name {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-secondary-min);
  letter-spacing: 3px;
  text-transform: uppercase;
}

.template-minimalist .cert-school-slogan {
  display: none; /* Hidden in minimalist */
}

.template-minimalist .cert-award-title {
  font-family: 'Playfair Display', serif;
  font-size: 2rem;
  font-weight: 400;
  color: var(--color-primary-min);
  letter-spacing: 1px;
  margin: 15px 0;
}

.template-minimalist .cert-presented-to {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.75rem;
  color: #9ca3af;
  letter-spacing: 1px;
}

.template-minimalist .cert-student-name {
  font-family: 'Playfair Display', serif;
  font-size: 2.6rem;
  font-weight: 400;
  color: var(--color-primary-min);
  margin: 10px 0;
}

.template-minimalist .cert-description {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.8rem;
  font-weight: 300;
  color: #4b5563;
  max-width: 500px;
  line-height: 1.6;
  letter-spacing: 0.5px;
}

.template-minimalist .cert-value {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.8rem;
  border-bottom: 1px solid var(--color-secondary-min);
  width: 100%;
  text-align: center;
  height: 24px;
}

.template-minimalist .cert-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.6rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: #9ca3af;
  margin-top: 4px;
}

