/* ==========================================================================
   OPL Shop Design System
   Modern SaaS aesthetic with Bootstrap 3 compatibility
   ========================================================================== */

/* --- Design Tokens --- */
:root {
  /* Colors */
  --color-primary: #2563eb;
  --color-primary-hover: #1d4ed8;
  --color-success: #16a34a;
  --color-success-hover: #15803d;
  --color-gray-50: #f9fafb;
  --color-gray-100: #f3f4f6;
  --color-gray-200: #e5e7eb;
  --color-gray-300: #d1d5db;
  --color-gray-400: #9ca3af;
  --color-gray-500: #6b7280;
  --color-gray-600: #4b5563;
  --color-gray-700: #374151;
  --color-gray-800: #1f2937;
  --color-gray-900: #111827;
  --color-white: #ffffff;
  --color-error: #b94a48;
  --color-error-bg: #f2dede;
  --color-error-border: #eed3d7;
  --color-special-bg: #fffbeb;
  --color-special-border: #fde68a;

  /* Spacing */
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 32px;
  --space-2xl: 48px;

  /* Typography */
  --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-size-xs: 0.75rem;
  --font-size-sm: 0.875rem;
  --font-size-base: 1rem;
  --font-size-lg: 1.125rem;
  --font-size-xl: 1.25rem;
  --font-size-2xl: 1.5rem;
  --line-height-tight: 1.25;
  --line-height-normal: 1.5;

  /* Shadows */
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.07), 0 2px 4px -2px rgba(0, 0, 0, 0.05);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.08), 0 4px 6px -4px rgba(0, 0, 0, 0.04);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.04);

  /* Radii */
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-full: 9999px;

  /* Transitions */
  --transition-fast: 150ms ease;
  --transition-base: 200ms ease;
  --transition-slow: 300ms ease;
}

/* --- Base / Existing Overrides --- */
blockquote {
  font-style: italic;
}

#shoptitle h2 {
  margin: 5px 0 10px 0;
}

#shoptitle ul {
  margin: 10px 0 10px 20px;
}

body.adminPage {
  padding: 20px;
  font-size: 14px;
  line-height: 14px;
}

input, textarea {
  box-sizing: content-box;
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
}

.adminPage input, textarea {
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
}

table input[type="text"] {
  margin-bottom: 0px;
}

.contentbox2.error {
  background-color: var(--color-error-bg);
  border-color: var(--color-error-border);
  color: var(--color-error);
  font-weight: bold;
  text-align: center;
  margin: 0 0 10px 0;
  border-radius: var(--radius-md);
  padding: var(--space-md);
}

.row .contentbox h1 {
  margin: 0 0 15px;
}
.row .contentbox h2 {
  margin: 15px 0 10px;
}

.dropdown-menu .divider {
  box-sizing: content-box;
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
}
.pagination-centered {
  text-align: center;
}

#displayStyle {
  margin: 20px 0;
  line-height: 1.42857143;
  padding-right: 5px;
  padding-bottom: 5px;
  text-align: center;
}
.displaySelected {
  box-shadow:
    rgb(204, 219, 232) 3px 3px 6px 0px inset,
    rgba(255, 255, 255, 0.5) -3px -3px 6px 1px inset;
}

.crossout {
  text-decoration: line-through;
  color: var(--color-gray-400);
}

div.turtle {
  font-family: monospace, monospace;
  font-size: 1em;
  overflow: auto;
  display: block;
  padding: 9.5px;
  margin: 0 0 10px;
  font-size: 13px;
  line-height: 1.42857143;
  word-break: break-all;
  word-wrap: break-word;
  color: #333333;
  background-color: #f5f5f5;
  border: 1px solid #cccccc;
  border-radius: 4px;
}

.adminPage .form-horizontal label {
  font-weight: 700;
}
.filter-button {
  margin: 10px;
}

#offersCounter {
  margin: 20px 0;
  float: right;
  line-height: 1.42857143;
  padding-right: 5px;
}

/* ==========================================================================
   Filter Count & Facet Sidebar
   ========================================================================== */

#filterCount {
  padding-top: var(--space-lg);
  min-width: 150px;
  font-size: var(--font-size-base);
  color: var(--color-gray-700);
}

#filterCount a {
  color: var(--color-primary);
  font-weight: 700;
  text-decoration: none;
}

#filterCount a:hover {
  color: var(--color-primary);
}

