/* FRDO Diploma Check Widget */

:root {
	--frdo-primary:        #fc3f1d;
	--frdo-primary-dark:   #d93015;
	--frdo-success:        #1aa34a;
	--frdo-error:          #c0392b;
	--frdo-warning:        #92400e;
	--frdo-warning-bg:     #fffbeb;
	--frdo-warning-border: #fcd34d;
	--frdo-border:         #dde1e7;
	--frdo-card-bg:        #ffffff;
	--frdo-text:           #1e1e1e;
	--frdo-text-muted:     #6b7280;
	--frdo-radius:         12px;
	--frdo-shadow:         0 2px 16px rgba(0,0,0,.08);
}

.frdo-widget {
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
	font-size: 15px;
	line-height: 1.55;
	color: var(--frdo-text);
	max-width: 520px;
	margin: 0 auto;
}

/* ---- Card ---- */
.frdo-card {
	background: var(--frdo-card-bg);
	border: 1px solid var(--frdo-border);
	border-radius: var(--frdo-radius);
	box-shadow: var(--frdo-shadow);
	padding: 2.25rem 2.5rem;
	text-align: center;
}
.frdo-card--success { border-color: var(--frdo-success); }
.frdo-card--error   { border-color: var(--frdo-error); }
.frdo-card--warning {
	border-color: var(--frdo-warning-border);
	background: var(--frdo-warning-bg);
}
.frdo-card--loading {
	min-height: 180px;
	display: flex; flex-direction: column;
	align-items: center; justify-content: center;
	gap: 1rem;
}

.frdo-card__icon       { font-size: 2.5rem; margin-bottom: .75rem; display: block; }
.frdo-card__title      { font-size: 1.2rem; font-weight: 700; margin: 0 0 .75rem; }
.frdo-card__desc       { color: var(--frdo-text-muted); margin: 0 0 1.5rem; font-size: .9rem; }
.frdo-card__found-spec { margin: .5rem 0 1rem; font-size: .9rem; }

.frdo-card--success .frdo-card__title { color: var(--frdo-success); }
.frdo-card--error   .frdo-card__title { color: var(--frdo-error); }
.frdo-card--warning .frdo-card__title { color: var(--frdo-warning); }

/* Qualification badge shown on success */
.frdo-card__qualification {
	display: inline-block;
	background: #ecfdf5;
	color: var(--frdo-success);
	border: 1px solid #6ee7b7;
	border-radius: 999px;
	padding: .25rem .85rem;
	font-size: .85rem;
	font-weight: 600;
	margin-bottom: 1rem;
}

/* ---- Allowed specialties list (inside <details>) ---- */
.frdo-details {
	text-align: left;
	margin: .75rem 0 0;
}
.frdo-details summary {
	cursor: pointer;
	font-size: .85rem;
	color: var(--frdo-warning);
	font-weight: 600;
	margin-bottom: .5rem;
}
.frdo-specialty-list {
	margin: .5rem 0 0;
	padding-left: 1.25rem;
	font-size: .85rem;
	color: var(--frdo-text);
	text-align: left;
}
.frdo-specialty-list li { margin-bottom: .35rem; }
.frdo-level { color: var(--frdo-text-muted); font-size: .8rem; }

/* ---- Buttons ---- */
.frdo-btn {
	display: inline-flex; align-items: center; gap: .5rem;
	padding: .75rem 1.5rem; border-radius: 8px;
	font-size: 1rem; font-weight: 600; cursor: pointer;
	border: none; text-decoration: none;
	transition: background .15s, transform .1s;
}
.frdo-btn:active { transform: scale(.98); }

