P(      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJK L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                                                                                                                                                                   ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                 !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~None$/9;IM3The star selector applies to all elements. Maps to * in CSS.<Select elements by name. The preferred syntax is to enable OverloadedStrings and actually just use "element-name"- or use one of the predefined elements from  Clay.Elements.Named alias for  . $The deep selector composer. Maps to  sel1 sel2 in CSS.!Named alias for "."%The child selector composer. Maps to  sel1 > sel2 in CSS.#(The adjacent selector composer. Maps to  sel1 + sel2 in CSS.$Named alias for %.%SThe filter selector composer, adds a filter to a selector. Maps to something like  sel#filter or  sel.filter! in CSS, depending on the filter.&:Filter elements by id. The preferred syntax is to enable OverloadedStrings and use  "#id-name".'=Filter elements by class. The preferred syntax is to enable OverloadedStrings and use  ".class-name".(WFilter elements by pseudo selector or pseudo class. The preferred syntax is to enable OverloadedStrings and use ":pseudo-selector") or use one of the predefined ones from  Clay.Pseudo.)pFilter elements by pseudo selector functions. The preferred way is to use one of the predefined functions from  Clay.Pseudo.*aFilter elements based on the presence of a certain attribute. The preferred syntax is to enable OverloadedStrings and use "@attr"( or use one of the predefined ones from Clay.Attributes.+WFilter elements based on the presence of a certain attribute with the specified value.,bFilter elements based on the presence of a certain attribute that begins with the selected value.-aFilter elements based on the presence of a certain attribute that ends with the specified value..oFilter elements based on the presence of a certain attribute that contains the specified value as a substring./Filter elements based on the presence of a certain attribute that have the specified value contained in a space separated list.0Filter elements based on the presence of a certain attribute that have the specified value contained in a hyphen separated list.6  !"#$%&'()*+,-./0123453   !"#$%&'()*+,-./0126 !"#$%&'()*+,-./0 51 423   !"#$%&'()*+,-./012345NoneI%=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`a=>?@ABCDEFGHIJKLMNOPQRSTU%IJKLMa`NOPFGHQCDEAB_?@^]=>\[RZYXWVSTU=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`aU NonenThe other type class is used to escape from the type safety introduced by embedding CSS properties into the typed world of Clay. n allows you to cast any C to a specific value type.YCommon list browser prefixes to make experimental properties work in different browsers.Syntax for CSS function call.&Some auxiliary mathematical functions.3nopqrstuvwxyz{|}~'nopqrstuvwxyz{|}~3~|}z{xyvwturspqno'nopqrstuvwxyz{|}~None9;IThe d context is used to collect style rules which are mappings from selectors to style properties. The  type is a computation in the 6 monad that just collects and doesn't return anything.>Add a new style property to the stylesheet with the specified F6 and value. The value can be any type that is in the A5 typeclass, with other words: can be converted to a C.>Add a new style property to the stylesheet with the specified F and value, like  but use a I key.The colon operator can be used to add style rules to the current context for which there is no embedded version available. Both the key and the value are plain text values and rendered as is to the output CSS.oAssign a stylesheet to a selector. When the selector is nested inside an outer scope it will be composed with .oAssign a stylesheet to a selector. When the selector is nested inside an outer scope it will be composed with ".zAssign a stylesheet to a filter selector. When the selector is nested inside an outer scope it will be composed with the $ selector.1Root is used to add style rules to the top scope.Pop is used to add style rules to selectors defined in an outer scope. The counter specifies how far up the scope stack we want to add the rules.IApply a set of style rules when the media type and feature queries apply.PApply a set of style rules when the media type and feature queries do not apply.NApply a set of style rules only when the media type and feature queries apply.Define a new font-face.Import a CSS file from a URL-,-4555NoneIFocus behaviour.Selection mode.Selection mode.Selection mode.!Enabling user interface elements.Selection mode.Selection mode.Modifiability of an element.Selection mode.Selection mode.Selection mode.Content selection granularity.Selection mode.Selection mode.Selection mode.Selection mode.Content focusing granularity. Focus mode. Focus mode. Focus mode. Focus mode. Focus mode.None-name of format according to CSS specification    NoneI!   !"#$%&'()   !"#$%&'()# !" &$% '()   !"#$%&'()NoneD=Configuration to print to a pretty human readable CSS output.E<Configuration to print to a compacted unreadable CSS output.F[Configuration to print to a compacted unreadable CSS output for embedding inline with HTML.G/Render to CSS using the default configuration (D-) and directly print to the standard output.H[Render a stylesheet with the default configuration. The pretty printer is used by default.IMRender a stylesheet with a custom configuration and an optional outer scope.JRender a single CSS ."9:;<=>?@ABCDEFGHIJ9:;<=>?@ABCDEFGHIJ9:;<=>?@ABCDEHFGIJ9 :;<=>?@ABCDEFGHIJ NoneILTime in seconds.MTime in milliseconds.KLMNOKLMKLMKLMNO NoneIVWXYZ[\]^_`abcdefghijVWXYZ[\]^_`abcdefghijWXYZ[\Vgh]^_`abcdefijVWXYZ[\]^_`abcdefghij NoneI!nopqrstuvwxyz{|}~nopqrstuvwxyz{|}~stuvrwxyz{|}q~ponnopqrstuvwxyz{|}~ None      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJK      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEKJIHGF      !"#$%&'()*+,-./0123456789:;<=>?@ABCDE      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJK None /9;ACDIRT<Type family to define what is the result of a calc operationFWhen combining percentages with units using calc, we get a combinationT"Sizes can be given in percentages.U5Sizes can be given using a length unit (e.g. em, px).V Zero size.W/Unitless size (as recommended for line-height).XSize in centimeters.YSize in millimeters.ZSize in inches (1in = 2.54 cm).[Size in pixels.\#Size in points (1pt = 1/72 of 1in).]Size in picas (1pc = 12pt).^7Size in em's (computed cssDoubleText of the font-size)._;SimpleSize in ex'es (x-height of the first avaliable font).`DSimpleSize in rem's (em's, but always relative to the root element).a0SimpleSize in vw's (1vw = 1% of viewport width).b1SimpleSize in vh's (1vh = 1% of viewport height).c/SimpleSize in vmin's (the smaller of vw or vh).d.SimpleSize in vmax's (the larger of vw or vh).eSimpleSize in percents.f1Plus operator to combine sizes into calc functiong2Minus operator to combine sizes into calc functionh2Times operator to combine sizes into calc functioni;Reversed times operator to combine sizes into calc functionj5Division operator to combine sizes into calc functionnAngle in degrees.oAngle in radians.p1Angle in gradians (also knows as gons or grades).qAngle in turns.@NOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~$NOPQRSTUVWXYZ[\]^_`abcdefghijklmnopq$SUTVWXYZ[\]^_e`abcdfgihjkmlNRQPOnopq9NOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~f6g6h7i7j7NoneIj[[^NoneIB !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPA !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPA !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPA !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPNoneI VWXYZ[\]^ VWXYZ[\]^ VWXYZ[\]^ VWXYZ[\]^None9;ImWe implement the generic background property as a type class that accepts multiple value types. This allows us to combine different background aspects into a shorthand syntax.OWe have to prefix these values to avoid conflict with existing property names.OWe have to prefix these values to avoid conflict with existing property names.OWe have to prefix these values to avoid conflict with existing property names.OWe have to prefix these values to avoid conflict with existing property names.OWe have to prefix these values to avoid conflict with existing property names.OWe have to prefix these values to avoid conflict with existing property names.Nabcdefghijklmnopqrstuvwxyz{|}~7Aabcdefghijklmnopqrstuvwxyz{|}~8mnolrspqkwxtuvjyz{|}~hgfiedcabAbBabcdefghijklmnopqrstuvwxyz{|}~None9;IWe implement the generic mask property as a type class that accepts multiple value types. This allows us to combine different mask aspects into a shorthand syntax.*(None9;ICSS Flexible Box Layout %http://dev.w3.org/csswg/css-flexbox-1.     )     .     #     None9;IThe five generic font families. 6http://www.w3.org/TR/css3-fonts/#generic-font-families.LWe implement the generic font property as a type class that accepts multiple value types. This allows us to combine different font aspects into a shorthand syntax. Fonts require a mandatory part and have a optional a part. *http://www.w3.org/TR/css3-fonts/#font-propNAn alias for color.UThe U style rules takes to lists of font families: zero or more custom font-families and preferably one or more generic font families.:CDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstu/CDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopq/LMJKHINOUPQRSTG_`VWXYZ[\]^FcabEedDjfghiCklmnopq1CDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuNoneNone9;INoneIPEEENoneI+,-./0123456789:;<=>?@AB+,-./0123456789:;<=>?@AB+,-89:;<./01234567=>?@AB+,-./0123456789:;<=>?@ABNoneIEFGHIJKLMNOPQREFGHIJKLMNOPQREFGHIJKLMNOPQREFGHIJKLMNOPQRNoneI/VWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~,VWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~,WXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~V.VWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~None dSpecial cases, these items occur both as an HTML tag and an HTML attribute. We keep them polymorph.dSpecial cases, these items occur both as an HTML tag and an HTML attribute. We keep them polymorph.dSpecial cases, these items occur both as an HTML tag and an HTML attribute. We keep them polymorph.dSpecial cases, these items occur both as an HTML tag and an HTML attribute. We keep them polymorph.dSpecial cases, these items occur both as an HTML tag and an HTML attribute. We keep them polymorph.dSpecial cases, these items occur both as an HTML tag and an HTML attribute. We keep them polymorph.dSpecial cases, these items occur both as an HTML tag and an HTML attribute. We keep them polymorph.dSpecial cases, these items occur both as an HTML tag and an HTML attribute. We keep them polymorph.dSpecial cases, these items occur both as an HTML tag and an HTML attribute. We keep them polymorph.rrrrNonem      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abm      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abm      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abm      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abNone%cdefghijklmnopqrstuvwxyz{|}~%cdefghijklmnopqrstuvwxyz{|}~%cdefghijklmnopqrstuvwxyz{|}~%cdefghijklmnopqrstuvwxyz{|}~Noner  "#%&'()*+,-./0=>?@ABCDEFGHIJKLMNOPQRSTUnopqrstuvwxyz{|}~   !"#$%&'()DEGHIJKLMVWXYZ[\]^_`abcdefghijnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDENOPQRSTUVWXYZ[\]^_`abcdefghijklmnopq !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPVWXYZ[\]^abcdefghijklmnopqrstuvwxyz{|}~     CDEFGHIJKLMNOPQRSTUVWYZ[\]^_`abcdefghijnopq+,-./0123456789:;<=>?@ABEFGIJKLMNOQR      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPRSTUVWYZ]^_bcdefghijklmnoprstuvwxyz{|}'HIGDEJ  "%#&'()*+,-./0  !"#$%&'()*++,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZZ[[\]^^_``abbcdefghijklmnopqrstuvwxyz{|}~'      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLLMNOPQRSTUVWXYZ[\ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                                                                                                                                                                    ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                                 !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRRSSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopWqrstuvwxyz{|}~sou`     t !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKL?MNO]PQRSTUVWXYZ[\]^_`abcdef:Lg!hijklm !nopqrstuvwxyz{ ] h      | } _ ~      !gtuvwxyz{|}MNOPQ2L[A"clay-0.12.1-6yS1WpoQtjvA1g9hCguN1f Clay.Selector Clay.Property Clay.CommonClay.Stylesheet Clay.Dynamic Clay.FontFace Clay.List Clay.Render Clay.TimeClay.TransitionClay.Animation Clay.Color Clay.Size Clay.Display Clay.BorderClay.BoxClay.Background Clay.Mask Clay.Flexbox Clay.Font Clay.Geometry Clay.Gradient Clay.TextClay.Transform Clay.Filter Clay.Media Clay.ElementsClay.Attributes Clay.PseudoClaySelector SelectorFFixInoutPathStarElemChildDeepAdjacentCombined RefinementunFilter PredicateIdClassAttrAttrVal AttrBeginsAttrEnds AttrContains AttrSpaceAttrHyphPseudo PseudoFunc PseudoElemstarelementdeep**child|>|+with#byIdbyClasspseudofuncattr@=^=$=*=~=|=filterFromTexttext $fMonoidFix $fIsStringFix$fIsStringRefinement $fEqPredicate$fOrdPredicate$fShowPredicate$fShowRefinement $fShowPath$fShowSelectorF $fShowFixE5LiteralValvalueValueunValueKeyunKeysPrefixedPlain unPrefixedunPlainmergeplainquotecast cssDoubleText interspersenoCommas!$fVal[] $fValEither$fVal(,) $fValMaybe $fValValue $fValDouble$fHasResolutionE5 $fValInteger $fValLiteral $fValText$fMonoidPrefixed$fIsStringPrefixed$fShowPrefixed $fEqPrefixed $fShowKey $fMonoidKey $fIsStringKey $fShowValue $fMonoidValue$fIsStringValue $fEqValue $fShowLiteral$fMonoidLiteral$fIsStringLiteralOtherotherUnsetunsetInitialinitialHiddenhiddenVisiblevisibleNormalnormalNonenoneInheritinheritCentercenterBaselinebaselineAutoautoAllallallValue autoValue baselineValue centerValue inheritValue normalValue noneValue visibleValue hiddenValue initialValue unsetValuebrowserscallfracMod decimalRound $fUnsetValue$fInitialValue $fOtherValue $fHiddenValue$fVisibleValue $fNoneValue $fNormalValue$fInheritValue $fCenterValue$fBaselineValue $fAutoValue $fAllValueCssStyleMSRulePropertyNestedQueryFaceKeyframeImport KeyframesAppSelfRootPopSubFeature MediaQuery NotOrOnlyNotOnly MediaTyperunSrulekeyprefixed-:?