#offerFacets {
  padding-top: var(--space-md);
  min-width: 150px;
}

/* --- Facet Clear All --- */
.facet-clear-all {
  padding: var(--space-sm) 0;
  margin-bottom: var(--space-sm);
}

.facet-clear-all a {
  font-size: var(--font-size-sm);
  color: var(--color-gray-500);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.facet-clear-all a:hover {
  color: var(--color-primary);
}

/* --- Facet Panels --- */
.facet {
  margin: 0 0 var(--space-xs) 0;
  border: none;
  border-radius: var(--radius-sm);
  background: var(--color-white);
  box-shadow: none;
}

.facet.panel-default {
  border: none;
  box-shadow: none;
}

.facet .panel-heading,
.shop_panel_heading {
  padding: var(--space-sm) var(--space-sm);
  background: transparent;
  border: none;
  border-bottom: none;
  border-radius: 0;
}

.shop_panel_heading h4,
.facet .panel-heading h4 {
  font-size: var(--font-size-sm);
  font-family: var(--font-sans);
  font-weight: 600;
  line-height: var(--line-height-normal);
  margin: 0;
  color: var(--color-gray-700);
}

.facet .panel-heading a,
.shop_panel_heading a {
  text-decoration: none;
  color: var(--color-gray-700);
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: color var(--transition-fast);
}

.facet .panel-heading a:hover {
  color: var(--color-primary);
}

/* Chevron icon for accordion */
.facet .panel-heading .facet-chevron {
  display: inline-block;
  width: 16px;
  height: 16px;
  transition: transform var(--transition-base);
  flex-shrink: 0;
  margin-left: var(--space-sm);
  color: var(--color-gray-400);
}

.facet .panel-heading a[aria-expanded="true"] .facet-chevron,
.facet .panel-heading a:not(.collapsed) .facet-chevron {
  transform: rotate(180deg);
}

.facet .panel-collapse {
  border: none;
}

.facet .panel-body {
  padding: 0 var(--space-sm) var(--space-sm) var(--space-sm);
  border-top: none;
}

/* --- Facet Options List --- */
.facet-options-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.facet-options-list li {
  margin: 0;
}

.facet-options-list li a {
  display: flex;
  align-items: center;
  padding: var(--space-xs) var(--space-sm);
  border-radius: var(--radius-sm);
  text-decoration: none;
  color: var(--color-gray-700);
  font-size: var(--font-size-sm);
  transition: background-color var(--transition-fast), color var(--transition-fast);
  gap: var(--space-sm);
}

.facet-options-list li a:hover {
  background-color: var(--color-gray-50);
  color: var(--color-gray-900);
}

.facet-options-list li.divider {
  height: 1px;
  margin: var(--space-xs) 0;
  background-color: var(--color-gray-200);
  overflow: hidden;
}

/* Facet option label */
.facetItemLabel {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex: 1;
  min-width: 0;
}

/* Facet option count badge */
.facet-option-count {
  font-size: var(--font-size-xs);
  color: var(--color-gray-400);
  background: var(--color-gray-100);
  padding: 1px 6px;
  border-radius: var(--radius-full);
  flex-shrink: 0;
  font-weight: 500;
}

/* Facet selected state */
.facet-option-selected > a {
  background-color: #eff6ff;
  color: var(--color-primary);
  font-weight: 600;
}

.facet-option-selected > a:hover {
  background-color: #dbeafe;
}

/* Facet logo in sidebar */
.facetLogo {
  max-height: 24px;
  width: auto;
  padding: 0;
  flex-shrink: 0;
}

.facet ul {
  margin-left: 0;
  padding-left: 0;
  list-style: none;
}

/* ==========================================================================
   Offers Grid
   ========================================================================== */

div.offersGrid {
  padding-top: var(--space-md);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-lg);
}

/* ==========================================================================
   Offer Card
   ========================================================================== */

div.offerCard {
  margin: 0;
  padding: 0;
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-lg);
  min-width: 280px;
  max-width: 500px;
  min-height: auto;
  transition: box-shadow var(--transition-base), transform var(--transition-base);
  font-size: var(--font-size-sm);
  background: var(--color-white);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
}

/* Override Bootstrap col-* constraints for flex-based 2-per-row layout */
div.offersGrid > div.offerCard {
  width: auto;
  float: none;
  padding-left: 0;
  padding-right: 0;
  flex: 1 1 calc(50% - var(--space-lg));
}