.frdo-btn--primary            { background: var(--frdo-primary); color: #fff; }
.frdo-btn--primary:hover      { background: var(--frdo-primary-dark); color: #fff; text-decoration: none; }
.frdo-btn--primary:disabled   { opacity: .6; cursor: not-allowed; }

.frdo-btn--secondary          { background: transparent; color: var(--frdo-primary); border: 2px solid var(--frdo-primary); }
.frdo-btn--secondary:hover    { background: rgba(252,63,29,.06); }

.frdo-btn__spinner {
	width: 16px; height: 16px;
	border: 2px solid rgba(255,255,255,.4);
	border-top-color: #fff;
	border-radius: 50%;
	animation: frdo-spin .7s linear infinite;
}

/* ---- Form ---- */
.frdo-form { text-align: left; margin-top: 1.25rem; }
.frdo-form__row { margin-bottom: 1rem; }
.frdo-form__label {
	display: block; font-size: .8rem; font-weight: 600;
	color: var(--frdo-text-muted); margin-bottom: .35rem;
	text-transform: uppercase; letter-spacing: .04em;
}
.frdo-form__input {
	width: 100%; padding: .65rem .85rem;
	border: 1.5px solid var(--frdo-border); border-radius: 8px;
	font-size: 1rem; color: var(--frdo-text); background: #fff;
	transition: border-color .15s; box-sizing: border-box;
}
.frdo-form__input:focus { outline: none; border-color: var(--frdo-primary); }
.frdo-form #frdo-submit-btn { width: 100%; margin-top: .5rem; justify-content: center; }

/* ---- Notices ---- */
.frdo-notice { padding: .75rem 1rem; border-radius: 8px; font-size: .9rem; margin: .75rem 0; }
.frdo-notice--error { background: #fdf2f2; border: 1px solid #fca5a5; color: var(--frdo-error); }

/* ---- Spinner (standalone) ---- */
.frdo-spinner {
	width: 40px; height: 40px;
	border: 3px solid var(--frdo-border);
	border-top-color: var(--frdo-primary);
	border-radius: 50%;
	animation: frdo-spin .8s linear infinite;
}

@keyframes frdo-spin { to { transform: rotate(360deg); } }

/* ---- Two-column row group ---- */
.frdo-form__row-group {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0 1rem;
}
@media ( max-width: 420px ) { .frdo-form__row-group { grid-template-columns: 1fr; } }

/* ---- Checkbox row ---- */
.frdo-form__row--checkbox { margin-bottom: .5rem; }
.frdo-form__checkbox-label {
	display: flex;
	align-items: center;
	gap: .5rem;
	font-size: .9rem;
	cursor: pointer;
}
.frdo-form__hint { margin: .25rem 0 0 1.5rem; font-size: .8rem; color: var(--frdo-text-muted); }

/* ---- Organisation autocomplete ---- */
.frdo-autocomplete { position: relative; }
.frdo-autocomplete__dropdown {
	position: absolute;
	z-index: 99;
	width: 100%;
	background: #fff;
	border: 1.5px solid var(--frdo-primary);
	border-top: none;
	border-radius: 0 0 8px 8px;
	box-shadow: 0 4px 12px rgba(0,0,0,.12);
	max-height: 220px;
	overflow-y: auto;
}
.frdo-autocomplete__item {
	padding: .6rem .85rem;
	font-size: .9rem;
	cursor: pointer;
	border-bottom: 1px solid var(--frdo-border);
}
.frdo-autocomplete__item:last-child { border-bottom: none; }
.frdo-autocomplete__item:hover { background: #fef3f0; }
.frdo-autocomplete__empty { padding: .6rem .85rem; color: var(--frdo-text-muted); font-size: .9rem; }
.frdo-org-selected {
	margin-top: .35rem;
	font-size: .8rem;
	color: var(--frdo-success);
	word-break: break-word;
}

/* ---- Captcha ---- */
.frdo-captcha { display: flex; flex-direction: column; gap: .5rem; }
.frdo-captcha__image-wrap { display: flex; align-items: center; gap: .75rem; }
.frdo-captcha__img { border-radius: 6px; border: 1px solid var(--frdo-border); height: 50px; }
.frdo-captcha__loading { font-size: .85rem; color: var(--frdo-text-muted); }
.frdo-captcha__reload {
	background: none; border: 1px solid var(--frdo-border); border-radius: 6px;
	padding: .3rem .6rem; cursor: pointer; font-size: 1.1rem; color: var(--frdo-text-muted);
	transition: color .15s;
}
.frdo-captcha__reload:hover { color: var(--frdo-primary); }
.frdo-captcha__input { max-width: 180px; }

/* ---- Form select ---- */
.frdo-form__select {
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b7280' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right .85rem center;
	padding-right: 2.5rem;
	cursor: pointer;
}

/* ---- Responsive ---- */
@media ( max-width: 540px ) {
	.frdo-card { padding: 1.5rem 1.25rem; }
	.frdo-card__title { font-size: 1.05rem; }
}