@media only screen and (min-width: 576px) {
  div.offerCard {
    min-width: 320px;
  }
}

@media only screen and (min-width: 1024px) {
  div.offerCard:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
  }
}

/* --- Card Inner Layout --- */
.offer-card-inner {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: var(--space-lg);
}

/* --- Card Header / Type Badge --- */
.offer-card-header {
  margin-bottom: var(--space-md);
}

.offer-type-badge {
  display: inline-block;
  padding: 5px 14px;
  border-radius: var(--radius-full);
  border: 1px solid var(--color-gray-300);
  font-size: var(--font-size-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  background: var(--color-gray-100);
  color: var(--color-gray-600);
  line-height: var(--line-height-normal);
  margin: 0;
}

/* --- Product & DBMS Names --- */
.offer-product-name {
  font-size: var(--font-size-sm);
  color: var(--color-gray-500);
  margin: 0 0 var(--space-xs) 0;
  font-weight: 400;
  line-height: var(--line-height-normal);
}

.offer-dbms-name {
  font-size: var(--font-size-lg);
  font-weight: 700;
  color: var(--color-gray-900);
  margin: 0 0 var(--space-md) 0;
  line-height: var(--line-height-tight);
}

/* --- Logos Row --- */
.offer-logos {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-md);
}

.offer-logos a {
  display: inline-flex;
  align-items: center;
}

.offer-logos img {
  max-width: 80px;
  height: auto;
  transition: opacity var(--transition-fast);
}

.offer-logos img:hover {
  opacity: 0.8;
}

/* --- License Diagram --- */
.offer-diagram {
  text-align: center;
  margin-bottom: var(--space-md);
}

.offer-diagram a {
  display: inline-block;
}

.offer-diagram img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-sm);
}

/* --- Description --- */
.offer-description {
  margin-bottom: var(--space-md);
}

.offer-description .description-text {
  font-size: var(--font-size-sm);
  color: var(--color-gray-600);
  line-height: var(--line-height-normal);
}

/* --- License Details Link --- */
.offer-details-link {
  margin-bottom: var(--space-md);
}

/* --- Specs List --- */
.offer-specs {
  margin-bottom: var(--space-md);
}

.offer-specs ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.offer-specs ul li {
  padding: 3px 0;
  font-size: var(--font-size-sm);
  color: var(--color-gray-600);
  line-height: var(--line-height-normal);
}

.offer-specs ul li::before {
  content: "\2713";
  color: var(--color-success);
  font-weight: 700;
  margin-right: var(--space-sm);
}

/* --- Price --- */
.offer-price {
  margin-bottom: var(--space-md);
  font-size: var(--font-size-xl);
}

.offer-price strong {
  font-weight: 700;
  color: var(--color-gray-900);
}

.offer-price .crossout {
  font-size: var(--font-size-sm);
}

.offer-price-special {
  background: var(--color-special-bg);
  border: 1px solid var(--color-special-border);
  border-radius: var(--radius-sm);
  padding: var(--space-sm) var(--space-md);
  display: inline-block;
}

/* --- Action Buttons --- */
.offer-actions {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-top: auto;
  flex-wrap: wrap;
}

/* Primary: Add to Cart */
.offer-actions .btn-primary,
.offer-actions a.btn-primary {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-white);
  border-radius: var(--radius-sm);
  padding: 8px 20px;
  font-size: var(--font-size-sm);
  font-weight: 600;
  transition: background-color var(--transition-fast), transform var(--transition-fast);
  text-decoration: none;
}

.offer-actions .btn-primary:hover,
.offer-actions a.btn-primary:hover {
  background-color: var(--color-primary-hover);
  border-color: var(--color-primary-hover);
  transform: translateY(-1px);
}

/* Outlined: License Details / Contact */
.offer-actions .btn-default,
.offer-actions a.btn-default,
.offer-details-link .btn-default {
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-300);
  color: var(--color-gray-700);
  border-radius: var(--radius-sm);
  padding: 8px 20px;
  font-size: var(--font-size-sm);
  font-weight: 500;
  transition: border-color var(--transition-fast), color var(--transition-fast), background-color var(--transition-fast);
  text-decoration: none;
}

.offer-actions .btn-default:hover,
.offer-actions a.btn-default:hover,
.offer-details-link .btn-default:hover {
  border-color: var(--color-gray-400);
  background-color: var(--color-gray-50);
  color: var(--color-gray-900);
}

/* Outlined Green: Get Started Free */
.offer-actions .btn-info,
.offer-actions a.btn-info {
  background-color: var(--color-white);
  border: 1px solid var(--color-success);
  color: var(--color-success);
  border-radius: var(--radius-sm);
  padding: 8px 20px;
  font-size: var(--font-size-sm);
  font-weight: 600;
  transition: background-color var(--transition-fast), color var(--transition-fast);
  text-decoration: none;
}

.offer-actions .btn-info:hover,
.offer-actions a.btn-info:hover {
  background-color: var(--color-success);
  color: var(--color-white);
}

/* ==========================================================================
   Load More Button
   ========================================================================== */

#loadMore {
  text-align: center;
  padding: var(--space-xl) 0;
}

#loadMoreBtn {
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-300);
  color: var(--color-gray-700);
  border-radius: var(--radius-sm);
  padding: 10px 32px;
  font-size: var(--font-size-sm);
  font-weight: 500;
  cursor: pointer;
  transition: border-color var(--transition-fast), color var(--transition-fast), box-shadow var(--transition-fast);
}

#loadMoreBtn:hover {
  border-color: var(--color-gray-400);
  color: var(--color-gray-900);
  box-shadow: var(--shadow-sm);
}

/* ==========================================================================
   Search Results (search.vsp)
   ========================================================================== */

.search-results-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.search-result-card {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  padding: var(--space-md) var(--space-lg);
  background: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-md);
  transition: box-shadow var(--transition-fast), transform var(--transition-fast);
}

.search-result-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}

.search-result-logos {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
  flex-shrink: 0;
  min-width: 100px;
}

.search-result-logos img {
  max-width: 80px;
  max-height: 60px;
  width: auto;
  height: auto;
}

.search-result-diagram {
  flex-shrink: 0;
}

.search-result-diagram img {
  max-width: 120px;
  max-height: 80px;
  width: auto;
  height: auto;
}

.search-result-info {
  flex: 1;
  min-width: 0;
}

.search-result-info .description-text {
  font-size: var(--font-size-sm);
  color: var(--color-gray-700);
  line-height: var(--line-height-normal);
}

.search-result-info a {
  color: var(--color-primary);
  text-decoration: none;
  font-weight: 500;
  margin-left: var(--space-sm);
}

.search-result-info a:hover {
  text-decoration: underline;
}

.search-result-price {
  flex-shrink: 0;
  text-align: right;
  white-space: nowrap;
  font-size: var(--font-size-base);
  font-weight: 600;
  color: var(--color-gray-900);
  min-width: 100px;
}

.search-result-price .crossout {
  font-weight: 400;
  font-size: var(--font-size-sm);
}

.search-result-action {
  flex-shrink: 0;
}

.search-result-action .btn {
  border-radius: var(--radius-sm);
  font-size: var(--font-size-sm);
  font-weight: 500;
  padding: 8px 16px;
  white-space: nowrap;
}

/* Search result responsive */
@media (max-width: 767px) {
  .search-result-card {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-md);
  }

  .search-result-logos {
    flex-direction: row;
    min-width: auto;
  }

  .search-result-price {
    text-align: left;
    min-width: auto;
  }
}

/* ==========================================================================
   Responsive: Offer Cards
   ========================================================================== */

@media (max-width: 767px) {
  div.offersGrid {
    gap: var(--space-md);
    justify-content: center;
  }

  div.offerCard {
    min-width: 100%;
    max-width: 100%;
  }

  .offer-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .offer-actions .btn {
    text-align: center;
  }
}

@media (min-width: 768px) and (max-width: 1023px) {
  div.offerCard {
    min-width: 280px;
    max-width: 460px;
  }
}

@media (min-width: 1024px) {
  div.offerCard {
    min-width: 320px;
    max-width: 500px;
  }
}

/* ==========================================================================
   License Details Modal
   ========================================================================== */

#licenseDetailsModal {
  padding: var(--space-lg) var(--space-md);
  overflow-y: auto;
}

/* Dialog wraps the content box — width follows content after resize */
#licenseDetailsModal .modal-dialog {
  width: fit-content;
  max-width: 95vw;
  min-width: 400px;
  margin: 40px auto;
}

/* resize: both lives here; overflow: auto is required — 'hidden' suppresses
   the grip handle in WebKit/Safari even though the spec permits it */
#licenseDetailsModal .modal-content {
  resize: both;
  overflow: auto;
  width: min(760px, 85vw);
  min-width: 400px;
  min-height: 350px;
  display: flex;
  flex-direction: column;
  border: none;
  border-radius: var(--radius-md);
  background: var(--color-white);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.3);
}

/* Blue header matching the page's primary color */
#licenseDetailsModal .modal-header {
  display: flex;
  align-items: center;
  padding: 14px var(--space-lg);
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-hover) 100%);
  border-bottom: none;
  flex-shrink: 0;
  border-radius: var(--radius-md) var(--radius-md) 0 0;
}

#licenseDetailsModal .modal-title {
  flex: 1;
  order: 1;
  font-size: var(--font-size-lg);
  font-weight: 700;
  color: var(--color-white);
  margin: 0;
  letter-spacing: -0.01em;
}

/* Close button — forced right via flex order, white on blue */
#licenseDetailsModal .close {
  order: 2;
  float: none;
  color: rgba(255, 255, 255, 0.9);
  opacity: 1;
  text-shadow: none;
  font-size: 20px;
  font-weight: 400;
  line-height: 1;
  padding: 4px 8px;
  margin: -4px -8px -4px var(--space-md);
  background: none;
  border: none;
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: background-color var(--transition-fast);
}

#licenseDetailsModal .close:hover,
#licenseDetailsModal .close:focus {
  background-color: rgba(255, 255, 255, 0.2);
  color: var(--color-white);
  opacity: 1;
}

/* Body scrolls independently when dialog is small */
#licenseDetailsModal .modal-body {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: var(--space-lg);
  background: var(--color-gray-50);
}

/* Footer with right-aligned close action */
#licenseDetailsModal .modal-footer {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  flex-shrink: 0;
  padding: var(--space-sm) var(--space-lg);
  border-top: 1px solid var(--color-gray-200);
  background: var(--color-white);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
}

#licenseDetailsModal .modal-footer .btn-default {
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-300);
  color: var(--color-gray-700);
  border-radius: var(--radius-sm);
  padding: 7px 22px;
  font-size: var(--font-size-sm);
  font-weight: 500;
  transition: background-color var(--transition-fast), border-color var(--transition-fast);
}

#licenseDetailsModal .modal-footer .btn-default:hover {
  background-color: var(--color-gray-100);
  border-color: var(--color-gray-400);
  color: var(--color-gray-900);
}

/* License data layout */
.license-details-layout {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.license-details-section {
  background: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-sm);
  padding: var(--space-md);
  box-shadow: var(--shadow-sm);
}

/* Section title uses primary blue accent to match the page */
.license-section-title {
  margin: 0 0 var(--space-sm) 0;
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-primary);
  font-weight: 700;
  padding-bottom: var(--space-xs);
  border-bottom: 2px solid var(--color-gray-100);
}

.license-spec-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
}

.license-spec-row {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: var(--space-md);
  align-items: start;
  padding: 8px 0;
  border-bottom: 1px solid var(--color-gray-100);
}

.license-spec-row:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.license-spec-key {
  font-size: var(--font-size-xs);
  font-weight: 700;
  color: var(--color-gray-500);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding-top: 1px;
}

.license-spec-value {
  font-size: var(--font-size-sm);
  color: var(--color-gray-800);
  word-break: break-word;
  line-height: var(--line-height-normal);
}

.license-description {
  margin: 0;
  font-size: var(--font-size-sm);
  color: var(--color-gray-700);
  line-height: var(--line-height-normal);
}

.license-empty-state {
  border: 1px dashed var(--color-gray-300);
  border-radius: var(--radius-sm);
  background: var(--color-gray-50);
  color: var(--color-gray-500);
  font-size: var(--font-size-sm);
  padding: var(--space-lg) var(--space-md);
  text-align: center;
}

@media (max-width: 767px) {
  #licenseDetailsModal .modal-dialog {
    width: 95vw;
    min-width: auto;
    resize: none;
  }

  .license-spec-row {
    grid-template-columns: 1fr;
    gap: 2px;
  }
}

.round {
  border-radius: var(--radius-lg);
}

button.close {
  padding:0;
  background:0 0;
  border:0
}

.close {
  font-size:21px;
  font-weight:700;
  opacity:.2
}

.close:hover {
  color:#000;
  text-decoration:none;
  cursor:pointer;
  opacity:.5
}
